source: mainline/uspace/app/tester/tester.c@ d230358

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since d230358 was d230358, checked in by Jiri Svoboda <jiri@…>, 7 years ago

Move ping_pong into a separate performance measuring tool 'perf'.

  • Property mode set to 100644
File size: 4.5 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
[a63966d]30/** @addtogroup tester
[b2951e2]31 * @{
[2d11a7d8]32 */
[b2951e2]33/**
34 * @file
35 */
36
[51dbadf3]37#include <stdio.h>
[582a0b8]38#include <stddef.h>
[c45dc5e1]39#include <stdlib.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"
[6a5b999]50#include "thread/setjmp1.def"
[dd655970]51#include "print/print1.def"
[2d11a7d8]52#include "print/print2.def"
53#include "print/print3.def"
[7a2c479]54#include "print/print4.def"
[855e0d8]55#include "print/print5.def"
[34b9299]56#include "print/print6.def"
[2d11a7d8]57#include "console/console1.def"
58#include "stdio/stdio1.def"
59#include "stdio/stdio2.def"
[f47c70d4]60#include "stdio/logger1.def"
[9a53e00]61#include "stdio/logger2.def"
[be66dee]62#include "fault/fault1.def"
63#include "fault/fault2.def"
[d91a20c]64#include "fault/fault3.def"
[b6636dc]65#include "float/float1.def"
[d9be488]66#include "float/float2.def"
[2d11a7d8]67#include "vfs/vfs1.def"
[3191c01]68#include "ipc/starve.def"
[ce4a3dae]69#include "loop/loop1.def"
[2d11a7d8]70#include "mm/malloc1.def"
[9e953bda]71#include "mm/malloc2.def"
[013a5d7]72#include "mm/malloc3.def"
[b93d637]73#include "mm/mapping1.def"
[dd5f703]74#include "mm/pager1.def"
[ffdd2b9]75#include "hw/serial/serial1.def"
[57914494]76#include "chardev/chardev1.def"
[1433ecda]77 { NULL, NULL, NULL, false }
[dd655970]78};
79
80static bool run_test(test_t *test)
[51dbadf3]81{
[dd655970]82 /* Execute the test */
[a000878c]83 const char *ret = test->entry();
[a35b458]84
[dd655970]85 if (ret == NULL) {
[2d11a7d8]86 printf("\nTest passed\n");
[dd655970]87 return true;
[51dbadf3]88 }
[a35b458]89
[2d11a7d8]90 printf("\n%s\n", ret);
[dd655970]91 return false;
[51dbadf3]92}
93
[209cd41]94static int run_safe_tests(void)
[51dbadf3]95{
[047aa46]96 test_t *test;
[e190a89b]97 unsigned int i = 0;
98 unsigned int n = 0;
[a35b458]99
[c45dc5e1]100 char *failed_names = NULL;
101
[e190a89b]102 printf("\n*** Running all safe tests ***\n\n");
[a35b458]103
[047aa46]104 for (test = tests; test->name != NULL; test++) {
[c45dc5e1]105 if (!test->safe)
106 continue;
107
108 printf("%s (%s)\n", test->name, test->desc);
109 if (run_test(test)) {
110 i++;
111 continue;
112 }
113
114 if (!failed_names) {
115 failed_names = str_dup(test->name);
116 } else {
117 char *f = NULL;
118 asprintf(&f, "%s, %s", failed_names, test->name);
119 if (!f) {
120 printf("Out of memory.\n");
121 abort();
122 }
123 free(failed_names);
124 failed_names = f;
[047aa46]125 }
[c45dc5e1]126 n++;
[047aa46]127 }
[a35b458]128
[2d11a7d8]129 printf("\nCompleted, %u tests run, %u passed.\n", i + n, i);
[c45dc5e1]130 if (failed_names)
131 printf("Failed tests: %s\n", failed_names);
[209cd41]132
133 return n;
[51dbadf3]134}
135
[dd655970]136static void list_tests(void)
[51dbadf3]137{
[2d11a7d8]138 size_t len = 0;
[dd655970]139 test_t *test;
[2d11a7d8]140 for (test = tests; test->name != NULL; test++) {
141 if (str_length(test->name) > len)
142 len = str_length(test->name);
143 }
[a35b458]144
[855e0d8]145 unsigned int _len = (unsigned int) len;
146 if ((_len != len) || (((int) _len) < 0)) {
147 printf("Command length overflow\n");
148 return;
149 }
[a35b458]150
[2d11a7d8]151 for (test = tests; test->name != NULL; test++)
[855e0d8]152 printf("%-*s %s%s\n", _len, test->name, test->desc,
153 (test->safe ? "" : " (unsafe)"));
[a35b458]154
[855e0d8]155 printf("%-*s Run all safe tests\n", _len, "*");
[51dbadf3]156}
157
[2d11a7d8]158int main(int argc, char *argv[])
[51dbadf3]159{
[2d11a7d8]160 if (argc < 2) {
161 printf("Usage:\n\n");
162 printf("%s <test> [args ...]\n\n", argv[0]);
[dd655970]163 list_tests();
[2d11a7d8]164 return 0;
165 }
[a35b458]166
[267f235]167 log_init("tester");
[f47c70d4]168
[2d11a7d8]169 test_quiet = false;
170 test_argc = argc - 2;
171 test_argv = argv + 2;
[a35b458]172
[2d11a7d8]173 if (str_cmp(argv[1], "*") == 0) {
[209cd41]174 return run_safe_tests();
[2d11a7d8]175 }
[a35b458]176
[2d11a7d8]177 test_t *test;
178 for (test = tests; test->name != NULL; test++) {
179 if (str_cmp(argv[1], test->name) == 0) {
180 return (run_test(test) ? 0 : -1);
[51b966b]181 }
[51dbadf3]182 }
[a35b458]183
[2d11a7d8]184 printf("Unknown test \"%s\"\n", argv[1]);
185 return -2;
[51dbadf3]186}
[b2951e2]187
188/** @}
189 */
Note: See TracBrowser for help on using the repository browser.