yaffs Are trapping a suspeced bug in quick_tests.
[yaffs2.git] / direct / timothy_tests / quick_tests / quick_tests.c
1 #include "quick_tests.h"
2
3 #include "yaffsfs.h"
4 int random_seed;
5 int simulate_power_failure = 0;
6
7
8
9 typedef struct test {
10         int (*p_function)(void);        /*pointer to test function*/
11         int (*p_function_clean)(void);
12         /*char pass_message[50]; will not need a pass message*/
13         char *fail_message;     /*pointer to fail message, needs to include name of test*/
14 }test_template;
15
16
17 int dummy_test_pass(void){
18         //printf("running dummy_test_pass\n");
19         return 1;
20 }
21 void dummy_test_pass_clean(void){
22         
23 }
24 int dummy_test_fail(void){
25         //printf("running dummy_test_fail\n");
26         return -1;
27 }
28 void dummy_test_fail_clean(void){
29 }
30 test_template test_list[]={
31         //{dummy_test_pass,dummy_test_pass_clean,"dummy_test_pass"},
32         //{dummy_test_fail,dummy_test_fail_clean,"dummy_test_fail"},
33         {mount_yaffs_test,mount_yaffs_test_clean,"mount_yaffs_test"},
34         {test_open_file,test_open_file_clean,"test_open_file"},
35         
36         {test_yaffs_access,test_yaffs_access_clean,"test_yaffs_access"},
37         {test_yaffs_unlinking, test_yaffs_unlinking_clean,"test_yaffs_unlinking"},
38
39         {test_yaffs_lseek,test_yaffs_lseek_clean,"test_yaffs_lseek"},
40         {test_yaffs_read,test_yaffs_read_clean,"test_yaffs_read"},
41         {test_yaffs_write,test_yaffs_write_clean,"test_yaffs_write"},
42
43         {test_yaffs_stat,test_yaffs_stat_clean,"test_yaffs_stat"},
44         {test_yaffs_ftruncate,test_yaffs_ftruncate_clean,"test_yaffs_ftruncate"},
45         {test_yaffs_truncate,test_yaffs_truncate_clean,"test_yaffs_truncate"}
46
47         };
48
49 unsigned int num_of_tests_pass=0;
50 unsigned int num_of_tests_failed=0;
51 unsigned int total_number_of_tests=(sizeof(test_list)/sizeof(test_template));
52
53 int main(){
54         int output=0;
55
56
57         unsigned int x=0;       
58         init_quick_tests();
59         printf("\n\nrunning quick tests for yaffs\n");
60         //printf("testing yaffs\n");
61
62         //printf("len function %d",(sizeof(test_list)/sizeof(test_template)));
63         for (x=0;x<total_number_of_tests;x++){
64                 //printf("x %d\n",x);
65                 output=test_list[x].p_function();       /*run test*/
66                 if (output>=0){
67                         /*test has passed*/
68                         num_of_tests_pass++;
69                 }
70                 else {
71                         /*test is assumed to have failed*/
72                         //printf("test failed\n");
73                         printf("test: %s failed\n",test_list[x].fail_message);          
74                         num_of_tests_failed ++; 
75                         quit_quick_tests(1);
76                         
77                 }
78                 output=test_list[x].p_function_clean(); /*clean the test*/
79                 if (output <0){
80                         /* if the test failed to clean it's self then */
81                         printf("test: %s failed to clean\n",test_list[x].fail_message);         
82                         num_of_tests_failed ++; 
83                         num_of_tests_pass--;
84                         quit_quick_tests(1);
85                 }
86                         
87         }
88         /*this is where the loop should break to*/
89         quit_quick_tests(0);
90         /* the progame should never get here*/  
91         return 0;
92 }
93
94 void quit_quick_tests(int exit_code){
95         if (num_of_tests_pass==total_number_of_tests &&  num_of_tests_failed==0){
96                 printf("\t OK \n");
97         }
98         printf("tests: %d passed %d failed\n\n\n",num_of_tests_pass,num_of_tests_failed);
99         exit(exit_code);
100 }
101
102 void init_quick_tests(void){
103         yaffs_start_up();;
104         yaffs_set_trace(0);
105
106 }