1 /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3 * Data Differential YATL (i.e. libtest) library
5 * Copyright (C) 2012 Data Differential, http://datadifferential.com/
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
14 * * Redistributions in binary form must reproduce the above
15 * copyright notice, this list of conditions and the following disclaimer
16 * in the documentation and/or other materials provided with the
19 * * The names of its contributors may not be used to endorse or
20 * promote products derived from this software without specific prior
23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
38 #include <libtest/common.h>
49 #include <sys/types.h>
55 #ifndef __INTEL_COMPILER
56 #pragma GCC diagnostic ignored "-Wold-style-cast"
59 using namespace libtest
;
61 static void stats_print(Framework
*frame
)
63 if (frame
->failed() == 0 and frame
->success() == 0)
69 Out
<< "Collections\t\t\t\t\t" << frame
->total();
70 Out
<< "\tFailed\t\t\t\t\t" << frame
->failed();
71 Out
<< "\tSkipped\t\t\t\t\t" << frame
->skipped();
72 Out
<< "\tSucceeded\t\t\t\t" << frame
->success();
74 Out
<< "Tests\t\t\t\t\t" << frame
->sum_total();
75 Out
<< "\tFailed\t\t\t\t" << frame
->sum_failed();
76 Out
<< "\tSkipped\t\t\t\t" << frame
->sum_skipped();
77 Out
<< "\tSucceeded\t\t\t" << frame
->sum_success();
83 int main(int argc
, char *argv
[])
85 bool opt_massive
= false;
86 unsigned long int opt_repeat
= 1; // Run all tests once
87 bool opt_quiet
= false;
88 std::string collection_to_run
;
95 OPT_LIBYATL_MATCH_COLLECTION
,
98 OPT_LIBYATL_MATCH_WILDCARD
,
102 static struct option long_options
[]=
104 { "version", no_argument
, NULL
, OPT_LIBYATL_VERSION
},
105 { "quiet", no_argument
, NULL
, OPT_LIBYATL_QUIET
},
106 { "repeat", no_argument
, NULL
, OPT_LIBYATL_REPEAT
},
107 { "collection", required_argument
, NULL
, OPT_LIBYATL_MATCH_COLLECTION
},
108 { "wildcard", required_argument
, NULL
, OPT_LIBYATL_MATCH_WILDCARD
},
109 { "massive", no_argument
, NULL
, OPT_LIBYATL_MASSIVE
},
116 int option_rv
= getopt_long(argc
, argv
, "", long_options
, &option_index
);
124 case OPT_LIBYATL_VERSION
:
127 case OPT_LIBYATL_QUIET
:
131 case OPT_LIBYATL_REPEAT
:
132 opt_repeat
= strtoul(optarg
, (char **) NULL
, 10);
135 case OPT_LIBYATL_MATCH_COLLECTION
:
136 collection_to_run
= optarg
;
139 case OPT_LIBYATL_MATCH_WILDCARD
:
143 case OPT_LIBYATL_MASSIVE
:
148 /* getopt_long already printed an error message. */
149 Error
<< "unknown option to getopt_long()";
158 srandom((unsigned int)time(NULL
));
160 if (bool(getenv("YATL_REPEAT")) and (strtoul(getenv("YATL_REPEAT"), (char **) NULL
, 10) > 1))
162 opt_repeat
= strtoul(getenv("YATL_REPEAT"), (char **) NULL
, 10);
165 if ((bool(getenv("YATL_QUIET")) and (strcmp(getenv("YATL_QUIET"), "0") == 0)) or opt_quiet
)
169 else if (getenv("JENKINS_URL"))
171 if (bool(getenv("YATL_QUIET")) and (strcmp(getenv("YATL_QUIET"), "1") == 0))
181 close(STDOUT_FILENO
);
185 if (getenv("LIBTEST_TMP"))
187 snprintf(buffer
, sizeof(buffer
), "%s", getenv("LIBTEST_TMP"));
191 snprintf(buffer
, sizeof(buffer
), "%s", LIBTEST_TEMP
);
194 if (chdir(buffer
) == -1)
196 char getcwd_buffer
[1024];
197 char *dir
= getcwd(getcwd_buffer
, sizeof(getcwd_buffer
));
199 Error
<< "Unable to chdir() from " << dir
<< " to " << buffer
<< " errno:" << strerror(errno
);
203 if (libtest::libtool() == NULL
)
205 Error
<< "Failed to locate libtool";
209 if (getenv("YATL_COLLECTION_TO_RUN"))
211 if (strlen(getenv("YATL_COLLECTION_TO_RUN")))
213 collection_to_run
= getenv("YATL_COLLECTION_TO_RUN");
217 if (collection_to_run
.compare("none") == 0)
222 if (collection_to_run
.empty() == false)
224 Out
<< "Only testing " << collection_to_run
;
233 exit_code
= EXIT_SUCCESS
;
234 fatal_assert(sigignore(SIGPIPE
) == 0);
236 libtest::SignalThread signal
;
237 if (signal
.setup() == false)
239 Error
<< "Failed to setup signals";
243 std::auto_ptr
<Framework
> frame(new Framework(signal
, collection_to_run
, wildcard
));
245 // Run create(), bail on error.
247 switch (frame
->create())
253 Out
<< "SKIP " << argv
[0];
263 if (signal
.is_shutdown() == false)
265 signal
.set_shutdown(SHUTDOWN_GRACEFUL
);
268 shutdown_t status
= signal
.get_shutdown();
269 if (status
== SHUTDOWN_FORCED
)
271 Out
<< "Tests were aborted.";
272 exit_code
= EXIT_FAILURE
;
274 else if (frame
->failed())
276 Out
<< "Some test failed.";
277 exit_code
= EXIT_FAILURE
;
279 else if (frame
->skipped() and frame
->failed() and frame
->success())
281 Out
<< "Some tests were skipped.";
283 else if (frame
->success() and (frame
->failed() == 0))
285 Out
<< "All tests completed successfully.";
288 stats_print(frame
.get());
290 Outn(); // Generate a blank to break up the messages if make check/test has been run
291 } while (exit_code
== EXIT_SUCCESS
and --opt_repeat
);
293 catch (libtest::fatal
& e
)
295 std::cerr
<< e
.what() << std::endl
;
296 exit_code
= EXIT_FAILURE
;
298 catch (libtest::disconnected
& e
)
300 std::cerr
<< "Unhandled disconnection occurred:" << e
.what() << std::endl
;
301 exit_code
= EXIT_FAILURE
;
303 catch (std::exception
& e
)
305 std::cerr
<< e
.what() << std::endl
;
306 exit_code
= EXIT_FAILURE
;
310 std::cerr
<< "Unknown exception halted execution." << std::endl
;
311 exit_code
= EXIT_FAILURE
;