yaffs More tests for quick tests.
[yaffs2.git] / direct / timothy_tests / quick_tests / README.txt
1
2 Made by Timothy Manning <timothy@yaffs.net> on 04/11/2010
3
4
5 Tests made
6         test_yaffs_mount
7         test_yaffs_mount_ENODEV
8         test_yaffs_mount_ENAMETOOLONG
9         test_yaffs_mount_ENOENT
10         test_yaffs_mount_EBUSY          //called when trying to mount a new mount point with a mount point already mounted.
11
12         test_yaffs_access
13         test_yaffs_access_ENIVAL
14         test_yaffs_access_ENOTDIR
15         test_yaffs_access_ENOENT
16
17         test_yaffs_close_EBADF
18
19         test_yaffs_ftruncate
20         test_yaffs_ftruncate_EBADF
21         test_yaffs_ftruncate_ENIVAL
22         test_yaffs_ftruncate_EFBIG
23
24         test_yaffs_lseek
25         test_yaffs_lseek_EBADF
26         test_yaffs_lseek_EINVAL
27         test_yaffs_lseek_EFBIG
28
29         test_yaffs_open
30         test_yaffs_open_EEXIST
31         test_yaffs_open_EISDIR
32         test_yaffs_open_ENAMETOOLONG
33         test_yaffs_open_ENOENT
34         test_yaffs_open_ENOTDIR
35         test_yaffs_open_EINVAL
36         test_yaffs_open_EINVAL2 //the function open has two modes which can be set, so two tests modes are needed.
37
38         test_yaffs_read
39         test_yaffs_read_EBADF
40         test_yaffs_read_EINVAL
41
42
43         test_yaffs_stat
44
45         test_yaffs_truncate
46         test_yaffs_truncate_ENOTDIR
47         test_yaffs_truncate_EISDIR
48         test_yaffs_truncate_ENOENT
49         test_yaffs_truncate_ENIVAL
50         test_yaffs_truncate_EFBIG
51
52         test_yaffs_unlink
53         test_yaffs_unlink_EISDIR
54         test_yaffs_unlink_ENAMETOOLONG
55         test_yaffs_unlink_ENOENT
56         test_yaffs_unlink_ENOTDIR
57         test_yaffs_unlink_ENOENT
58
59         test_yaffs_unmount
60         test_yaffs_unmount_ENOENT
61         test_yaffs_unmount_ENAMETOOLONG
62         test_yaffs_umount_EBUSY //cause by having a file handle open and then trying to unmount yaffs.
63
64         test_yaffs_write
65         test_yaffs_write_EBADF
66
67         
68
69 Tests to add
70         test_yaffs_mount_EACCES         //Cannot be generated with yaffs.
71         test_yaffs_mount_EINVAL         //Cannot be generated with yaffs.
72         test_yaffs_mount_ELOOP          //Cannot be generated with yaffs.
73         test_yaffs_mount_EMFILE         //Cannot be generated with yaffs.
74         test_yaffs_mount_ENOTDIR        //Cannot be generated with yaffs.
75
76         test_yaffs_umount_ENODEV        //Cannot be generated with yaffs.
77         test_yaffs_umount_ENOENT        //Cannot be generated with yaffs.
78                         
79
80         test_yaffs_open_EACCES
81         test_yaffs_open_ENOSPC
82         test_yaffs_open_ELOOP   //Too many symbolic links were encountered in resolving pathname
83         test yaffs_open_running_out_of_handles error
84
85         test_yaffs_close        //This function has already been called by the time this test is reached.
86         
87         test_yaffs_stat_EBADF
88         test_yaffs_stat_ELOOP
89         test_yaffs_stat_EACCES
90         test_yaffs_stat_ENAMETOOLONG
91         test_yaffs_stat_ENOTDIR
92          
93         test_yaffs_read_EISDIR          //Cannot be generated with yaffs.
94         test_yaffs_read_EFBIG
95         test what happens if you read off the end of the file?
96
97         test_yaffs_write_EFBIG
98         test_yaffs_write_EINVAL
99         What happens when you run out of space?
100
101         test_yaffs_unlink_EACCES
102         test_yaffs_unlink_ELOOP
103         test_yaffs_unlink_ENOMEM
104
105         test_yaffs_access_EACCESS
106         test_yaffs_access_ELOOP
107         test_yaffs_access_ENAMETOOLONG
108         test_yaffs_access_ENOENT_generated_with_a_dangling_symbloic_link
109
110         test_yaffs_ftruncate_EACCES     
111         test_yaffs_ftruncate_EISDIR     //Cannot be generated with yaffs.
112         test_yaffs_ftruncate_ELOOP      //Cannot be generated with yaffs.
113         test_yaffs_ftruncate_ENOENT     //Cannot be generated with yaffs.
114         test_yaffs_ftruncate_ENOTDIR    //Cannot be generated with yaffs.
115
116         test_yaffs_truncate_EACCES
117         test_yaffs_truncate_ELOOP
118         test_yaffs_truncate_ENAMETOOLONG
119         add a truncate function for truncating a file size to -1.
120
121         What happens if a handle is opened to a file and the file is then deleted?
122         Check to see if yaffs generates an error code for no reason.
123         What happens when a file is opened with no modes set?
124         Add a test where a directory is moved. /fluffy/box. move "fluffy" to "/fluffy/frog". 
125         What happens when yaffs is unmounted twice?
126
127         What happens when open a handle, unmount yaffs and then try to use the handle? 
128
129 How to add a test
130         First create the test .c and .h file.
131         The file name and test function name should be the same. 
132         This name should follow one of these formats: 
133         Test_yaffs_[function of yaffs which is been tested]
134         Test_yaffs_[function of yaffs which is been tested]_[error trying to be generated]
135         
136         The .c file needs to contain two functions.
137         The first function needs to contain the code for the main test and will 
138         return -1 on a failure and 0 or greater on a success.
139         The second function needs contain the code for cleaning up after the test. 
140         Cleaning up may include closing some open handles, recreating a file, ect. 
141         This second function needs to return -1 on a failure and 0 or greater on success.
142
143         The name of first function needs to be called the same as the file 
144         name (without the .c or .h)
145         The second function's name needs be the same as the first function but 
146         with "_clean" added on the end.
147         
148         So if a test is been created for the yaffs function yaffs_foo() then 
149         create these files
150         test_yaffs_foo.c
151                 Contains int test_yaffs_foo(void); int test_yaffs_foo_clean(void);
152         test_yaffs_foo.h
153                 Which includes "lib.h", "yaffsfs.h" header files.
154
155         Next write the test code in these files then add these files to the Makefile.
156
157         Add the name of the test files' object file (test_yaffs_foo.o ) to the 
158         TESTFILES tag around line 50 of the Makefile.   
159
160         Now add the test functions to the test_list[] array in quick_tests.h
161         The order of the tests matters. The idea is to test each yaffs_function 
162         individualy and only using tested yaffs_components before using this new 
163         yaffs_function. 
164         This array consists of: 
165         {[test function], [the clean function], [name of the tests which will be printed when the test fails]}, 
166         
167         So add this line to the test_list[]: {test_yaffs_foo, test_yaffs_foo_clean, "test_yaffs_foo"},
168
169         Also include the test's .h file in the quick_test.h file: #include "test_yaffs_foo.h"
170         
171         The test file should now make and run(you may need to make clean first). 
172
173
174
175         PS: yaffs_foo() is a made up function for this README (in case you want 
176         to find this function in yaffs). 
177
178
179
180
181
182