source: mainline/uspace/app/tester/tester.c@ 6e596bd

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 6e596bd was 9a53e00, checked in by Vojtech Horky <vojtechhorky@…>, 13 years ago

Add logger2 test - for ever log at all levels

  • Property mode set to 100644
File size: 4.1 KB
RevLine 
[b2951e2]1/*
[df4ed85]2 * Copyright (c) 2006 Ondrej Palkovsky
[dd655970]3 * Copyright (c) 2007 Martin Decky
[b2951e2]4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * - Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * - Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * - The name of the author may not be used to endorse or promote products
16 * derived from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT 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 OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
[2d11a7d8]30/** @addtogroup tester User space tester
31 * @brief User space testing infrastructure.
[b2951e2]32 * @{
[2d11a7d8]33 */
[b2951e2]34/**
35 * @file
36 */
37
[dd655970]38#include <unistd.h>
[51dbadf3]39#include <stdio.h>
[19f857a]40#include <str.h>
[f47c70d4]41#include <io/log.h>
[dd655970]42#include "tester.h"
43
[2d11a7d8]44bool test_quiet;
45int test_argc;
46char **test_argv;
[dd655970]47
48test_t tests[] = {
49#include "thread/thread1.def"
50#include "print/print1.def"
[2d11a7d8]51#include "print/print2.def"
52#include "print/print3.def"
[7a2c479]53#include "print/print4.def"
[855e0d8]54#include "print/print5.def"
[2d11a7d8]55#include "console/console1.def"
56#include "stdio/stdio1.def"
57#include "stdio/stdio2.def"
[f47c70d4]58#include "stdio/logger1.def"
[9a53e00]59#include "stdio/logger2.def"
[be66dee]60#include "fault/fault1.def"
61#include "fault/fault2.def"
[d91a20c]62#include "fault/fault3.def"
[2d11a7d8]63#include "vfs/vfs1.def"
64#include "ipc/ping_pong.def"
[3191c01]65#include "ipc/starve.def"
[ce4a3dae]66#include "loop/loop1.def"
[2d11a7d8]67#include "mm/malloc1.def"
[9e953bda]68#include "mm/malloc2.def"
[013a5d7]69#include "mm/malloc3.def"
[b93d637]70#include "mm/mapping1.def"
[ffdd2b9]71#include "hw/serial/serial1.def"
[424558a]72#include "hw/misc/virtchar1.def"
[9ffbdf1]73#include "libext2/libext2_1.def"
[2d11a7d8]74 {NULL, NULL, NULL, false}
[dd655970]75};
76
77static bool run_test(test_t *test)
[51dbadf3]78{
[dd655970]79 /* Execute the test */
[a000878c]80 const char *ret = test->entry();
[dd655970]81
82 if (ret == NULL) {
[2d11a7d8]83 printf("\nTest passed\n");
[dd655970]84 return true;
[51dbadf3]85 }
[2d11a7d8]86
87 printf("\n%s\n", ret);
[dd655970]88 return false;
[51dbadf3]89}
90
[dd655970]91static void run_safe_tests(void)
[51dbadf3]92{
[047aa46]93 test_t *test;
[e190a89b]94 unsigned int i = 0;
95 unsigned int n = 0;
[2d11a7d8]96
[e190a89b]97 printf("\n*** Running all safe tests ***\n\n");
[2d11a7d8]98
[047aa46]99 for (test = tests; test->name != NULL; test++) {
100 if (test->safe) {
[2d11a7d8]101 printf("%s (%s)\n", test->name, test->desc);
[047aa46]102 if (run_test(test))
103 i++;
104 else
105 n++;
106 }
107 }
[2d11a7d8]108
109 printf("\nCompleted, %u tests run, %u passed.\n", i + n, i);
[51dbadf3]110}
111
[dd655970]112static void list_tests(void)
[51dbadf3]113{
[2d11a7d8]114 size_t len = 0;
[dd655970]115 test_t *test;
[2d11a7d8]116 for (test = tests; test->name != NULL; test++) {
117 if (str_length(test->name) > len)
118 len = str_length(test->name);
119 }
[51dbadf3]120
[855e0d8]121 unsigned int _len = (unsigned int) len;
122 if ((_len != len) || (((int) _len) < 0)) {
123 printf("Command length overflow\n");
124 return;
125 }
126
[2d11a7d8]127 for (test = tests; test->name != NULL; test++)
[855e0d8]128 printf("%-*s %s%s\n", _len, test->name, test->desc,
129 (test->safe ? "" : " (unsafe)"));
[51dbadf3]130
[855e0d8]131 printf("%-*s Run all safe tests\n", _len, "*");
[51dbadf3]132}
133
[2d11a7d8]134int main(int argc, char *argv[])
[51dbadf3]135{
[2d11a7d8]136 if (argc < 2) {
137 printf("Usage:\n\n");
138 printf("%s <test> [args ...]\n\n", argv[0]);
[dd655970]139 list_tests();
[2d11a7d8]140 return 0;
141 }
142
[f47c70d4]143 log_init("tester", LVL_NOTE);
144
[2d11a7d8]145 test_quiet = false;
146 test_argc = argc - 2;
147 test_argv = argv + 2;
148
149 if (str_cmp(argv[1], "*") == 0) {
150 run_safe_tests();
151 return 0;
152 }
153
154 test_t *test;
155 for (test = tests; test->name != NULL; test++) {
156 if (str_cmp(argv[1], test->name) == 0) {
157 return (run_test(test) ? 0 : -1);
[51b966b]158 }
[51dbadf3]159 }
[2d11a7d8]160
161 printf("Unknown test \"%s\"\n", argv[1]);
162 return -2;
[51dbadf3]163}
[b2951e2]164
165/** @}
166 */
Note: See TracBrowser for help on using the repository browser.