X-Git-Url: http://www.aleph1.co.uk/gitweb/?p=yaffs2.git;a=blobdiff_plain;f=direct%2Ftest-framework%2Ftimothy_tests%2Fquick_tests%2Ftest_yaffs_rename_file_to_dir.c;h=fec2bf0693c88b20cae8ccd18f40404270ad2363;hp=89f7b689fc9a50e8c5e6612fc872f2571744ce27;hb=b470a08d9e257a3c5292637c23aa49103447d6af;hpb=dfb1bb995ecc12562408adf870ccf2006a244f44;ds=sidebyside diff --git a/direct/test-framework/timothy_tests/quick_tests/test_yaffs_rename_file_to_dir.c b/direct/test-framework/timothy_tests/quick_tests/test_yaffs_rename_file_to_dir.c index 89f7b68..fec2bf0 100644 --- a/direct/test-framework/timothy_tests/quick_tests/test_yaffs_rename_file_to_dir.c +++ b/direct/test-framework/timothy_tests/quick_tests/test_yaffs_rename_file_to_dir.c @@ -16,24 +16,14 @@ int test_yaffs_rename_file_to_dir(void) { + 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 (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) { @@ -41,6 +31,19 @@ int test_yaffs_rename_file_to_dir(void) 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; }