have added the new rename tests to quick_tests
authorTimothy Manning <tfhmanning@gmail.com>
Thu, 17 Jan 2013 23:45:40 +0000 (12:45 +1300)
committerTimothy Manning <tfhmanning@gmail.com>
Thu, 17 Jan 2013 23:45:40 +0000 (12:45 +1300)
Signed-off-by: Timothy Manning <tfhmanning@gmail.com>
direct/test-framework/timothy_tests/quick_tests/test_yaffs_rename_dir_to_file.c
direct/test-framework/timothy_tests/quick_tests/test_yaffs_rename_file_to_dir.c

index 02a068dacb084e12f66819d372db2f54c43f98f4..5fabdd227cc5c3582ce11bc35cb343cf6a0aabb7 100644 (file)
@@ -17,7 +17,7 @@
 int test_yaffs_rename_dir_to_file(void)
 {
        int output=0;
 int test_yaffs_rename_dir_to_file(void)
 {
        int output=0;
-
+       int error_code=0;
        if (0 !=  yaffs_access(DIR_PATH,0)) {
                output= yaffs_mkdir(DIR_PATH,(S_IREAD | S_IWRITE));
                if (output<0) {
        if (0 !=  yaffs_access(DIR_PATH,0)) {
                output= yaffs_mkdir(DIR_PATH,(S_IREAD | S_IWRITE));
                if (output<0) {
@@ -25,20 +25,23 @@ int test_yaffs_rename_dir_to_file(void)
                        return -1;
                }
        }
                        return -1;
                }
        }
-       if (0 !=  yaffs_access(RENAME_PATH,0)) {
-               output= yaffs_mkdir(RENAME_PATH,(S_IREAD | S_IWRITE));
-               if (output<0) {
-                       print_message("failed to remove file\n",2);
+       if (yaffs_close(yaffs_open(FILE_PATH,O_CREAT | O_RDWR, FILE_MODE))==-1){
+               print_message("failed to create file\n",1);
+               return -1;
+       }
+       output = yaffs_rename( DIR_PATH , FILE_PATH);
+       if (output==-1){
+               error_code=yaffs_get_error();
+               if (abs(error_code)==ENOTDIR){
+                       return 1;
+               } else {
+                       print_message("different error than expected\n",2);
                        return -1;
                }
                        return -1;
                }
-       }
-       output = yaffs_rename( DIR_PATH , RENAME_PATH);
-       if (output<0){ 
-               print_message("failed to rename a file over an empty directory\n",2);
+       } else {
+               print_message("renamed a directory over file.(which is a bad thing)\n",2);
                return -1;
                return -1;
-       } else{
-               return 1;
-       }       
+       }
 
 }
 
 
 }
 
index 89f7b689fc9a50e8c5e6612fc872f2571744ce27..fec2bf0693c88b20cae8ccd18f40404270ad2363 100644 (file)
 
 int test_yaffs_rename_file_to_dir(void)
 {
 
 int test_yaffs_rename_file_to_dir(void)
 {
+
        int output=0;
        int output=0;
+       int error_code=0;
        if (yaffs_close(yaffs_open(FILE_PATH,O_CREAT | O_RDWR, FILE_MODE))==-1){
                print_message("failed to create file\n",1);
                return -1;
        }
        if (yaffs_close(yaffs_open(FILE_PATH,O_CREAT | O_RDWR, FILE_MODE))==-1){
                print_message("failed to create file\n",1);
                return -1;
        }
-       if (0 !=  yaffs_access(FILE_PATH,0)) {
-               output = test_yaffs_open();
-               if (output < 0) {
-                       print_message("failed to create file\n",2);
-                       return -1;
-               } else {
-                       output = yaffs_close(output);
-                       if (output < 0) {
-                               print_message("failed to close file\n",2);
-                               return -1;
-                       }
-               }
-       }
+
        if (0 !=  yaffs_access(RENAME_DIR_PATH,0)) {
                output = yaffs_mkdir(RENAME_DIR_PATH,S_IWRITE | S_IREAD);
                if (output < 0) {
        if (0 !=  yaffs_access(RENAME_DIR_PATH,0)) {
                output = yaffs_mkdir(RENAME_DIR_PATH,S_IWRITE | S_IREAD);
                if (output < 0) {
@@ -41,6 +31,19 @@ int test_yaffs_rename_file_to_dir(void)
                        return -1;
                }
        }
                        return -1;
                }
        }
+       output=yaffs_rename(FILE_PATH,RENAME_DIR_PATH);
+       if (output==-1){
+               error_code=yaffs_get_error();
+               if (abs(error_code)==EISDIR){
+                       return 1;
+               } else {
+                       print_message("different error than expected\n",2);
+                       return -1;
+               }
+       } else {
+               print_message("renamed a file over a directory (which is a bad thing)\n",2);
+               return -1;
+       }
        return 1;
 
 }
        return 1;
 
 }