2 * YAFFS: Yet another FFS. A NAND-flash specific file system.
4 * Copyright (C) 2002-2010 Aleph One Ltd.
5 * for Toby Churchill Ltd and Brightstar Engineering
7 * Created by Timothy Manning <timothy@yaffs.net>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License version 2 as
11 * published by the Free Software Foundation.
14 #include "quick_tests.h"
18 int simulate_power_failure = 0;
23 static int number_of_random_tests=0;
24 static unsigned int num_of_tests_pass=0;
25 static unsigned int num_of_tests_failed=0;
26 static unsigned int total_number_of_tests=(sizeof(test_list)/sizeof(test_template));
28 int main(int argc, char *argv[])
32 init_quick_tests(argc, argv);
33 logical_run_of_tests();
34 for (x=0;x<number_of_random_tests;x ++){
35 run_random_test_loop();
37 /*this is where the loop should break to*/
42 void run_random_test_loop(void)
46 int run_list[total_number_of_tests];
47 for (x=0;x<total_number_of_tests;x++){
48 id = (rand() % (total_number_of_tests-1));
53 void logical_run_of_tests(void)
56 print_message("\n\nrunning quick tests for yaffs\n\n", 0);
58 for (x=0;x<total_number_of_tests;x++){
69 yaffs_set_error(0); /*reset the last error to 0 */
70 //printf("foo exists %d\n",test_yaffs_open());
71 sprintf(message,"\nrunning test: %s \n",test_list[x].name_of_test);
72 print_message(message,3);
73 output=test_list[x].p_function(); /*run test*/
76 sprintf(message,"\ttest %s passed\n",test_list[x].name_of_test);
77 print_message(message,3);
80 /*test is assumed to have failed*/
81 //printf("test failed\n");
82 sprintf(message,"test: %s failed\n",test_list[x].name_of_test);
83 print_message(message,1);
84 num_of_tests_failed ++;
87 print_message("\n\n",1);
88 if (get_exit_on_error()){
93 output=test_list[x].p_function_clean(); /*clean the test*/
95 /* if the test failed to clean it's self then */
96 sprintf(message,"test: %s failed to clean\n",test_list[x].name_of_test);
97 print_message(message,1);
98 num_of_tests_failed ++;
102 if (get_exit_on_error()){
107 sprintf(message,"\ttest clean: %s passed\n",test_list[x].name_of_test);
108 print_message(message,3);
112 void quit_quick_tests(int exit_code)
116 if (num_of_tests_pass==total_number_of_tests && num_of_tests_failed==0){
117 printf("\t OK --all tests passed\n");
119 printf("out of %d tests, %d ran: %d passed and %d failed\n\n\n", total_number_of_tests,(num_of_tests_pass+num_of_tests_failed) ,num_of_tests_pass,num_of_tests_failed);
120 yaffs_unmount(YAFFS_MOUNT_POINT);
130 error_code=yaffs_get_error();
131 sprintf(message,"yaffs_error code %d\n",error_code);
132 print_message(message,1);
133 sprintf(message,"error is : %s\n",yaffs_error_to_str(error_code));
134 print_message(message,1);
137 void init_quick_tests(int argc, char *argv[])
141 for (x = 0; x < argc; x++){
142 if (0==strcmp(argv[x],"-h")){
144 printf("-h will print the commands available\n");
145 printf("-c will continue after a test failes else the program will exit\n");
146 printf("-v will print all messages\n");
147 printf("-q quiet mode only the number of tests passed and failed will be printed\n");
148 printf("-t [number] set yaffs_trace to number\n");
149 printf("-r [number] sets the number of random loops to run after the the test has run\n");
151 } else if (0==strcmp(argv[x],"-c")) {
152 set_exit_on_error(0);
153 } else if (0==strcmp(argv[x],"-q")) {
155 } else if (0==strcmp(argv[x],"-t")) {
156 trace = atoi(argv[x+1]);
157 } else if (0==strcmp(argv[x],"-v")) {
159 } else if (0==strcmp(argv[x],"-r")) {
160 number_of_random_tests=atoi(argv[x+1]);
165 yaffs_set_trace(trace);