yaffs Fixed some bugs in quick tests and added some more tests.
authorTimothy Manning <tfhmanning@gmail.com>
Thu, 18 Nov 2010 01:00:57 +0000 (14:00 +1300)
committerTimothy Manning <tfhmanning@gmail.com>
Thu, 18 Nov 2010 01:00:57 +0000 (14:00 +1300)
Signed-off-by: Timothy Manning <tfhmanning@gmail.com>
30 files changed:
direct/timothy_tests/quick_tests/Makefile
direct/timothy_tests/quick_tests/README.txt
direct/timothy_tests/quick_tests/quick_tests.c
direct/timothy_tests/quick_tests/quick_tests.h
direct/timothy_tests/quick_tests/test_yaffs_freespace.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_freespace.h [moved from direct/timothy_tests/quick_tests/test_yaffs_sync_ENOENT.h with 79% similarity]
direct/timothy_tests/quick_tests/test_yaffs_mount2_ENODEV.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_mount2_ENODEV.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_EINVAL.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_EINVAL.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_ENODEV.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_ENODEV.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_off.c [moved from direct/timothy_tests/quick_tests/test_yaffs_sync_ENOENT.c with 55% similarity]
direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_off.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_on.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_on.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_off.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_off.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_on.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_on.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_sync_ENODEV.c [moved from direct/timothy_tests/quick_tests/test_yaffs_sync_ENOTDIR.c with 84% similarity]
direct/timothy_tests/quick_tests/test_yaffs_sync_ENODEV.h [moved from direct/timothy_tests/quick_tests/test_yaffs_sync_ENOTDIR.h with 78% similarity]
direct/timothy_tests/quick_tests/test_yaffs_unmount2_EINVAL.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_unmount2_EINVAL.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_unmount2_ENODEV.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_unmount2_ENODEV.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_off.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_off.h [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_on.c [new file with mode: 0644]
direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_on.h [new file with mode: 0644]

index 0604e1d79162ee03ff4e32a41032b8b8b181a8e3..747d5059e9e476e6a8c6d39783137ad19ee678d5 100644 (file)
@@ -67,9 +67,13 @@ TESTFILES =  quick_tests.o lib.o \
                test_yaffs_mkdir.o test_yaffs_mkdir_EEXIST.o test_yaffs_mkdir_ENOTDIR.o \
                test_yaffs_fchmod.o test_yaffs_fchmod_EBADF.o test_yaffs_fchmod_EINVAL.o \
                test_yaffs_symlink.o test_yaffs_symlink_ENOTDIR.o test_yaffs_symlink_EEXIST.o test_yaffs_symlink_ENOENT.o \
                test_yaffs_mkdir.o test_yaffs_mkdir_EEXIST.o test_yaffs_mkdir_ENOTDIR.o \
                test_yaffs_fchmod.o test_yaffs_fchmod_EBADF.o test_yaffs_fchmod_EINVAL.o \
                test_yaffs_symlink.o test_yaffs_symlink_ENOTDIR.o test_yaffs_symlink_EEXIST.o test_yaffs_symlink_ENOENT.o \
-               test_yaffs_mount2.o \
-               test_yaffs_unmount2.o \
-               test_yaffs_sync.o test_yaffs_sync_ENOTDIR.o test_yaffs_sync_ENOENT.o
+               test_yaffs_mount2.o test_yaffs_mount2_ENODEV.o \
+               test_yaffs_unmount2.o test_yaffs_unmount2_ENODEV.o test_yaffs_unmount2_EINVAL.o \
+               test_yaffs_unmount2_with_handle_open_and_forced_mode_on.o test_yaffs_unmount2_with_handle_open_and_forced_mode_off.o\
+               test_yaffs_sync.o test_yaffs_sync_ENODEV.o  \
+               test_yaffs_remount_force_off_read_only_off.o test_yaffs_remount_force_on_read_only_off.o test_yaffs_remount_ENODEV.o \
+               test_yaffs_remount_EINVAL.o \
+               test_yaffs_freespace.o
 
 
                  
 
 
                  
index 398512a78a70e6312d7dcbc31a89c670b615c4e4..3d9d5a185974b420caae2ce5a270502047148102 100644 (file)
@@ -17,6 +17,7 @@ Tests made
        test_yaffs_mount_EBUSY          //caused by trying to mount a new mount point with a mount point already mounted.
 
        test_yaffs_mount2
        test_yaffs_mount_EBUSY          //caused by trying to mount a new mount point with a mount point already mounted.
 
        test_yaffs_mount2
+       test_yaffs_mount2_ENODEV        //when a bad mount point is used.
 
        test_yaffs_access
        test_yaffs_access_ENIVAL
 
        test_yaffs_access
        test_yaffs_access_ENIVAL
@@ -58,6 +59,7 @@ Tests made
        test_yaffs_mkdir_EEXISTS
        test_yaffs_mkdir_ENOTDIR
 
        test_yaffs_mkdir_EEXISTS
        test_yaffs_mkdir_ENOTDIR
 
+
        test_yaffs_stat
        test_yaffs_stat_ENOENT
        test_yaffs_stat_ENOTDIR
        test_yaffs_stat
        test_yaffs_stat_ENOENT
        test_yaffs_stat_ENOTDIR
@@ -73,6 +75,11 @@ Tests made
        test_yaffs_fstat
        test_yaffs_fstat_EBADF
 
        test_yaffs_fstat
        test_yaffs_fstat_EBADF
 
+       test_yaffs_remount_force_off_read_only_off
+       test_yaffs_remount_force_on_read_only_off
+       test_yaffs_remount_ENODEV
+       test_yaffs_remount_EINVAL
+
        test_yaffs_truncate
        test_yaffs_truncate_ENOTDIR
        test_yaffs_truncate_EISDIR
        test_yaffs_truncate
        test_yaffs_truncate_ENOTDIR
        test_yaffs_truncate_EISDIR
@@ -89,9 +96,13 @@ Tests made
        test_yaffs_unmount
        test_yaffs_unmount_ENODEV
        test_yaffs_unmount_ENAMETOOLONG
        test_yaffs_unmount
        test_yaffs_unmount_ENODEV
        test_yaffs_unmount_ENAMETOOLONG
-       test_yaffs_umount_EBUSY //cause by having a file handle open and then trying to unmount yaffs.
+       test_yaffs_umount_EBUSY //caused by having a file handle open and then trying to unmount yaffs.
 
        test_yaffs_unmount2
 
        test_yaffs_unmount2
+       test_yaffs_unmount2_ENODEV
+       test_yaffs_unmount2_with handle open and forced mode on
+       test_yaffs_unmount2_with handle open and forced mode off. should give EBUSY.
+       test_yaffs_unmount2_EINVAL      //should be caused when the file system is alredy unmounted.
 
        test_yaffs_write
        test_yaffs_write_EBADF
 
        test_yaffs_write
        test_yaffs_write_EBADF
@@ -143,33 +154,30 @@ Tests to add
        test_yaffs_mknod_EROFS
 
 
        test_yaffs_mknod_EROFS
 
 
-       test_yaffs_mount2_EINVAL
-       test_yaffs_mount2_ENOTDIR
-       test_yaffs_mount2_ENOENT
-       test_yaffs_mount2_ENODEV
+       test_yaffs_mount2_EINVAL        //cannot happen in yaffs since the mode is not checked.
+       test_yaffs_mount2_ENOTDIR       //cannot be generated in yaffs.
+       test_yaffs_mount2_ENOENT        //cannot be generated in yaffs.
        test_yaffs_mount2_ENAMETOOLONG
        test_yaffs_mount2_ENAMETOOLONG
+       test_yaffs_mount2_with read only set
 
 
 
 
-       test_yaffs_unmount2_with handle open and forced mode on
-       test_yaffs_unmount2_with handle open and forced mode off. should give EBUSY.
-       test_yaffs_unmount2
-       test_yaffs_unmount2_ENOENT
-       test_yaffs_unmount2_ENOTDIR
-       test_yaffs_unmount2_ENODEV
-       test_yaffs_unmount2_EINVAL
 
 
-       test_yaffs_remount2
-       test_yaffs_remount2_ENOENT
-       test_yaffs_remount2_ENOTDIR
-       test_yaffs_remount2_ENODEV
-       test_yaffs_remount2_EINVAL
+       test_yaffs_unmount2_ENOENT      //cannot be generated in yaffs.
+       test_yaffs_unmount2_ENOTDIR     //cannot be generated in yaffs.
+       test_yaffs_unmount2_ENAMETOOLONG
+       
+
+       test_yaffs_remount_force_off_read_only_on
+       test_yaffs_remount_force_on_read_only_on
+       test_yaffs_remount_ENOENT       //cannot be generated in yaffs
+       test_yaffs_remount_ENOTDIR      //cannot be generated in yaffs
 
 
        test_yaffs_sync_ENOENT
 
        test_yaffs_freespace
 
 
        test_yaffs_sync_ENOENT
 
        test_yaffs_freespace
-       test_yaffs_freespace_ENOENT
-       test_yaffs_freespace_ENOTDIR
+       test_yaffs_freespace_EINVAL
+       test_yaffs_freespace_ENAMETOOLONG
 
        test_yaffs_totalspace
        test_yaffs_totalspace_ENOTDIR
 
        test_yaffs_totalspace
        test_yaffs_totalspace_ENOTDIR
index a943f4d3bce1938c0e7406779721326351f76b67..79a7aae649b682f233e7e95502fe2c3f2df6d45b 100644 (file)
@@ -89,7 +89,7 @@ void quit_quick_tests(int exit_code)
        char message[30];
        message[0]='\0';        
        if (num_of_tests_pass==total_number_of_tests &&  num_of_tests_failed==0){
        char message[30];
        message[0]='\0';        
        if (num_of_tests_pass==total_number_of_tests &&  num_of_tests_failed==0){
-               printf("\t OK \n");
+               printf("\t OK --all tests passed\n");
        }
        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);
        yaffs_unmount(YAFFS_MOUNT_POINT);
        }
        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);
        yaffs_unmount(YAFFS_MOUNT_POINT);
index 5d41e806c20b31b48f674aacf072b38ace771905..535bd3afc142e135e8b9f45e9e5351ccd69decd3 100644 (file)
 #include "test_yaffs_symlink_ENOENT.h"
 
 #include "test_yaffs_mount2.h"
 #include "test_yaffs_symlink_ENOENT.h"
 
 #include "test_yaffs_mount2.h"
+#include "test_yaffs_mount2_ENODEV.h"
 
 #include "test_yaffs_unmount2.h"
 
 #include "test_yaffs_unmount2.h"
+#include "test_yaffs_unmount2_ENODEV.h"
+#include "test_yaffs_unmount2_EINVAL.h"
+#include "test_yaffs_unmount2_with_handle_open_and_forced_mode_on.h"
+#include "test_yaffs_unmount2_with_handle_open_and_forced_mode_off.h"
 
 #include "test_yaffs_sync.h"
 
 #include "test_yaffs_sync.h"
-#include "test_yaffs_sync_ENOTDIR.h"
-#include "test_yaffs_sync_ENOENT.h"
+#include "test_yaffs_sync_ENODEV.h"
 
 
+#include "test_yaffs_remount_force_off_read_only_off.h"
+#include "test_yaffs_remount_force_on_read_only_off.h"
+#include "test_yaffs_remount_ENODEV.h"
+#include "test_yaffs_remount_EINVAL.h"
+
+#include "test_yaffs_freespace.h"
 
 #include "yaffsfs.h"
 #include "yaffs_error_converter.h"
 
 #include "yaffsfs.h"
 #include "yaffs_error_converter.h"
@@ -171,7 +181,7 @@ test_template test_list[]={
        {test_yaffs_lseek,test_yaffs_lseek_clean,"test_yaffs_lseek"},
        {test_yaffs_lseek_EBADF,test_yaffs_lseek_EBADF_clean,"test_yaffs_lseek_EBADF"},
        {test_yaffs_lseek_EINVAL,test_yaffs_lseek_EINVAL_clean,"test_yaffs_lseek_EINVAL"},
        {test_yaffs_lseek,test_yaffs_lseek_clean,"test_yaffs_lseek"},
        {test_yaffs_lseek_EBADF,test_yaffs_lseek_EBADF_clean,"test_yaffs_lseek_EBADF"},
        {test_yaffs_lseek_EINVAL,test_yaffs_lseek_EINVAL_clean,"test_yaffs_lseek_EINVAL"},
-       {test_yaffs_lseek_big_file,test_yaffs_lseek_big_file_clean,"test_yaffs_lseek_big_file"},
+//     {test_yaffs_lseek_big_file,test_yaffs_lseek_big_file_clean,"test_yaffs_lseek_big_file"}, //this test does not work because the large number becomes 0 when the file is compiled.
 
        {test_yaffs_write,test_yaffs_write_clean,"test_yaffs_write"},
        {test_yaffs_write_EBADF,test_yaffs_write_EBADF_clean,"test_yaffs_write_EBADF"},
 
        {test_yaffs_write,test_yaffs_write_clean,"test_yaffs_write"},
        {test_yaffs_write_EBADF,test_yaffs_write_EBADF_clean,"test_yaffs_write_EBADF"},
@@ -198,7 +208,7 @@ test_template test_list[]={
        {test_yaffs_truncate_EISDIR,test_yaffs_truncate_EISDIR_clean,"test_yaffs_truncate_EISDIR"},
        {test_yaffs_truncate_EINVAL,test_yaffs_truncate_EINVAL_clean,"test_yaffs_truncate_EINVAL"},
        {test_yaffs_truncate_ENOENT,test_yaffs_truncate_ENOENT_clean,"test_yaffs_truncate_ENOENT"},
        {test_yaffs_truncate_EISDIR,test_yaffs_truncate_EISDIR_clean,"test_yaffs_truncate_EISDIR"},
        {test_yaffs_truncate_EINVAL,test_yaffs_truncate_EINVAL_clean,"test_yaffs_truncate_EINVAL"},
        {test_yaffs_truncate_ENOENT,test_yaffs_truncate_ENOENT_clean,"test_yaffs_truncate_ENOENT"},
-       {test_yaffs_truncate_big_file,test_yaffs_truncate_big_file_clean,"test_yaffs_truncate_big_file"},
+//     {test_yaffs_truncate_big_file,test_yaffs_truncate_big_file_clean,"test_yaffs_truncate_big_file"}, //this test does not work because the large number becomes 0 when the file is compiled.
 
        {test_yaffs_chmod,test_yaffs_chmod_clean,"test_yaffs_chmod"},
        {test_yaffs_chmod_ENOENT,test_yaffs_chmod_ENOENT_clean,"test_yaffs_chmod_ENOENT"},
 
        {test_yaffs_chmod,test_yaffs_chmod_clean,"test_yaffs_chmod"},
        {test_yaffs_chmod_ENOENT,test_yaffs_chmod_ENOENT_clean,"test_yaffs_chmod_ENOENT"},
@@ -225,15 +235,25 @@ test_template test_list[]={
        {test_yaffs_symlink_ENOENT,test_yaffs_symlink_ENOENT_clean,"test_yaffs_symlink_ENOENT"},
 
        {test_yaffs_mount2,test_yaffs_mount2_clean,"test_yaffs_mount2"},
        {test_yaffs_symlink_ENOENT,test_yaffs_symlink_ENOENT_clean,"test_yaffs_symlink_ENOENT"},
 
        {test_yaffs_mount2,test_yaffs_mount2_clean,"test_yaffs_mount2"},
+       {test_yaffs_mount2_ENODEV,test_yaffs_mount2_ENODEV_clean,"test_yaffs_mount2_ENODEV"},
+       
 
        {test_yaffs_unmount2,test_yaffs_unmount2_clean,"test_yaffs_unmount2"},
 
        {test_yaffs_unmount2,test_yaffs_unmount2_clean,"test_yaffs_unmount2"},
+       {test_yaffs_unmount2_ENODEV,test_yaffs_unmount2_ENODEV_clean,"test_yaffs_unmount2_ENODEV"},
+       {test_yaffs_unmount2_EINVAL,test_yaffs_unmount2_EINVAL_clean,"test_yaffs_unmount2_EINVAL"},     {test_yaffs_unmount2_with_handle_open_and_forced_mode_on,test_yaffs_unmount2_with_handle_open_and_forced_mode_on_clean,"test_yaffs_unmount2_with_handle_open_and_forced_mode_on"},
+{test_yaffs_unmount2_with_handle_open_and_forced_mode_off,test_yaffs_unmount2_with_handle_open_and_forced_mode_off_clean,"test_yaffs_unmount2_with_handle_open_and_forced_mode_off"},
 
        {test_yaffs_sync,test_yaffs_sync_clean,"test_yaffs_sync"},
 
        {test_yaffs_sync,test_yaffs_sync_clean,"test_yaffs_sync"},
-       {test_yaffs_sync_ENOTDIR,test_yaffs_sync_ENOTDIR_clean,"test_yaffs_sync_ENOTDIR"},
-       {test_yaffs_sync_ENOENT,test_yaffs_sync_ENOENT_clean,"test_yaffs_sync_ENOENT"}
+       {test_yaffs_sync_ENODEV,test_yaffs_sync_ENODEV_clean,"test_yaffs_sync_ENODEV"},
+
 
 
 
 
+       {test_yaffs_remount_force_off_read_only_off,test_yaffs_remount_force_off_read_only_off_clean,"test_yaffs_remount_force_off_read_only_off"},
+{test_yaffs_remount_force_on_read_only_off,test_yaffs_remount_force_on_read_only_off_clean,"test_yaffs_remount_force_on_read_only_off"},
+       {test_yaffs_remount_ENODEV,test_yaffs_remount_ENODEV_clean,"test_yaffs_remount_ENODEV"},
+       {test_yaffs_remount_EINVAL,test_yaffs_remount_EINVAL_clean,"test_yaffs_remount_EINVAL"},
 
 
+       {test_yaffs_freespace,test_yaffs_freespace_clean,"test_yaffs_freespace"}
        };
 
 void init_quick_tests(int argc, char *argv[]);
        };
 
 void init_quick_tests(int argc, char *argv[]);
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_freespace.c b/direct/timothy_tests/quick_tests/test_yaffs_freespace.c
new file mode 100644 (file)
index 0000000..8d714d8
--- /dev/null
@@ -0,0 +1,30 @@
+/*
+ * 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 "test_yaffs_freespace.h"
+
+
+
+int test_yaffs_freespace(void)
+{
+       int output=0;
+       output = yaffs_freespace(YAFFS_MOUNT_POINT);
+       return output;
+}
+
+
+int test_yaffs_freespace_clean(void)
+{
+       return 1;
+}
+
similarity index 79%
rename from direct/timothy_tests/quick_tests/test_yaffs_sync_ENOENT.h
rename to direct/timothy_tests/quick_tests/test_yaffs_freespace.h
index 55cf61b4f3ed83a6670c4fedc457c25bfad55bfc..8644be7454c4a6a034d755b17d35405a18eb46c2 100644 (file)
  * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
  */
 
  * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
  */
 
-#ifndef __test_yaffs_sync_ENOENT_h__
-#define __test_yaffs_sync_ENOENT_h__
+#ifndef __test_yaffs_freespace_h__
+#define __test_yaffs_freespace_h__
 
 #include "lib.h"
 #include "yaffsfs.h"
 
 
 #include "lib.h"
 #include "yaffsfs.h"
 
-int test_yaffs_sync_ENOENT(void);
-int test_yaffs_sync_ENOENT_clean(void);
+int test_yaffs_freespace(void);
+int test_yaffs_freespace_clean(void);
 
 #endif
 
 #endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_mount2_ENODEV.c b/direct/timothy_tests/quick_tests/test_yaffs_mount2_ENODEV.c
new file mode 100644 (file)
index 0000000..92a1e74
--- /dev/null
@@ -0,0 +1,55 @@
+/*
+ * 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 "test_yaffs_mount2_ENODEV.h"
+
+int test_yaffs_mount2_ENODEV(void)
+{
+       int output = -1;
+       int error_code =0;
+       output= yaffs_unmount(YAFFS_MOUNT_POINT);
+       if (output < 0) {
+               print_message("failed to unmount current_mountpoint\n",2);
+               return -1;
+       }
+
+       output = yaffs_mount2("/non-existing-dir/mountpoint",255);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == ENODEV){
+                       return 1;
+               } else {
+                       print_message("different_error than expected\n",2);
+                       return -1;
+               }
+       } else {
+               print_message("mounted a non-existing mountpoint\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_mount2_ENODEV_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_mount2_ENODEV.h b/direct/timothy_tests/quick_tests/test_yaffs_mount2_ENODEV.h
new file mode 100644 (file)
index 0000000..dfaec01
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_mount2_ENODEV__
+#define __test_yaffs_mount2_ENODEV__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_mount2_ENODEV(void);
+int test_yaffs_mount2_ENODEV_clean(void);
+
+#endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_EINVAL.c b/direct/timothy_tests/quick_tests/test_yaffs_remount_EINVAL.c
new file mode 100644 (file)
index 0000000..1f89ee7
--- /dev/null
@@ -0,0 +1,55 @@
+/*
+ * 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 "test_yaffs_remount_EINVAL.h"
+
+int test_yaffs_remount_EINVAL(void)
+{
+       int output = -1;
+       int error_code =0;
+       output = yaffs_unmount(YAFFS_MOUNT_POINT);      
+       if (output<0){
+               print_message("failed to unmount mount point\n",2);
+               return -1;
+       }
+
+       output = yaffs_remount(YAFFS_MOUNT_POINT,0,0);
+       if (output<0){
+               error_code = yaffs_get_error();
+               if (abs(error_code) == EINVAL){
+                       return 1;
+               } else {
+                       print_message("returned error does not match the the expected error\n",2);
+                       return -1;
+               }
+       } else {
+               print_message("remounted a non-existing-dir\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_remount_EINVAL_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_EINVAL.h b/direct/timothy_tests/quick_tests/test_yaffs_remount_EINVAL.h
new file mode 100644 (file)
index 0000000..b425da4
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_remount_EINVAL__
+#define __test_yaffs_remount_EINVAL__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_remount_EINVAL(void);
+int test_yaffs_remount_EINVAL_clean(void);
+
+#endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_ENODEV.c b/direct/timothy_tests/quick_tests/test_yaffs_remount_ENODEV.c
new file mode 100644 (file)
index 0000000..813de5c
--- /dev/null
@@ -0,0 +1,51 @@
+/*
+ * 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 "test_yaffs_remount_ENODEV.h"
+
+int test_yaffs_remount_ENODEV(void)
+{
+       int output = -1;
+       int error_code =0;
+
+
+       output = yaffs_remount("non-existing-mount-point",0,0);
+       if (output<0){
+               error_code = yaffs_get_error();
+               if (abs(error_code) == ENODEV){
+                       return 1;
+               } else {
+                       print_message("returned error does not match the the expected error\n",2);
+                       return -1;
+               }
+       } else {
+               print_message("remounted a non-existing-dir\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_remount_ENODEV_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_ENODEV.h b/direct/timothy_tests/quick_tests/test_yaffs_remount_ENODEV.h
new file mode 100644 (file)
index 0000000..d37a5a1
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_remount_ENODEV__
+#define __test_yaffs_remount_ENODEV__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_remount_ENODEV(void);
+int test_yaffs_remount_ENODEV_clean(void);
+
+#endif
similarity index 55%
rename from direct/timothy_tests/quick_tests/test_yaffs_sync_ENOENT.c
rename to direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_off.c
index 2f1792d4ac4cb789468014dc084126e1ba6190c1..e86f9239a71223d5f3bae3f8fa87f31254567f3a 100644 (file)
  * published by the Free Software Foundation.
  */
 
  * published by the Free Software Foundation.
  */
 
-#include "test_yaffs_sync_ENOENT.h"
+#include "test_yaffs_remount_force_off_read_only_off.h"
 
 
+int test_yaffs_remount_force_off_read_only_off(void)
+{
+       int output = -1;
+       int error_code =0;
+
+
+       output = yaffs_remount(YAFFS_MOUNT_POINT,0,0);
+       if (output>=0){
+               return 1;
+       } else {
+               print_message("failed to remount\n",2);
+               return -1;
+       }
+}
 
 
-int test_yaffs_sync_ENOENT(void)
+int test_yaffs_remount_force_off_read_only_off_clean(void)
 {
 {
-       int error_code=-1;
-       int output = yaffs_sync("yaffs2/non-existing-file");
-       
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
        if (output<0){
                error_code=yaffs_get_error();
        if (output<0){
                error_code=yaffs_get_error();
-               if (abs(error_code)==ENOENT){
+               if (abs(error_code) == EBUSY){
                        return 1;
                } else {
                        return 1;
                } else {
-                       print_message("returned error does not match the the expected error\n",2);
                        return -1;
                }
                        return -1;
                }
-       } else {
-               print_message("synced a file in a non-existing directory (which is a bad thing)\n",2);
-               return -1;
-       }       
-
-
-}
-
-
-int test_yaffs_sync_ENOENT_clean(void)
-{
+       }
        return 1;
 }
        return 1;
 }
-
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_off.h b/direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_off.h
new file mode 100644 (file)
index 0000000..6772e7d
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_remount_force_off_read_only_off__
+#define __test_yaffs_remount_force_off_read_only_off__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_remount_force_off_read_only_off(void);
+int test_yaffs_remount_force_off_read_only_off_clean(void);
+
+#endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_on.c b/direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_on.c
new file mode 100644 (file)
index 0000000..fbb37c1
--- /dev/null
@@ -0,0 +1,49 @@
+/*
+ * 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 "test_yaffs_remount.h"
+
+int test_yaffs_remount(void)
+{
+       int output = -1;
+       int error_code =0;
+       output=test_yaffs_open();
+       if (output<0) {
+               print_message("failed to open file\n",2);
+               return -1;
+       }
+
+       output = yaffs_remount(YAFFS_MOUNT_POINT,1,0);
+       if (output>=0){
+               return 1;
+       } else {
+               print_message("failed to unmount with a open file with the force mode set\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_remount_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_on.h b/direct/timothy_tests/quick_tests/test_yaffs_remount_force_off_read_only_on.h
new file mode 100644 (file)
index 0000000..7574695
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_unmount2_with_handle_open_and_forced_mode_on__
+#define __test_yaffs_unmount2_with_handle_open_and_forced_mode_on__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_on(void);
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_on_clean(void);
+
+#endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_off.c b/direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_off.c
new file mode 100644 (file)
index 0000000..64dcfd7
--- /dev/null
@@ -0,0 +1,49 @@
+/*
+ * 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 "test_yaffs_remount_force_on_read_only_off.h"
+
+int test_yaffs_remount_force_on_read_only_off(void)
+{
+       int output = -1;
+       int error_code =0;
+       output=test_yaffs_open();
+       if (output<0) {
+               print_message("failed to open file\n",2);
+               return -1;
+       }
+
+       output = yaffs_remount(YAFFS_MOUNT_POINT,1,0);
+       if (output>=0){
+               return 1;
+       } else {
+               print_message("failed to unmount with a open file with the force mode set\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_remount_force_on_read_only_off_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_off.h b/direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_off.h
new file mode 100644 (file)
index 0000000..00646fb
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_remount_force_on_read_only_off__
+#define __test_yaffs_remount_force_on_read_only_off__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_remount_force_on_read_only_off(void);
+int test_yaffs_remount_force_on_read_only_off_clean(void);
+
+#endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_on.c b/direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_on.c
new file mode 100644 (file)
index 0000000..fbb37c1
--- /dev/null
@@ -0,0 +1,49 @@
+/*
+ * 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 "test_yaffs_remount.h"
+
+int test_yaffs_remount(void)
+{
+       int output = -1;
+       int error_code =0;
+       output=test_yaffs_open();
+       if (output<0) {
+               print_message("failed to open file\n",2);
+               return -1;
+       }
+
+       output = yaffs_remount(YAFFS_MOUNT_POINT,1,0);
+       if (output>=0){
+               return 1;
+       } else {
+               print_message("failed to unmount with a open file with the force mode set\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_remount_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_on.h b/direct/timothy_tests/quick_tests/test_yaffs_remount_force_on_read_only_on.h
new file mode 100644 (file)
index 0000000..7574695
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_unmount2_with_handle_open_and_forced_mode_on__
+#define __test_yaffs_unmount2_with_handle_open_and_forced_mode_on__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_on(void);
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_on_clean(void);
+
+#endif
similarity index 84%
rename from direct/timothy_tests/quick_tests/test_yaffs_sync_ENOTDIR.c
rename to direct/timothy_tests/quick_tests/test_yaffs_sync_ENODEV.c
index 0961af20c6789c595289e62670ea6c90a44a578f..90ae4a41bf63f324f7dd7f6adfd8f3185a74185b 100644 (file)
  * published by the Free Software Foundation.
  */
 
  * published by the Free Software Foundation.
  */
 
-#include "test_yaffs_sync_ENOTDIR.h"
+#include "test_yaffs_sync_ENODEV.h"
 
 
 
 
-int test_yaffs_sync_ENOTDIR(void)
+int test_yaffs_sync_ENODEV(void)
 {
        int error_code=-1;
        int output = yaffs_sync("non-existing-dir/foo");
        
        if (output<0){
                error_code=yaffs_get_error();
 {
        int error_code=-1;
        int output = yaffs_sync("non-existing-dir/foo");
        
        if (output<0){
                error_code=yaffs_get_error();
-               if (abs(error_code)==ENOTDIR){
+               if (abs(error_code)==ENODEV){
                        return 1;
                } else {
                        print_message("returned error does not match the the expected error\n",2);
                        return 1;
                } else {
                        print_message("returned error does not match the the expected error\n",2);
@@ -36,7 +36,7 @@ int test_yaffs_sync_ENOTDIR(void)
 }
 
 
 }
 
 
-int test_yaffs_sync_ENOTDIR_clean(void)
+int test_yaffs_sync_ENODEV_clean(void)
 {
        return 1;
 }
 {
        return 1;
 }
similarity index 78%
rename from direct/timothy_tests/quick_tests/test_yaffs_sync_ENOTDIR.h
rename to direct/timothy_tests/quick_tests/test_yaffs_sync_ENODEV.h
index 4b11cabd4f8197dceb3f08d12ee69b1393b7a089..e3aec49819612a17cb7a8e13c13693904889d1d9 100644 (file)
  * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
  */
 
  * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
  */
 
-#ifndef __test_yaffs_sync_ENOTDIR_h__
-#define __test_yaffs_sync_ENOTDIR_h__
+#ifndef __test_yaffs_sync_ENODEV_h__
+#define __test_yaffs_sync_ENODEV_h__
 
 #include "lib.h"
 #include "yaffsfs.h"
 
 
 #include "lib.h"
 #include "yaffsfs.h"
 
-int test_yaffs_sync_ENOTDIR(void);
-int test_yaffs_sync_ENOTDIR_clean(void);
+int test_yaffs_sync_ENODEV(void);
+int test_yaffs_sync_ENODEV_clean(void);
 
 #endif
 
 #endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unmount2_EINVAL.c b/direct/timothy_tests/quick_tests/test_yaffs_unmount2_EINVAL.c
new file mode 100644 (file)
index 0000000..cafc508
--- /dev/null
@@ -0,0 +1,55 @@
+/*
+ * 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 "test_yaffs_unmount2_EINVAL.h"
+
+int test_yaffs_unmount2_EINVAL(void)
+{
+       int output = -1;
+       int error_code =0;
+       output=yaffs_unmount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               print_message("failed to unmount the mount poin the first time\n",2);
+               return -1;
+       }
+
+       output = yaffs_unmount2(YAFFS_MOUNT_POINT,255);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EINVAL){
+                       return 1;
+               } else {
+                       print_message("different_error than expected\n",2);
+                       return -1;
+               }
+       } else {
+               print_message("unmounted a non-existing mountpoint\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_unmount2_EINVAL_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unmount2_EINVAL.h b/direct/timothy_tests/quick_tests/test_yaffs_unmount2_EINVAL.h
new file mode 100644 (file)
index 0000000..b698dff
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_unmount2_EINVAL__
+#define __test_yaffs_unmount2_EINVAL__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_unmount2_EINVAL(void);
+int test_yaffs_unmount2_EINVAL_clean(void);
+
+#endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unmount2_ENODEV.c b/direct/timothy_tests/quick_tests/test_yaffs_unmount2_ENODEV.c
new file mode 100644 (file)
index 0000000..4311438
--- /dev/null
@@ -0,0 +1,50 @@
+/*
+ * 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 "test_yaffs_unmount2_ENODEV.h"
+
+int test_yaffs_unmount2_ENODEV(void)
+{
+       int output = -1;
+       int error_code =0;
+
+       output = yaffs_unmount2("/non-existing-dir/",255);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == ENODEV){
+                       return 1;
+               } else {
+                       print_message("different_error than expected\n",2);
+                       return -1;
+               }
+       } else {
+               print_message("unmounted a non-existing mountpoint\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_unmount2_ENODEV_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unmount2_ENODEV.h b/direct/timothy_tests/quick_tests/test_yaffs_unmount2_ENODEV.h
new file mode 100644 (file)
index 0000000..dc2b1fa
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_unmount2_ENODEV__
+#define __test_yaffs_unmount2_ENODEV__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_unmount2_ENODEV(void);
+int test_yaffs_unmount2_ENODEV_clean(void);
+
+#endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_off.c b/direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_off.c
new file mode 100644 (file)
index 0000000..982f2bd
--- /dev/null
@@ -0,0 +1,55 @@
+/*
+ * 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 "test_yaffs_unmount2_with_handle_open_and_forced_mode_off.h"
+
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_off(void)
+{
+       int output = -1;
+       int error_code =0;
+       output=test_yaffs_open();
+       if (output<0) {
+               print_message("failed to open file\n",2);
+               return -1;
+       }
+
+       output = yaffs_unmount2(YAFFS_MOUNT_POINT,0);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       print_message("different_error than expected\n",2);
+                       return -1;
+               }
+       } else {
+               print_message("unmounted with a open file and force mode off.\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_off_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_off.h b/direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_off.h
new file mode 100644 (file)
index 0000000..e60f117
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_unmount2_with_handle_open_and_forced_mode_off__
+#define __test_yaffs_unmount2_with_handle_open_and_forced_mode_off__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_off(void);
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_off_clean(void);
+
+#endif
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_on.c b/direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_on.c
new file mode 100644 (file)
index 0000000..b7f7c12
--- /dev/null
@@ -0,0 +1,49 @@
+/*
+ * 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 "test_yaffs_unmount2_with_handle_open_and_forced_mode_on.h"
+
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_on(void)
+{
+       int output = -1;
+       int error_code =0;
+       output=test_yaffs_open();
+       if (output<0) {
+               print_message("failed to open file\n",2);
+               return -1;
+       }
+
+       output = yaffs_unmount2(YAFFS_MOUNT_POINT,1);
+       if (output>=0){
+               return 1;
+       } else {
+               print_message("failed to unmount with a open file with the force mode set\n",2);
+               return -1;
+       }
+}
+
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_on_clean(void)
+{
+       int output=0;
+       int error_code =0;
+       output= yaffs_mount(YAFFS_MOUNT_POINT);
+       if (output<0){
+               error_code=yaffs_get_error();
+               if (abs(error_code) == EBUSY){
+                       return 1;
+               } else {
+                       return -1;
+               }
+       }
+       return 1;
+}
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_on.h b/direct/timothy_tests/quick_tests/test_yaffs_unmount2_with_handle_open_and_forced_mode_on.h
new file mode 100644 (file)
index 0000000..7574695
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * YAFFS: Yet another Flash File System . 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 Lesser General Public License version 2.1 as
+ * published by the Free Software Foundation.
+ *
+ * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
+ */
+
+#ifndef __test_yaffs_unmount2_with_handle_open_and_forced_mode_on__
+#define __test_yaffs_unmount2_with_handle_open_and_forced_mode_on__
+
+#include "yaffsfs.h"
+#include "lib.h"
+#include "test_yaffs_unmount.h"
+
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_on(void);
+int test_yaffs_unmount2_with_handle_open_and_forced_mode_on_clean(void);
+
+#endif