yaffs Improvements on the quick tests code. note the bug is still here.
[yaffs2.git] / direct / timothy_tests / quick_tests / quick_tests.c
1 #include "quick_tests.h"
2
3
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_yaffs_open_file,test_yaffs_open_file_clean,"test_yaffs_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_write,test_yaffs_write_clean,"test_yaffs_write"},
41         {test_yaffs_read,test_yaffs_read_clean,"test_yaffs_read"},
42
43
44         {test_yaffs_stat,test_yaffs_stat_clean,"test_yaffs_stat"},
45         {test_yaffs_ftruncate,test_yaffs_ftruncate_clean,"test_yaffs_ftruncate"},
46         {test_yaffs_truncate,test_yaffs_truncate_clean,"test_yaffs_truncate"}
47
48         };
49
50 unsigned int num_of_tests_pass=0;
51 unsigned int num_of_tests_failed=0;
52 unsigned int total_number_of_tests=(sizeof(test_list)/sizeof(test_template));
53
54 int main(){
55         int output=0;
56
57
58         unsigned int x=0;       
59         init_quick_tests();
60         printf("\n\nrunning quick tests for yaffs\n");
61         //printf("testing yaffs\n");
62
63         //printf("len function %d",(sizeof(test_list)/sizeof(test_template)));
64         for (x=0;x<total_number_of_tests;x++){
65                 //printf("x %d\n",x);
66                 output=test_list[x].p_function();       /*run test*/
67                 if (output>=0){
68                         /*test has passed*/
69                         num_of_tests_pass++;
70                 }
71                 else {
72                         /*test is assumed to have failed*/
73                         //printf("test failed\n");
74                         printf("test: %s failed\n",test_list[x].fail_message);          
75                         num_of_tests_failed ++; 
76                         quit_quick_tests(1);
77                         
78                 }
79                 output=test_list[x].p_function_clean(); /*clean the test*/
80                 if (output <0){
81                         /* if the test failed to clean it's self then */
82                         printf("test: %s failed to clean\n",test_list[x].fail_message);         
83                         num_of_tests_failed ++; 
84                         num_of_tests_pass--;
85                         quit_quick_tests(1);
86                 }
87                         
88         }
89         /*this is where the loop should break to*/
90         quit_quick_tests(0);
91         /* the progame should never get here*/  
92         return 0;
93 }
94
95 void quit_quick_tests(int exit_code){
96         int error_code=0;
97         if (num_of_tests_pass==total_number_of_tests &&  num_of_tests_failed==0){
98                 printf("\t OK \n");
99         }
100         else {
101                 error_code=yaffs_get_error();
102                 printf("yaffs_error code %d\n",error_code);
103                 printf("error is : %s\n",yaffs_error_to_str(error_code));
104         }
105         printf("tests: %d passed %d failed\n\n\n",num_of_tests_pass,num_of_tests_failed);
106         yaffs_unmount(YAFFS_MOUNT_POINT);
107         exit(exit_code);
108 }
109
110 void init_quick_tests(void){
111         yaffs_start_up();;
112         yaffs_set_trace(0);
113
114 }