1c19800e8SDoug Rabson /*
2*ae771770SStanislav Sedov * Copyright (c) 2004 Kungliga Tekniska Högskolan
3c19800e8SDoug Rabson * (Royal Institute of Technology, Stockholm, Sweden).
4c19800e8SDoug Rabson * All rights reserved.
5c19800e8SDoug Rabson *
6c19800e8SDoug Rabson * Redistribution and use in source and binary forms, with or without
7c19800e8SDoug Rabson * modification, are permitted provided that the following conditions
8c19800e8SDoug Rabson * are met:
9c19800e8SDoug Rabson *
10c19800e8SDoug Rabson * 1. Redistributions of source code must retain the above copyright
11c19800e8SDoug Rabson * notice, this list of conditions and the following disclaimer.
12c19800e8SDoug Rabson *
13c19800e8SDoug Rabson * 2. Redistributions in binary form must reproduce the above copyright
14c19800e8SDoug Rabson * notice, this list of conditions and the following disclaimer in the
15c19800e8SDoug Rabson * documentation and/or other materials provided with the distribution.
16c19800e8SDoug Rabson *
17c19800e8SDoug Rabson * 3. Neither the name of the Institute nor the names of its contributors
18c19800e8SDoug Rabson * may be used to endorse or promote products derived from this software
19c19800e8SDoug Rabson * without specific prior written permission.
20c19800e8SDoug Rabson *
21c19800e8SDoug Rabson * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
22c19800e8SDoug Rabson * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23c19800e8SDoug Rabson * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24c19800e8SDoug Rabson * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
25c19800e8SDoug Rabson * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26c19800e8SDoug Rabson * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27c19800e8SDoug Rabson * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28c19800e8SDoug Rabson * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29c19800e8SDoug Rabson * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30c19800e8SDoug Rabson * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31c19800e8SDoug Rabson * SUCH DAMAGE.
32c19800e8SDoug Rabson */
33c19800e8SDoug Rabson
34c19800e8SDoug Rabson #include <config.h>
35c19800e8SDoug Rabson
36c19800e8SDoug Rabson #include "roken.h"
37c19800e8SDoug Rabson #include "parse_time.h"
38c19800e8SDoug Rabson #include "test-mem.h"
39c19800e8SDoug Rabson #include "err.h"
40c19800e8SDoug Rabson
41c19800e8SDoug Rabson static struct testcase {
42c19800e8SDoug Rabson size_t size;
43*ae771770SStanislav Sedov int val;
44c19800e8SDoug Rabson char *str;
45c19800e8SDoug Rabson } tests[] = {
46c19800e8SDoug Rabson { 8, 1, "1 second" },
47c19800e8SDoug Rabson { 17, 61, "1 minute 1 second" },
48c19800e8SDoug Rabson { 18, 62, "1 minute 2 seconds" },
49c19800e8SDoug Rabson { 8, 60, "1 minute" },
50c19800e8SDoug Rabson { 6, 3600, "1 hour" },
51c19800e8SDoug Rabson { 15, 3601, "1 hour 1 second" },
52c19800e8SDoug Rabson { 16, 3602, "1 hour 2 seconds" }
53c19800e8SDoug Rabson };
54c19800e8SDoug Rabson
55c19800e8SDoug Rabson int
main(int argc,char ** argv)56c19800e8SDoug Rabson main(int argc, char **argv)
57c19800e8SDoug Rabson {
58c19800e8SDoug Rabson size_t sz;
59c19800e8SDoug Rabson size_t buf_sz;
60c19800e8SDoug Rabson int i, j;
61c19800e8SDoug Rabson
62c19800e8SDoug Rabson for (i = 0; i < sizeof(tests)/sizeof(tests[0]); ++i) {
63c19800e8SDoug Rabson char *buf;
64c19800e8SDoug Rabson
65c19800e8SDoug Rabson sz = unparse_time(tests[i].val, NULL, 0);
66c19800e8SDoug Rabson if (sz != tests[i].size)
67c19800e8SDoug Rabson errx(1, "sz (%lu) != tests[%d].size (%lu)",
68c19800e8SDoug Rabson (unsigned long)sz, i, (unsigned long)tests[i].size);
69c19800e8SDoug Rabson
70c19800e8SDoug Rabson for (buf_sz = 0; buf_sz < tests[i].size + 2; buf_sz++) {
71c19800e8SDoug Rabson
72c19800e8SDoug Rabson buf = rk_test_mem_alloc(RK_TM_OVERRUN, "overrun",
73c19800e8SDoug Rabson NULL, buf_sz);
74c19800e8SDoug Rabson sz = unparse_time(tests[i].val, buf, buf_sz);
75c19800e8SDoug Rabson if (sz != tests[i].size)
76c19800e8SDoug Rabson errx(1, "sz (%lu) != tests[%d].size (%lu) with in size %lu",
77c19800e8SDoug Rabson (unsigned long)sz, i,
78c19800e8SDoug Rabson (unsigned long)tests[i].size,
79c19800e8SDoug Rabson (unsigned long)buf_sz);
80c19800e8SDoug Rabson if (buf_sz > 0 && memcmp(buf, tests[i].str, buf_sz - 1) != 0)
81c19800e8SDoug Rabson errx(1, "test %i wrong result %s vs %s", i, buf, tests[i].str);
82c19800e8SDoug Rabson if (buf_sz > 0 && buf[buf_sz - 1] != '\0')
83c19800e8SDoug Rabson errx(1, "test %i not zero terminated", i);
84c19800e8SDoug Rabson rk_test_mem_free("overrun");
85c19800e8SDoug Rabson
86c19800e8SDoug Rabson buf = rk_test_mem_alloc(RK_TM_UNDERRUN, "underrun",
87c19800e8SDoug Rabson NULL, tests[i].size);
88*ae771770SStanislav Sedov sz = unparse_time(tests[i].val, buf, min(buf_sz, tests[i].size));
89c19800e8SDoug Rabson if (sz != tests[i].size)
90c19800e8SDoug Rabson errx(1, "sz (%lu) != tests[%d].size (%lu) with insize %lu",
91c19800e8SDoug Rabson (unsigned long)sz, i,
92c19800e8SDoug Rabson (unsigned long)tests[i].size,
93c19800e8SDoug Rabson (unsigned long)buf_sz);
94*ae771770SStanislav Sedov if (buf_sz > 0 && strncmp(buf, tests[i].str, min(buf_sz, tests[i].size) - 1) != 0)
95c19800e8SDoug Rabson errx(1, "test %i wrong result %s vs %s", i, buf, tests[i].str);
96*ae771770SStanislav Sedov if (buf_sz > 0 && buf[min(buf_sz, tests[i].size) - 1] != '\0')
97c19800e8SDoug Rabson errx(1, "test %i not zero terminated", i);
98c19800e8SDoug Rabson rk_test_mem_free("underrun");
99c19800e8SDoug Rabson }
100*ae771770SStanislav Sedov
101c19800e8SDoug Rabson buf = rk_test_mem_alloc(RK_TM_OVERRUN, "overrun",
102c19800e8SDoug Rabson tests[i].str, tests[i].size + 1);
103c19800e8SDoug Rabson j = parse_time(buf, "s");
104c19800e8SDoug Rabson if (j != tests[i].val)
105c19800e8SDoug Rabson errx(1, "parse_time failed for test %d", i);
106c19800e8SDoug Rabson rk_test_mem_free("overrun");
107c19800e8SDoug Rabson
108c19800e8SDoug Rabson buf = rk_test_mem_alloc(RK_TM_UNDERRUN, "underrun",
109c19800e8SDoug Rabson tests[i].str, tests[i].size + 1);
110c19800e8SDoug Rabson j = parse_time(buf, "s");
111c19800e8SDoug Rabson if (j != tests[i].val)
112c19800e8SDoug Rabson errx(1, "parse_time failed for test %d", i);
113c19800e8SDoug Rabson rk_test_mem_free("underrun");
114*ae771770SStanislav Sedov
115c19800e8SDoug Rabson }
116c19800e8SDoug Rabson return 0;
117c19800e8SDoug Rabson }
118