1 // Copyright 2012 Google Inc.
2 // All rights reserved.
4 // Redistribution and use in source and binary forms, with or without
5 // modification, are permitted provided that the following conditions are
8 // * Redistributions of source code must retain the above copyright
9 // notice, this list of conditions and the following disclaimer.
10 // * Redistributions in binary form must reproduce the above copyright
11 // notice, this list of conditions and the following disclaimer in the
12 // documentation and/or other materials provided with the distribution.
13 // * Neither the name of Google Inc. nor the names of its contributors
14 // may be used to endorse or promote products derived from this software
15 // without specific prior written permission.
17 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 /// \file common_inttest.h
30 /// Common integration tests for the tester binaries.
32 #if defined(KYUA_COMMON_INTTEST_H)
33 # error "common_inttest.h can only be defined once"
36 #define KYUA_COMMON_INTTEST_H
38 #if !defined(INTERFACE)
39 # error "Must define INTERFACE to the name of the tester interface"
50 #include "cli.h" // For the EXIT_* constants only.
54 /// Path to the installed testers.
55 static const char* default_testersdir
= TESTERSDIR
;
58 /// Returns the name of the current tester.
59 #define TESTER_BIN "kyua-" INTERFACE "-tester"
62 /// Returns the path to the helpers.
64 /// \param tc Pointer to the caller test case, to obtain the srcdir property.
66 /// \return A dynamically-allocated string; must be released with free(3).
68 helpers_path(const atf_tc_t
* tc
)
70 const char* srcdir
= atf_tc_get_config_var(tc
, "srcdir");
71 const char* name
= INTERFACE
"_helpers";
73 const size_t length
= strlen(srcdir
) + 1 + strlen(name
) + 1;
74 char* buffer
= (char*)malloc(length
);
75 (void)snprintf(buffer
, length
, "%s/%s", srcdir
, name
);
80 /// Returns the path to the tester.
82 /// \return A dynamically-allocated string; must be released with free(3).
86 const char* testersdir
= getenv("TESTERSDIR");
87 if (testersdir
== NULL
)
88 testersdir
= default_testersdir
;
89 const char* name
= TESTER_BIN
;
91 const size_t length
= strlen(testersdir
) + 1 + strlen(name
) + 1;
92 char* buffer
= (char*)malloc(length
);
93 ATF_REQUIRE(buffer
!= NULL
);
94 (void)snprintf(buffer
, length
, "%s/%s", testersdir
, name
);
99 /// Initializes the test case metadata and the helpers.
101 /// \param [in,out] tc The test case in which to set the property.
102 /// \param uses_helpers Whether the test uses the helpers or not.
104 setup(atf_tc_t
* tc
, const bool uses_helpers
)
106 char* tester
= tester_path();
108 char* helpers
= helpers_path(tc
);
109 atf_tc_set_md_var(tc
, "require.progs", "%s %s", tester
, helpers
);
112 atf_tc_set_md_var(tc
, "require.progs", "%s", tester
);
118 static void execute(va_list ap
) KYUA_DEFS_NORETURN
;
121 /// Executes the tester with the given set of variable arguments.
123 /// \param ap List of arguments to the tester.
127 const char* args
[16];
129 const char** current_arg
= &args
[0];
130 *current_arg
= TESTER_BIN
;
132 while ((*current_arg
= va_arg(ap
, const char*)) != NULL
)
135 char* program
= tester_path();
136 (void)execv(program
, KYUA_DEFS_UNCONST(args
));
138 err(111, "Failed to execute %s", program
);
142 /// Executes the tester and validates its output.
144 /// \param expected_exit_status Expected exit status of the subprocess.
145 /// \param expected_stdout Expected contents of stdout.
146 /// \param expected_stderr Expected contents of stderr.
147 /// \param ... Arguments to the tester, not including the program name.
149 check(const int expected_exit_status
, const char* expected_stdout
,
150 const char* expected_stderr
, ...)
152 const pid_t pid
= atf_utils_fork();
155 va_start(ap
, expected_stderr
);
159 atf_utils_wait(pid
, expected_exit_status
, expected_stdout
,
165 ATF_TC(top__missing_command
);
166 ATF_TC_HEAD(top__missing_command
, tc
) { setup(tc
, false); }
167 ATF_TC_BODY(top__missing_command
, tc
)
169 check(EXIT_USAGE_ERROR
, "", TESTER_BIN
": Must provide a command\n",
174 ATF_TC(top__unknown_command
);
175 ATF_TC_HEAD(top__unknown_command
, tc
) { setup(tc
, false); }
176 ATF_TC_BODY(top__unknown_command
, tc
)
178 check(EXIT_USAGE_ERROR
, "", TESTER_BIN
": Unknown command 'foo'\n",