Subversion Repositories HelenOS

Rev

Rev 2656 | Rev 2786 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2656 Rev 2785
1
/*
1
/*
2
 * Copyright (c) 2006 Ondrej Palkovsky
2
 * Copyright (c) 2006 Ondrej Palkovsky
3
 * Copyright (c) 2007 Martin Decky
3
 * Copyright (c) 2007 Martin Decky
4
 * All rights reserved.
4
 * All rights reserved.
5
 *
5
 *
6
 * Redistribution and use in source and binary forms, with or without
6
 * Redistribution and use in source and binary forms, with or without
7
 * modification, are permitted provided that the following conditions
7
 * modification, are permitted provided that the following conditions
8
 * are met:
8
 * are met:
9
 *
9
 *
10
 * - Redistributions of source code must retain the above copyright
10
 * - Redistributions of source code must retain the above copyright
11
 *   notice, this list of conditions and the following disclaimer.
11
 *   notice, this list of conditions and the following disclaimer.
12
 * - Redistributions in binary form must reproduce the above copyright
12
 * - Redistributions in binary form must reproduce the above copyright
13
 *   notice, this list of conditions and the following disclaimer in the
13
 *   notice, this list of conditions and the following disclaimer in the
14
 *   documentation and/or other materials provided with the distribution.
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
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.
16
 *   derived from this software without specific prior written permission.
17
 *
17
 *
18
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
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
19
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21
 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21
 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
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
24
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
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
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.
27
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
 */
28
 */
29
 
29
 
30
/** @addtogroup tester User space Tester
30
/** @addtogroup tester User space Tester
31
 * @brief   User space testing infrastructure.
31
 * @brief   User space testing infrastructure.
32
 * @{
32
 * @{
33
 */
33
 */
34
/**
34
/**
35
 * @file
35
 * @file
36
 */
36
 */
37
 
37
 
38
#include <unistd.h>
38
#include <unistd.h>
39
#include <stdio.h>
39
#include <stdio.h>
40
#include "tester.h"
40
#include "tester.h"
41
 
41
 
42
int myservice = 0;
42
int myservice = 0;
43
int phones[MAX_PHONES];
43
int phones[MAX_PHONES];
44
int connections[MAX_CONNECTIONS];
44
int connections[MAX_CONNECTIONS];
45
ipc_callid_t callids[MAX_CONNECTIONS];
45
ipc_callid_t callids[MAX_CONNECTIONS];
46
 
46
 
47
test_t tests[] = {
47
test_t tests[] = {
48
#include "thread/thread1.def"
48
#include "thread/thread1.def"
49
#include "print/print1.def"
49
#include "print/print1.def"
50
#include "fault/fault1.def"
50
#include "fault/fault1.def"
51
#include "fault/fault2.def"
51
#include "fault/fault2.def"
52
#include "ipc/register.def"
52
#include "ipc/register.def"
53
#include "ipc/connect.def"
53
#include "ipc/connect.def"
54
#include "ipc/send_async.def"
54
#include "ipc/send_async.def"
55
#include "ipc/send_sync.def"
55
#include "ipc/send_sync.def"
56
#include "ipc/answer.def"
56
#include "ipc/answer.def"
57
#include "ipc/hangup.def"
57
#include "ipc/hangup.def"
58
#include "devmap/devmap1.def"
58
#include "devmap/devmap1.def"
59
#include "vfs/vfs1.def"
59
#include "vfs/vfs1.def"
60
    {NULL, NULL, NULL}
60
    {NULL, NULL, NULL}
61
};
61
};
62
 
62
 
63
static bool run_test(test_t *test)
63
static bool run_test(test_t *test)
64
{
64
{
65
    printf("%s\t\t%s\n", test->name, test->desc);
65
    printf("%s\t\t%s\n", test->name, test->desc);
66
   
66
   
67
    /* Execute the test */
67
    /* Execute the test */
68
    char * ret = test->entry(false);
68
    char * ret = test->entry(false);
69
   
69
   
70
    if (ret == NULL) {
70
    if (ret == NULL) {
71
        printf("Test passed\n\n");
71
        printf("Test passed\n\n");
72
        return true;
72
        return true;
73
    }
73
    }
74
 
74
 
75
    printf("%s\n\n", ret);
75
    printf("%s\n\n", ret);
76
    return false;
76
    return false;
77
}
77
}
78
 
78
 
79
static void run_safe_tests(void)
79
static void run_safe_tests(void)
80
{
80
{
-
 
81
    test_t *test;
-
 
82
    int i = 0, n = 0;
-
 
83
 
-
 
84
    printf("\n*** Running all safe tests\n\n");
-
 
85
 
-
 
86
    for (test = tests; test->name != NULL; test++) {
-
 
87
        if (test->safe) {
-
 
88
            if (run_test(test))
-
 
89
                i++;
-
 
90
            else
-
 
91
                n++;
-
 
92
        }
-
 
93
    }
-
 
94
 
-
 
95
    printf("\nSafe tests completed, %d tests run, %d passed.\n\n", i + n, i);
81
}
96
}
82
 
97
 
83
static void list_tests(void)
98
static void list_tests(void)
84
{
99
{
85
    test_t *test;
100
    test_t *test;
86
    char c = 'a';
101
    char c = 'a';
87
   
102
   
88
    for (test = tests; test->name != NULL; test++, c++)
103
    for (test = tests; test->name != NULL; test++, c++)
89
        printf("%c\t%s\t\t%s%s\n", c, test->name, test->desc, (test->safe ? "" : " (unsafe)"));
104
        printf("%c\t%s\t\t%s%s\n", c, test->name, test->desc, (test->safe ? "" : " (unsafe)"));
90
   
105
   
91
    printf("*\t\t\tRun all safe tests\n");
106
    printf("*\t\t\tRun all safe tests\n");
92
}
107
}
93
 
108
 
94
int main(void)
109
int main(void)
95
{
110
{
96
    while (1) {
111
    while (1) {
97
        char c;
112
        char c;
98
        test_t *test;
113
        test_t *test;
99
       
114
       
100
        list_tests();
115
        list_tests();
101
        printf("> ");
116
        printf("> ");
102
       
117
       
103
        c = getchar();
118
        c = getchar();
104
        printf("%c\n", c);
119
        printf("%c\n", c);
105
       
120
       
106
        if ((c >= 'a') && (c <= 'z')) {
121
        if ((c >= 'a') && (c <= 'z')) {
107
            for (test = tests; test->name != NULL; test++, c--)
122
            for (test = tests; test->name != NULL; test++, c--)
108
                if (c == 'a')
123
                if (c == 'a')
109
                    break;
124
                    break;
110
           
125
           
111
            if (c > 'a')
126
            if (c > 'a')
112
                printf("Unknown test\n\n");
127
                printf("Unknown test\n\n");
113
            else
128
            else
114
                run_test(test);
129
                run_test(test);
115
        } else if (c == '*')
130
        } else if (c == '*')
116
            run_safe_tests();
131
            run_safe_tests();
117
        else
132
        else
118
            printf("Invalid test\n\n");
133
            printf("Invalid test\n\n");
119
    }
134
    }
120
}
135
}
121
 
136
 
122
/** @}
137
/** @}
123
 */
138
 */
124
 
139