|
Packit |
0b5880 |
/*
|
|
Packit |
0b5880 |
* Check: a unit test framework for C
|
|
Packit |
0b5880 |
* Copyright (C) 2001, 2002 Arien Malec
|
|
Packit |
0b5880 |
*
|
|
Packit |
0b5880 |
* This library is free software; you can redistribute it and/or
|
|
Packit |
0b5880 |
* modify it under the terms of the GNU Lesser General Public
|
|
Packit |
0b5880 |
* License as published by the Free Software Foundation; either
|
|
Packit |
0b5880 |
* version 2.1 of the License, or (at your option) any later version.
|
|
Packit |
0b5880 |
*
|
|
Packit |
0b5880 |
* This library is distributed in the hope that it will be useful,
|
|
Packit |
0b5880 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit |
0b5880 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit |
0b5880 |
* Lesser General Public License for more details.
|
|
Packit |
0b5880 |
*
|
|
Packit |
0b5880 |
* You should have received a copy of the GNU Lesser General Public
|
|
Packit |
0b5880 |
* License along with this library; if not, write to the
|
|
Packit |
0b5880 |
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
|
|
Packit |
0b5880 |
* MA 02110-1301, USA.
|
|
Packit |
0b5880 |
*/
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
#include <stdlib.h>
|
|
Packit |
0b5880 |
#include <stdio.h>
|
|
Packit |
0b5880 |
#include <string.h>
|
|
Packit |
0b5880 |
#include <check.h>
|
|
Packit |
0b5880 |
#include "config.h"
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
START_TEST(test_pass)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
ck_assert_msg(1 == 1, "Shouldn't see this");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
END_TEST
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
START_TEST(test_fail)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
ck_abort_msg("Failure");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
END_TEST
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
/*
|
|
Packit |
0b5880 |
* This test will fail without fork, as it will result in the
|
|
Packit |
0b5880 |
* unit test runniner exiting early.
|
|
Packit |
0b5880 |
*/
|
|
Packit |
0b5880 |
#if defined(HAVE_FORK) && HAVE_FORK==1
|
|
Packit |
0b5880 |
START_TEST(test_exit)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
exit(1);
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
END_TEST
|
|
Packit |
0b5880 |
#endif /* HAVE_FORK */
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
/*
|
|
Packit |
0b5880 |
* This test will intentionally mess up the unit testing program
|
|
Packit |
0b5880 |
* when fork is unavailable. The purpose of including it is to
|
|
Packit |
0b5880 |
* ensure that the tap output is correct when a test crashes.
|
|
Packit |
0b5880 |
*/
|
|
Packit |
0b5880 |
START_TEST(test_abort)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
exit(1);
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
END_TEST
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
START_TEST(test_pass2)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
ck_assert_msg(1 == 1, "Shouldn't see this");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
END_TEST
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
START_TEST(test_loop)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
ck_assert_msg(_i == 1, "Iteration %d failed", _i);
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
END_TEST
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
START_TEST(test_xml_esc_fail_msg)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
ck_abort_msg("fail \" ' < > & \x9 \xA" "X""\x08"" message"); /* backspace char \x08 deletes the X */
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
END_TEST
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
static Suite *make_log1_suite(void)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
Suite *s;
|
|
Packit |
0b5880 |
TCase *tc;
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
s = suite_create("S1");
|
|
Packit |
0b5880 |
tc = tcase_create("Core");
|
|
Packit |
0b5880 |
suite_add_tcase(s, tc);
|
|
Packit |
0b5880 |
tcase_add_test(tc, test_pass);
|
|
Packit |
0b5880 |
tcase_add_test(tc, test_fail);
|
|
Packit |
0b5880 |
#if defined(HAVE_FORK) && HAVE_FORK==1
|
|
Packit |
0b5880 |
tcase_add_test(tc, test_exit);
|
|
Packit |
0b5880 |
#endif /* HAVE_FORK */
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
return s;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
static Suite *make_log2_suite(int include_exit_test)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
Suite *s;
|
|
Packit |
0b5880 |
TCase *tc;
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
s = suite_create("S2");
|
|
Packit |
0b5880 |
tc = tcase_create("Core");
|
|
Packit |
0b5880 |
suite_add_tcase(s, tc);
|
|
Packit |
0b5880 |
if(include_exit_test == 1)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
tcase_add_test(tc, test_abort);
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
tcase_add_test(tc, test_pass2);
|
|
Packit |
0b5880 |
tcase_add_loop_test(tc, test_loop, 0, 3);
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
return s;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
/* check that XML special characters are properly escaped in XML log file */
|
|
Packit |
0b5880 |
static Suite *make_xml_esc_suite(void)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
Suite *s;
|
|
Packit |
0b5880 |
TCase *tc;
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
s = suite_create("XML escape \" ' < > & \x9 \xA" "X""\x08"" tests"); /* backspace char \x08 deletes the X */
|
|
Packit |
0b5880 |
tc = tcase_create("description \" ' < > & \x9 \xA" "X""\x08"" end"); /* backspace char \x08 deletes the X */
|
|
Packit |
0b5880 |
suite_add_tcase(s, tc);
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
tcase_add_test(tc, test_xml_esc_fail_msg);
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
return s;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
static void print_usage(void)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
printf("Usage: ex_output (CK_SILENT | CK_MINIMAL | CK_NORMAL | CK_VERBOSE | CK_ENV");
|
|
Packit |
0b5880 |
#if ENABLE_SUBUNIT
|
|
Packit |
0b5880 |
printf(" | CK_SUBUNIT");
|
|
Packit |
0b5880 |
#endif
|
|
Packit |
0b5880 |
printf(")\n");
|
|
Packit |
0b5880 |
printf(" (STDOUT | STDOUT_DUMP | LOG | LOG_STDOUT | TAP | TAP_STDOUT | XML | XML_STDOUT)\n");
|
|
Packit |
0b5880 |
printf(" (NORMAL | EXIT_TEST)\n");
|
|
Packit |
0b5880 |
printf(" If CK_ENV is used, the environment variable CK_VERBOSITY can be set to\n");
|
|
Packit |
0b5880 |
printf(" one of these: silent, minimal, or verbose. If it is not set to these, or\n");
|
|
Packit |
0b5880 |
printf(" if CK_VERBOSITY is not set, then CK_NORMAL will be used\n");
|
|
Packit |
0b5880 |
printf(" If testing the CK_[LOG|TAP_LOG|XML_LOG]_FILE_NAME env var and setting it to '-',\n");
|
|
Packit |
0b5880 |
printf(" then use the following mode: CK_SILENT STDOUT [NORMAL|EXIT_TEST].\n");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
static void run_tests(enum print_output printmode, char *log_type, int include_exit_test)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
SRunner *sr;
|
|
Packit |
0b5880 |
int dump_everything_to_stdout = 0;
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
sr = srunner_create(make_log1_suite());
|
|
Packit |
0b5880 |
srunner_add_suite(sr, make_log2_suite(include_exit_test));
|
|
Packit |
0b5880 |
srunner_add_suite(sr, make_xml_esc_suite());
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
if(strcmp(log_type, "STDOUT") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
/* Nothing else to do here */
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(log_type, "STDOUT_DUMP") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
/*
|
|
Packit |
0b5880 |
* Dump each type to stdout, in addition to printing out
|
|
Packit |
0b5880 |
* the configured print level.
|
|
Packit |
0b5880 |
*/
|
|
Packit |
0b5880 |
dump_everything_to_stdout = 1;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(log_type, "LOG") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
srunner_set_log(sr, "test.log");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(log_type, "LOG_STDOUT") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
srunner_set_log(sr, "-");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(log_type, "TAP") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
srunner_set_tap(sr, "test.tap");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(log_type, "TAP_STDOUT") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
srunner_set_tap(sr, "-");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(log_type, "XML") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
srunner_set_xml(sr, "test.xml");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(log_type, "XML_STDOUT") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
srunner_set_xml(sr, "-");
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
print_usage();
|
|
Packit |
0b5880 |
exit(EXIT_FAILURE);
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
srunner_run_all(sr, printmode);
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
if(dump_everything_to_stdout)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
srunner_print(sr, CK_SILENT);
|
|
Packit |
0b5880 |
srunner_print(sr, CK_MINIMAL);
|
|
Packit |
0b5880 |
srunner_print(sr, CK_NORMAL);
|
|
Packit |
0b5880 |
srunner_print(sr, CK_VERBOSE);
|
|
Packit |
0b5880 |
srunner_print(sr, CK_ENV);
|
|
Packit |
0b5880 |
#if ENABLE_SUBUNIT
|
|
Packit |
0b5880 |
/*
|
|
Packit |
0b5880 |
* Note that this call does not contribute anything, as
|
|
Packit |
0b5880 |
* subunit is not fully considered an 'output mode'.
|
|
Packit |
0b5880 |
*/
|
|
Packit |
0b5880 |
srunner_print(sr, CK_SUBUNIT);
|
|
Packit |
0b5880 |
#endif
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
srunner_free(sr);
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
#define OUTPUT_TYPE_ARG 1
|
|
Packit |
0b5880 |
#define LOG_TYPE_ARG 2
|
|
Packit |
0b5880 |
#define INCLUDE_EXIT_TEST_ARG 3
|
|
Packit |
0b5880 |
int main(int argc, char **argv)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
enum print_output printmode;
|
|
Packit |
0b5880 |
int include_exit_test;
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
if(argc != 4)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
print_usage();
|
|
Packit |
0b5880 |
return EXIT_FAILURE;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
if(strcmp(argv[OUTPUT_TYPE_ARG], "CK_SILENT") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
printmode = CK_SILENT;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(argv[OUTPUT_TYPE_ARG], "CK_MINIMAL") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
printmode = CK_MINIMAL;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(argv[OUTPUT_TYPE_ARG], "CK_NORMAL") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
printmode = CK_NORMAL;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(argv[OUTPUT_TYPE_ARG], "CK_VERBOSE") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
printmode = CK_VERBOSE;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(argv[OUTPUT_TYPE_ARG], "CK_ENV") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
printmode = CK_ENV;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
#if ENABLE_SUBUNIT
|
|
Packit |
0b5880 |
else if(strcmp(argv[OUTPUT_TYPE_ARG], "CK_SUBUNIT") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
printmode = CK_SUBUNIT;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
#endif
|
|
Packit |
0b5880 |
else
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
print_usage();
|
|
Packit |
0b5880 |
return EXIT_FAILURE;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
if(strcmp(argv[INCLUDE_EXIT_TEST_ARG], "NORMAL") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
include_exit_test = 0;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else if(strcmp(argv[INCLUDE_EXIT_TEST_ARG], "EXIT_TEST") == 0)
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
include_exit_test = 1;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
else
|
|
Packit |
0b5880 |
{
|
|
Packit |
0b5880 |
print_usage();
|
|
Packit |
0b5880 |
return EXIT_FAILURE;
|
|
Packit |
0b5880 |
}
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
run_tests(printmode, argv[LOG_TYPE_ARG], include_exit_test);
|
|
Packit |
0b5880 |
|
|
Packit |
0b5880 |
return EXIT_SUCCESS;
|
|
Packit |
0b5880 |
}
|