yaffs Updated quick tests' README.
[yaffs2.git] / direct / timothy_tests / quick_tests / quick_tests.c
index 125624d022a721979ceb2006550598914a731641..1f6a935cfc90af888d7bcd607760d9d833aae8d7 100644 (file)
+/*
+ * YAFFS: Yet another FFS. A NAND-flash specific file system.
+ *
+ * Copyright (C) 2002-2010 Aleph One Ltd.
+ *   for Toby Churchill Ltd and Brightstar Engineering
+ *
+ * Created by Timothy Manning <timothy@yaffs.net>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
 #include "quick_tests.h"
 
 #include "quick_tests.h"
 
-#include "yaffsfs.h"
+
 int random_seed;
 int simulate_power_failure = 0;
 
 
 
 int random_seed;
 int simulate_power_failure = 0;
 
 
 
-typedef struct test {
-       int (*p_function)(void);        /*pointer to test function*/
-       void (*p_function_clean)(void);
-       /*char pass_message[50]; will not need a pass message*/
-       char *fail_message;     /*pointer to fail message, needs to include name of test*/
-}test_template;
 
 
 
 
-int dummy_test_pass(void){
-       //printf("running dummy_test_pass\n");
-       return 1;
-}
-void dummy_test_pass_clean(void){
-       
-}
-int dummy_test_fail(void){
-       //printf("running dummy_test_fail\n");
-       return 0;
-}
-void dummy_test_fail_clean(void){
-}
-test_template test_list[]={
-       {dummy_test_pass,dummy_test_pass_clean,"dummy_test_pass"},
-       {dummy_test_fail,dummy_test_fail_clean,"dummy_test_fail"},
-       {mount_yaffs_test,mount_yaffs_test_clean,"mount_yaffs_test"}
-       };
-
+static unsigned int num_of_tests_pass=0;
+static unsigned int num_of_tests_failed=0;
+static unsigned int total_number_of_tests=(sizeof(test_list)/sizeof(test_template));
 
 int main(){
        int output=0;
 
 int main(){
        int output=0;
-       unsigned int num_of_tests_pass=0;
-       int num_of_tests_failed=0;
-       unsigned int total_number_of_tests=(sizeof(test_list)/sizeof(test_template));
+
+
        unsigned int x=0;       
        init_quick_tests();
        unsigned int x=0;       
        init_quick_tests();
-       printf("quick tests for yaffs\n");
+       printf("\n\nrunning quick tests for yaffs\n\n");
        //printf("testing yaffs\n");
 
        //printf("len function %d",(sizeof(test_list)/sizeof(test_template)));
        for (x=0;x<total_number_of_tests;x++){
                //printf("x %d\n",x);
        //printf("testing yaffs\n");
 
        //printf("len function %d",(sizeof(test_list)/sizeof(test_template)));
        for (x=0;x<total_number_of_tests;x++){
                //printf("x %d\n",x);
+               yaffs_set_error(0);     /*reset the last error to 0 */
                output=test_list[x].p_function();       /*run test*/
                output=test_list[x].p_function();       /*run test*/
-               if (output>0){
+               if (output>=0){
                        /*test has passed*/
                        num_of_tests_pass++;
                }
                else {
                        /*test is assumed to have failed*/
                        //printf("test failed\n");
                        /*test has passed*/
                        num_of_tests_pass++;
                }
                else {
                        /*test is assumed to have failed*/
                        //printf("test failed\n");
-                       printf("test: %s failed\n",test_list[x].fail_message);          
+                       printf("test: %s failed\n",test_list[x].name_of_test);          
                        num_of_tests_failed ++; 
                        num_of_tests_failed ++; 
+
+                       if (EXIT_ON_ERROR){
+                               get_error();
+                               printf("\n\n");
+                               quit_quick_tests(1);
+                       }
+                       else {
+                               get_error();
+                               printf("\n\n");
+                       }
+               }
+               output=test_list[x].p_function_clean(); /*clean the test*/
+               if (output <0){
+                       /* if the test failed to clean it's self then */
+                       printf("test: %s failed to clean\n",test_list[x].name_of_test);         
+                       num_of_tests_failed ++; 
+                       num_of_tests_pass--;
+                       get_error();
+                       printf("\n\n");
+                       if (EXIT_ON_ERROR){
+                               quit_quick_tests(1);
+                       }
+                       
                }
                }
-               test_list[x].p_function_clean();        /*run test*/
                        
        }
                        
        }
-       if (num_of_tests_pass==total_number_of_tests){
+       /*this is where the loop should break to*/
+       quit_quick_tests(0);
+       /* the progame should never get here*/  
+       return 0;
+}
+
+void quit_quick_tests(int exit_code){
+       
+       if (num_of_tests_pass==total_number_of_tests &&  num_of_tests_failed==0){
                printf("\t OK \n");
        }
                printf("\t OK \n");
        }
-       printf("tests: %d passed %d failed\n",num_of_tests_pass,num_of_tests_failed);
-       return 0;
+       printf("tests: %d passed %d failed\n\n\n",num_of_tests_pass,num_of_tests_failed);
+       yaffs_unmount(YAFFS_MOUNT_POINT);
+       exit(exit_code);
+}
+
+void get_error(void){
+       int error_code=0;
+       error_code=yaffs_get_error();
+       printf("yaffs_error code %d\n",error_code);
+       printf("error is : %s\n",yaffs_error_to_str(error_code));
 }
 
 void init_quick_tests(void){
        yaffs_start_up();;
 }
 
 void init_quick_tests(void){
        yaffs_start_up();;
-       //yaffs_set_trace(0);
+       yaffs_set_trace(0);
 
 }
 
 }