xref: /netbsd-src/external/bsd/kyua-testers/dist/atf_inttest.c (revision 754f425fc237c181450c91977727274098801c74)
1*754f425fSjmmv // Copyright 2012 Google Inc.
2*754f425fSjmmv // All rights reserved.
3*754f425fSjmmv //
4*754f425fSjmmv // Redistribution and use in source and binary forms, with or without
5*754f425fSjmmv // modification, are permitted provided that the following conditions are
6*754f425fSjmmv // met:
7*754f425fSjmmv //
8*754f425fSjmmv // * Redistributions of source code must retain the above copyright
9*754f425fSjmmv //   notice, this list of conditions and the following disclaimer.
10*754f425fSjmmv // * Redistributions in binary form must reproduce the above copyright
11*754f425fSjmmv //   notice, this list of conditions and the following disclaimer in the
12*754f425fSjmmv //   documentation and/or other materials provided with the distribution.
13*754f425fSjmmv // * Neither the name of Google Inc. nor the names of its contributors
14*754f425fSjmmv //   may be used to endorse or promote products derived from this software
15*754f425fSjmmv //   without specific prior written permission.
16*754f425fSjmmv //
17*754f425fSjmmv // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18*754f425fSjmmv // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19*754f425fSjmmv // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20*754f425fSjmmv // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21*754f425fSjmmv // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22*754f425fSjmmv // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23*754f425fSjmmv // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*754f425fSjmmv // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*754f425fSjmmv // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*754f425fSjmmv // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27*754f425fSjmmv // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*754f425fSjmmv 
29*754f425fSjmmv #include <stdlib.h>
30*754f425fSjmmv 
31*754f425fSjmmv #include <atf-c.h>
32*754f425fSjmmv 
33*754f425fSjmmv #define INTERFACE "atf"
34*754f425fSjmmv #include "common_inttest.h"
35*754f425fSjmmv 
36*754f425fSjmmv 
37*754f425fSjmmv ATF_TC(list__ok);
ATF_TC_HEAD(list__ok,tc)38*754f425fSjmmv ATF_TC_HEAD(list__ok, tc) { setup(tc, true); }
ATF_TC_BODY(list__ok,tc)39*754f425fSjmmv ATF_TC_BODY(list__ok, tc)
40*754f425fSjmmv {
41*754f425fSjmmv     char* helpers = helpers_path(tc);
42*754f425fSjmmv     check(EXIT_SUCCESS,
43*754f425fSjmmv           "test_case{name='fail'}\n"
44*754f425fSjmmv           "test_case{name='pass'}\n"
45*754f425fSjmmv           "test_case{name='signal'}\n"
46*754f425fSjmmv           "test_case{name='sleep'}\n"
47*754f425fSjmmv           "test_case{name='cleanup_check_work_directory', has_cleanup='true'}\n"
48*754f425fSjmmv           "test_case{name='cleanup_fail', has_cleanup='true'}\n"
49*754f425fSjmmv           "test_case{name='cleanup_signal', has_cleanup='true'}\n"
50*754f425fSjmmv           "test_case{name='cleanup_sleep', has_cleanup='true'}\n"
51*754f425fSjmmv           "test_case{name='body_and_cleanup_fail', has_cleanup='true'}\n"
52*754f425fSjmmv           "test_case{name='print_config', has_cleanup='true'}\n",
53*754f425fSjmmv           "",
54*754f425fSjmmv           "list", helpers, NULL);
55*754f425fSjmmv     free(helpers);
56*754f425fSjmmv }
57*754f425fSjmmv 
58*754f425fSjmmv 
59*754f425fSjmmv ATF_TC(test__pass);
ATF_TC_HEAD(test__pass,tc)60*754f425fSjmmv ATF_TC_HEAD(test__pass, tc) { setup(tc, true); }
ATF_TC_BODY(test__pass,tc)61*754f425fSjmmv ATF_TC_BODY(test__pass, tc)
62*754f425fSjmmv {
63*754f425fSjmmv     char* helpers = helpers_path(tc);
64*754f425fSjmmv     check(EXIT_SUCCESS,
65*754f425fSjmmv           "First line to stdout\nSecond line to stdout\n",
66*754f425fSjmmv           "First line to stderr\nSecond line to stderr\n",
67*754f425fSjmmv           "test", helpers, "pass", "test-result", NULL);
68*754f425fSjmmv     free(helpers);
69*754f425fSjmmv 
70*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result", "passed\n"));
71*754f425fSjmmv }
72*754f425fSjmmv 
73*754f425fSjmmv 
74*754f425fSjmmv ATF_TC(test__fail);
ATF_TC_HEAD(test__fail,tc)75*754f425fSjmmv ATF_TC_HEAD(test__fail, tc) { setup(tc, true); }
ATF_TC_BODY(test__fail,tc)76*754f425fSjmmv ATF_TC_BODY(test__fail, tc)
77*754f425fSjmmv {
78*754f425fSjmmv     char* helpers = helpers_path(tc);
79*754f425fSjmmv     check(EXIT_FAILURE, "First line to stdout\n", "First line to stderr\n",
80*754f425fSjmmv           "test", helpers, "fail", "test-result", NULL);
81*754f425fSjmmv     free(helpers);
82*754f425fSjmmv 
83*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result",
84*754f425fSjmmv         "failed: This is the failure message\n"));
85*754f425fSjmmv }
86*754f425fSjmmv 
87*754f425fSjmmv 
88*754f425fSjmmv ATF_TC(test__crash);
ATF_TC_HEAD(test__crash,tc)89*754f425fSjmmv ATF_TC_HEAD(test__crash, tc) { setup(tc, true); }
ATF_TC_BODY(test__crash,tc)90*754f425fSjmmv ATF_TC_BODY(test__crash, tc)
91*754f425fSjmmv {
92*754f425fSjmmv     char* helpers = helpers_path(tc);
93*754f425fSjmmv     check(EXIT_FAILURE, "", "save:crash.err",
94*754f425fSjmmv           "test", helpers, "signal", "test-result", NULL);
95*754f425fSjmmv     free(helpers);
96*754f425fSjmmv 
97*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result",
98*754f425fSjmmv         "broken: Premature exit; test case received signal 6 (core dumped)\n"));
99*754f425fSjmmv 
100*754f425fSjmmv     ATF_REQUIRE(atf_utils_grep_file("About to die due to SIGABRT!",
101*754f425fSjmmv                                     "crash.err"));
102*754f425fSjmmv     ATF_REQUIRE(atf_utils_grep_file("attempting to gather stack trace",
103*754f425fSjmmv                                     "crash.err"));
104*754f425fSjmmv }
105*754f425fSjmmv 
106*754f425fSjmmv 
107*754f425fSjmmv ATF_TC(test__timeout);
ATF_TC_HEAD(test__timeout,tc)108*754f425fSjmmv ATF_TC_HEAD(test__timeout, tc) { setup(tc, true); }
ATF_TC_BODY(test__timeout,tc)109*754f425fSjmmv ATF_TC_BODY(test__timeout, tc)
110*754f425fSjmmv {
111*754f425fSjmmv     char* helpers = helpers_path(tc);
112*754f425fSjmmv     check(EXIT_FAILURE, "", "Subprocess timed out; sending KILL signal...\n",
113*754f425fSjmmv           "-t1", "test", helpers, "sleep", "test-result", NULL);
114*754f425fSjmmv     free(helpers);
115*754f425fSjmmv 
116*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result",
117*754f425fSjmmv                                        "broken: Test case body timed out\n"));
118*754f425fSjmmv }
119*754f425fSjmmv 
120*754f425fSjmmv 
121*754f425fSjmmv ATF_TC(test__result_priority);
ATF_TC_HEAD(test__result_priority,tc)122*754f425fSjmmv ATF_TC_HEAD(test__result_priority, tc) { setup(tc, true); }
ATF_TC_BODY(test__result_priority,tc)123*754f425fSjmmv ATF_TC_BODY(test__result_priority, tc)
124*754f425fSjmmv {
125*754f425fSjmmv     char* helpers = helpers_path(tc);
126*754f425fSjmmv     check(EXIT_FAILURE, "Killing cleanup\n", "",
127*754f425fSjmmv           "test", "-vhas.cleanup=true", helpers, "body_and_cleanup_fail",
128*754f425fSjmmv           "test-result", NULL);
129*754f425fSjmmv     free(helpers);
130*754f425fSjmmv 
131*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result", "failed: Body fails\n"));
132*754f425fSjmmv }
133*754f425fSjmmv 
134*754f425fSjmmv 
135*754f425fSjmmv ATF_TC(test__cleanup__ok);
ATF_TC_HEAD(test__cleanup__ok,tc)136*754f425fSjmmv ATF_TC_HEAD(test__cleanup__ok, tc) { setup(tc, true); }
ATF_TC_BODY(test__cleanup__ok,tc)137*754f425fSjmmv ATF_TC_BODY(test__cleanup__ok, tc)
138*754f425fSjmmv {
139*754f425fSjmmv     char* helpers = helpers_path(tc);
140*754f425fSjmmv     check(EXIT_SUCCESS,
141*754f425fSjmmv           "Body stdout\nCleanup stdout\n"
142*754f425fSjmmv               "Cleanup properly ran in the same directory as the body\n",
143*754f425fSjmmv           "Body stderr\nCleanup stderr\n",
144*754f425fSjmmv           "test", "-vhas.cleanup=true", helpers, "cleanup_check_work_directory",
145*754f425fSjmmv           "test-result", NULL);
146*754f425fSjmmv     free(helpers);
147*754f425fSjmmv 
148*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result", "passed\n"));
149*754f425fSjmmv }
150*754f425fSjmmv 
151*754f425fSjmmv 
152*754f425fSjmmv ATF_TC(test__cleanup__fail);
ATF_TC_HEAD(test__cleanup__fail,tc)153*754f425fSjmmv ATF_TC_HEAD(test__cleanup__fail, tc) { setup(tc, true); }
ATF_TC_BODY(test__cleanup__fail,tc)154*754f425fSjmmv ATF_TC_BODY(test__cleanup__fail, tc)
155*754f425fSjmmv {
156*754f425fSjmmv     char* helpers = helpers_path(tc);
157*754f425fSjmmv     check(EXIT_FAILURE, "", "",
158*754f425fSjmmv           "test", "-vhas.cleanup=true", helpers, "cleanup_fail", "test-result",
159*754f425fSjmmv           NULL);
160*754f425fSjmmv     free(helpers);
161*754f425fSjmmv 
162*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result", "broken: Test case "
163*754f425fSjmmv         "cleanup exited with code 1\n"));
164*754f425fSjmmv }
165*754f425fSjmmv 
166*754f425fSjmmv 
167*754f425fSjmmv ATF_TC(test__cleanup__crash);
ATF_TC_HEAD(test__cleanup__crash,tc)168*754f425fSjmmv ATF_TC_HEAD(test__cleanup__crash, tc) { setup(tc, true); }
ATF_TC_BODY(test__cleanup__crash,tc)169*754f425fSjmmv ATF_TC_BODY(test__cleanup__crash, tc)
170*754f425fSjmmv {
171*754f425fSjmmv     char* helpers = helpers_path(tc);
172*754f425fSjmmv     check(EXIT_FAILURE, "", "save:crash.err",
173*754f425fSjmmv           "test", "-vhas.cleanup=true", helpers, "cleanup_signal",
174*754f425fSjmmv           "test-result", NULL);
175*754f425fSjmmv     free(helpers);
176*754f425fSjmmv 
177*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result",
178*754f425fSjmmv         "broken: Test case cleanup received signal 6 (core dumped)\n"));
179*754f425fSjmmv 
180*754f425fSjmmv     ATF_REQUIRE(atf_utils_grep_file("About to die due to SIGABRT!",
181*754f425fSjmmv                                     "crash.err"));
182*754f425fSjmmv     ATF_REQUIRE(atf_utils_grep_file("attempting to gather stack trace",
183*754f425fSjmmv                                     "crash.err"));
184*754f425fSjmmv }
185*754f425fSjmmv 
186*754f425fSjmmv 
187*754f425fSjmmv ATF_TC(test__cleanup__timeout);
ATF_TC_HEAD(test__cleanup__timeout,tc)188*754f425fSjmmv ATF_TC_HEAD(test__cleanup__timeout, tc) { setup(tc, true); }
ATF_TC_BODY(test__cleanup__timeout,tc)189*754f425fSjmmv ATF_TC_BODY(test__cleanup__timeout, tc)
190*754f425fSjmmv {
191*754f425fSjmmv     char* helpers = helpers_path(tc);
192*754f425fSjmmv     check(EXIT_FAILURE, "", "Subprocess timed out; sending KILL signal...\n",
193*754f425fSjmmv           "-t1", "test", "-vhas.cleanup=true", helpers, "cleanup_sleep",
194*754f425fSjmmv           "test-result", NULL);
195*754f425fSjmmv     free(helpers);
196*754f425fSjmmv 
197*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result", "broken: Test case "
198*754f425fSjmmv         "cleanup timed out\n"));
199*754f425fSjmmv }
200*754f425fSjmmv 
201*754f425fSjmmv 
202*754f425fSjmmv ATF_TC(test__config__builtin);
ATF_TC_HEAD(test__config__builtin,tc)203*754f425fSjmmv ATF_TC_HEAD(test__config__builtin, tc) { setup(tc, true); }
ATF_TC_BODY(test__config__builtin,tc)204*754f425fSjmmv ATF_TC_BODY(test__config__builtin, tc)
205*754f425fSjmmv {
206*754f425fSjmmv     char* helpers = helpers_path(tc);
207*754f425fSjmmv     check(EXIT_SUCCESS, "", "",
208*754f425fSjmmv           "test", helpers, "print_config", "test-result", NULL);
209*754f425fSjmmv     free(helpers);
210*754f425fSjmmv 
211*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result", "passed\n"));
212*754f425fSjmmv }
213*754f425fSjmmv 
214*754f425fSjmmv 
215*754f425fSjmmv ATF_TC(test__config__custom);
ATF_TC_HEAD(test__config__custom,tc)216*754f425fSjmmv ATF_TC_HEAD(test__config__custom, tc) { setup(tc, true); }
ATF_TC_BODY(test__config__custom,tc)217*754f425fSjmmv ATF_TC_BODY(test__config__custom, tc)
218*754f425fSjmmv {
219*754f425fSjmmv     char* helpers = helpers_path(tc);
220*754f425fSjmmv     check(EXIT_SUCCESS,
221*754f425fSjmmv           "body my-var1 value1\n"
222*754f425fSjmmv           "body v2 a b c foo\n"
223*754f425fSjmmv           "cleanup my-var1 value1\n"
224*754f425fSjmmv           "cleanup v2 a b c foo\n",
225*754f425fSjmmv           "",
226*754f425fSjmmv           "test", "-vmy-var1=value1", "-vv2=a b c foo", helpers,
227*754f425fSjmmv           "print_config", "test-result", NULL);
228*754f425fSjmmv     free(helpers);
229*754f425fSjmmv 
230*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result", "passed\n"));
231*754f425fSjmmv }
232*754f425fSjmmv 
233*754f425fSjmmv 
234*754f425fSjmmv ATF_TC(test__invalid_test_case_name);
ATF_TC_HEAD(test__invalid_test_case_name,tc)235*754f425fSjmmv ATF_TC_HEAD(test__invalid_test_case_name, tc) { setup(tc, false); }
ATF_TC_BODY(test__invalid_test_case_name,tc)236*754f425fSjmmv ATF_TC_BODY(test__invalid_test_case_name, tc)
237*754f425fSjmmv {
238*754f425fSjmmv     char* helpers = helpers_path(tc);
239*754f425fSjmmv     check(EXIT_FAILURE, "",  // TODO(jmmv): Should be EXIT_INTERNAL_ERROR.
240*754f425fSjmmv           "atf_helpers: ERROR: Unknown test case `foo'\n"
241*754f425fSjmmv           "atf_helpers: See atf-test-program(1) for usage details.\n",
242*754f425fSjmmv           "test", "-vhas.cleanup=false", helpers, "foo", "test-result", NULL);
243*754f425fSjmmv     free(helpers);
244*754f425fSjmmv 
245*754f425fSjmmv     ATF_REQUIRE(atf_utils_compare_file("test-result",
246*754f425fSjmmv         "broken: Premature exit; test case exited with code 1\n"));
247*754f425fSjmmv }
248*754f425fSjmmv 
249*754f425fSjmmv 
250*754f425fSjmmv ATF_TC(test__missing_test_program);
ATF_TC_HEAD(test__missing_test_program,tc)251*754f425fSjmmv ATF_TC_HEAD(test__missing_test_program, tc) { setup(tc, false); }
ATF_TC_BODY(test__missing_test_program,tc)252*754f425fSjmmv ATF_TC_BODY(test__missing_test_program, tc)
253*754f425fSjmmv {
254*754f425fSjmmv     check(EXIT_INTERNAL_ERROR, "",
255*754f425fSjmmv           "kyua-atf-tester: execvp failed: No such file or directory\n",
256*754f425fSjmmv           "test", "./non-existent", "pass", "test-result", NULL);
257*754f425fSjmmv 
258*754f425fSjmmv     ATF_REQUIRE(!atf_utils_file_exists("test-result"));
259*754f425fSjmmv }
260*754f425fSjmmv 
261*754f425fSjmmv 
ATF_TP_ADD_TCS(tp)262*754f425fSjmmv ATF_TP_ADD_TCS(tp)
263*754f425fSjmmv {
264*754f425fSjmmv     ATF_TP_ADD_TC(tp, top__missing_command);
265*754f425fSjmmv     ATF_TP_ADD_TC(tp, top__unknown_command);
266*754f425fSjmmv 
267*754f425fSjmmv     ATF_TP_ADD_TC(tp, list__ok);
268*754f425fSjmmv 
269*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__pass);
270*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__fail);
271*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__crash);
272*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__timeout);
273*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__result_priority);
274*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__cleanup__ok);
275*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__cleanup__fail);
276*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__cleanup__crash);
277*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__cleanup__timeout);
278*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__config__builtin);
279*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__config__custom);
280*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__missing_test_program);
281*754f425fSjmmv     ATF_TP_ADD_TC(tp, test__invalid_test_case_name);
282*754f425fSjmmv 
283*754f425fSjmmv     return atf_no_error();
284*754f425fSjmmv }
285