summaryrefslogtreecommitdiff
path: root/direct/timothy_tests/quick_tests/README.txt
blob: 55b670e6680eb2b1fef9916c0038f0682217bb85 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
Made by Timothy Manning <timothy@yaffs.net> on 04/11/2010

This test is designed to test the response and error handling of the yaffs functions.

compile command: make
run command: ./quick_tests

command line options:
	-h 				prints the available command line options.
	-c				tests will continue even if a test fails, rather than exiting the test.
	-v 				verbose mode. will print all messages.
	-q				quiet mode. will not print any messages.
	-t [number]		sets the yaffs_trace() function to the number.
	-n [number]		sets the number of randomly selected tests to run after the test has run through 
					after running all of listed tests.

############################# development infomation ####################################################################

Tests made

test_yaffs_access.c
test_yaffs_access_EACCES.c
test_yaffs_access_EINVAL.c
test_yaffs_access_ELOOP.c
test_yaffs_access_ELOOP_dir.c
test_yaffs_access_ENAMETOOLONG.c
test_yaffs_access_ENOENT2.c
test_yaffs_access_ENOENT.c
test_yaffs_access_ENOTDIR.c
test_yaffs_access_EROFS.c
test_yaffs_access_NULL.c

test_yaffs_chmod.c
test_yaffs_chmod_EINVAL.c
test_yaffs_chmod_ELOOP.c
test_yaffs_chmod_ELOOP_dir.c
test_yaffs_chmod_ENAMETOOLONG.c
test_yaffs_chmod_ENOENT2.c
test_yaffs_chmod_ENOENT.c
test_yaffs_chmod_ENOTDIR.c
test_yaffs_chmod_EROFS.c
test_yaffs_chmod_NULL.c

test_yaffs_close.c
test_yaffs_close_EBADF.c
test_yaffs_close_NULL.c

test_yaffs_dup.c
test_yaffs_dup_EBADF.c	

test_yaffs_fchmod.c
test_yaffs_fchmod_EBADF.c
test_yaffs_fchmod_EINVAL.c
test_yaffs_fchmod_EROFS.c
test_yaffs_fchmod_NULL.c

test_yaffs_fdatasync.c
test_yaffs_fdatasync_EBADF.c
test_yaffs_fdatasync_EROFS.c
test_yaffs_fdatasync_NULL.c

test_yaffs_flush.c
test_yaffs_flush_EBADF.c
test_yaffs_flush_EROFS.c

test_yaffs_freespace.c
test_yaffs_freespace_EINVAL.c
test_yaffs_freespace_ENAMETOOLONG.c
test_yaffs_freespace_NULL.c

test_yaffs_fstat.c
test_yaffs_fstat_EBADF.c

test_yaffs_fsync.c
test_yaffs_fsync_EBADF.c
test_yaffs_fsync_EROFS.c

test_yaffs_ftruncate_big_file.c
test_yaffs_ftruncate.c
test_yaffs_ftruncate_EBADF.c
test_yaffs_ftruncate_EINVAL.c
test_yaffs_ftruncate_EROFS.c

test_yaffs_inodecount.c
test_yaffs_inodecount_EINVAL.c
test_yaffs_inodecount_ENAMETOOLONG.c
test_yaffs_inodecount_NULL.c

test_yaffs_link.c
test_yaffs_link_EEXIST.c
test_yaffs_link_ELOOP_dir.c
test_yaffs_link_ENAMETOOLONG2.c
test_yaffs_link_ENAMETOOLONG.c
test_yaffs_link_ENOENT2.c
test_yaffs_link_ENOENT3.c
test_yaffs_link_ENOENT4.c
test_yaffs_link_ENOENT.c
test_yaffs_link_ENOTDIR2.c
test_yaffs_link_ENOTDIR.c
test_yaffs_link_EROFS.c
test_yaffs_link_NULL2.c
test_yaffs_link_NULL.c

test_yaffs_lseek_big_file.c
test_yaffs_lseek.c
test_yaffs_lseek_EBADF.c
test_yaffs_lseek_EINVAL.c
test_yaffs_lseek_EROFS.c

test_yaffs_lstat.c
test_yaffs_lstat_ENAMETOOLONG.c
test_yaffs_lstat_ENOENT.c
test_yaffs_lstat_ENOTDIR.c
test_yaffs_lstat_NULL.c

test_yaffs_mkdir.c
test_yaffs_mkdir_EEXIST.c
test_yaffs_mkdir_ELOOP_dir.c
test_yaffs_mkdir_ENAMETOOLONG.c
test_yaffs_mkdir_ENOENT.c
test_yaffs_mkdir_ENOTDIR.c
test_yaffs_mkdir_EROFS.c
test_yaffs_mkdir_NULL.c

test_yaffs_mount2.c
test_yaffs_mount2_ENODEV.c

test_yaffs_mount.c
test_yaffs_mount_EBUSY.c
test_yaffs_mount_ENAMETOOLONG.c
test_yaffs_mount_ENODEV.c
test_yaffs_mount_NULL.c

test_yaffs_open.c
test_yaffs_open_EACCES.c
test_yaffs_open_EEXIST.c
test_yaffs_open_EINVAL2.c
test_yaffs_open_EINVAL.c
test_yaffs_open_EISDIR.c
test_yaffs_open_ELOOP.c
test_yaffs_open_ELOOP_dir.c
test_yaffs_open_ENAMETOOLONG.c
test_yaffs_open_ENOENT.c
test_yaffs_open_ENOTDIR.c
test_yaffs_open_EROFS.c
test_yaffs_open_NULL.c

test_yaffs_read.c
test_yaffs_read_EBADF.c
test_yaffs_read_EINVAL.c

test_yaffs_remount_EINVAL.c
test_yaffs_remount_ENAMETOOLONG.c
test_yaffs_remount_ENODEV.c
test_yaffs_remount_force_off_read_only_off.c
test_yaffs_remount_force_off_read_only_on.c
test_yaffs_remount_force_on_read_only_off.c
test_yaffs_remount_force_on_read_only_on.c
test_yaffs_remount_NULL.c

test_yaffs_rename.c
test_yaffs_rename_dir.c
test_yaffs_rename_dir_ENOENT2.c
test_yaffs_rename_dir_ENOENT.c
test_yaffs_rename_dir_not_empty.c
test_yaffs_rename_dir_to_file.c
test_yaffs_rename_EEXISTS.c
test_yaffs_rename_EINVAL.c
test_yaffs_rename_ELOOP_dir.c
test_yaffs_rename_ENAMETOOLONG2.c
test_yaffs_rename_ENAMETOOLONG.c
test_yaffs_rename_ENOENT.c
test_yaffs_rename_ENOTDIR.c
test_yaffs_rename_EROFS.c
test_yaffs_rename_file_to_dir.c
test_yaffs_rename_NULL2.c
test_yaffs_rename_NULL.c

test_yaffs_rmdir.c
test_yaffs_rmdir_EBUSY.c
test_yaffs_rmdir_EINVAL.c
test_yaffs_rmdir_ELOOP_dir.c
test_yaffs_rmdir_ENAMETOOLONG.c
test_yaffs_rmdir_ENOENT.c
test_yaffs_rmdir_ENOTDIR.c
test_yaffs_rmdir_EROFS.c
test_yaffs_rmdir_NULL.c

test_yaffs_stat.c
test_yaffs_stat_ELOOP.c
test_yaffs_stat_ELOOP_dir.c
test_yaffs_stat_ENAMETOOLONG.c
test_yaffs_stat_ENOENT2.c
test_yaffs_stat_ENOENT.c
test_yaffs_stat_ENOTDIR.c
test_yaffs_stat_NULL.c

test_yaffs_symlink.c
test_yaffs_symlink_EEXIST.c
test_yaffs_symlink_ELOOP_dir.c
test_yaffs_symlink_ENAMETOOLONG.c
test_yaffs_symlink_ENOENT2.c
test_yaffs_symlink_ENOENT.c
test_yaffs_symlink_ENOTDIR.c
test_yaffs_symlink_EROFS.c
test_yaffs_symlink_NULL2.c
test_yaffs_symlink_NULL.c

test_yaffs_sync.c
test_yaffs_sync_ENAMETOOLONG.c
test_yaffs_sync_ENODEV.c
test_yaffs_sync_EROFS.c
test_yaffs_sync_NULL.c

test_yaffs_totalspace.c
test_yaffs_totalspace_EINVAL.c
test_yaffs_totalspace_ENAMETOOLONG.c
test_yaffs_totalspace_NULL.c

test_yaffs_truncate_big_file.c
test_yaffs_truncate.c
test_yaffs_truncate_EINVAL.c
test_yaffs_truncate_EISDIR.c
test_yaffs_truncate_ELOOP.c
test_yaffs_truncate_ELOOP_dir.c
test_yaffs_truncate_ENAMETOOLONG.c
test_yaffs_truncate_ENOENT2.c
test_yaffs_truncate_ENOENT.c
test_yaffs_truncate_ENOTDIR.c
test_yaffs_truncate_EROFS.c
test_yaffs_truncate_NULL.c

test_yaffs_unlink.c
test_yaffs_unlink_EISDIR.c
test_yaffs_unlink_ELOOP_dir.c
test_yaffs_unlink_ENAMETOOLONG.c
test_yaffs_unlink_ENOENT2.c
test_yaffs_unlink_ENOENT.c
test_yaffs_unlink_ENOTDIR.c
test_yaffs_unlink_EROFS.c
test_yaffs_unlink_NULL.c

test_yaffs_unmount2.c
test_yaffs_unmount2_EINVAL.c
test_yaffs_unmount2_ENODEV.c
test_yaffs_unmount2_with_handle_open_and_forced_mode_off.c
test_yaffs_unmount2_with_handle_open_and_forced_mode_on.c
test_yaffs_unmount.c
test_yaffs_unmount_EBUSY.c
test_yaffs_unmount_ENAMETOOLONG.c
test_yaffs_unmount_ENODEV.c
test_yaffs_unmount_NULL.c

test_yaffs_write_big_file.c
test_yaffs_write.c
test_yaffs_write_EBADF.c
test_yaffs_write_EROFS.c



Tests to add

	test_yaffs_rename a file over its self.

	test_yaffs_readlink
	test_yaffs_readlink_ENOENT
	test_yaffs_readlink_ENOTDIR
	test_yaffs_readlink_ELOOP

	test_yaffs_mount2_with read only set

	test_yaffs_remount_force_off_read_only_on
	test_yaffs_remount_force_on_read_only_on

	test_yaffs_opendir

	test_yaffs_readdir

	test_yaffs_rewinddir

	test_yaffs_closedir

	test_yaffs_link_EPERM

	test_yaffs_rmdir_ENOTEMPTY

	test_yaffs_rename_EMLINK
	test_yaffs_rename_EEXISTS or EPERM	

	test_yaffs_open_ENOSPC

	test yaffs_open_running_out_of_handles error

	test_yaffs_read_big_file
	test what happens if you read off the end of the file?

	test_yaffs_pread
	test_yaffs_pread_EBADF
	test_yaffs_pread_EINVAL
	test_yaffs_pread_big_file

	test_yaffs_write_big_file
	test_yaffs_write_EINVAL
	What happens when you run out of space?
	

	test_yaffs_pwrite_big_file
	test_yaffs_pwrite_EINVAL

	test_yaffs_unlink_ENOMEM

	test_yaffs_access_ENOENT_generated_with_a_dangling_symbloic_link

	Add a truncate function for truncating a file size to -1.

	What happens if a handle is opened to a file and the file is then deleted?
	Check to see if yaffs generates an error code for no reason.
	What happens when a file is opened with no modes set?

	What happens when yaffs is unmounted twice?

	What happens when open a handle, unmount yaffs and then try to use the handle? 

	What happens when a mount point is mounted using mount2 with read only mode set and then a file is chmoded? 

	Try to remove lost and found dir and replace it with a file of the same name.

	Change the mode of the lost and found dir to read only.

Tests which do not exist in yaffs:
	test_yaffs_close	//This function has already been called by the time this test is reached, 
				//so there is no point in testing it.

	test_yaffs_link_EMLINK		//should not happen on yaffs
	test_yaffs_link_ELOOP
	
	test_yaffs_lstat_ELOOP

	test_yaffs_mkdir_ELOOP

	//the yaffs_mknod function does not exist in yaffsfs, so these tests will not be added.
	test_yaffs_mknod_EACCES
	test_yaffs_mknod_EEXIST
	test_yaffs_mknod_EINVAL
	test_yaffs_mknod_ELOOP
	test_yaffs_mknod_ENAMETOOLONG
	test_yaffs_mknod_ENOENT
	test_yaffs_mknod_ENOTDIR
	test_yaffs_mknod_EROFS

	teat_yaffs_mount_ELOOP

	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_ELOOP

	test_yaffs_remount_ENOENT	//cannot be generated in yaffs
	test_yaffs_remount_ENOTDIR	//cannot be generated in yaffs

	test_yaffs_unmount2_ENOENT	//cannot be generated in yaffs.
	test_yaffs_unmount2_ENOTDIR	//cannot be generated in yaffs.

How to add a test
	First create the test .c and .h file.
	The file name and test function name should be the same. 
	This name should follow one of these formats: 
	Test_yaffs_[function of yaffs which is been tested]
	Test_yaffs_[function of yaffs which is been tested]_[error trying to be generated]
	
	The .c file needs to contain two functions.
	The first function needs to contain the code for the main test and will 
	return -1 on a failure and 0 or greater on a success.
	The second function needs contain the code for cleaning up after the test. 
	Cleaning up may include closing some open handles, recreating a file, ect. 
	This second function needs to return -1 on a failure and 0 or greater on success.

	The name of first function needs to be called the same as the file 
	name (without the .c or .h)
	The second function's name needs be the same as the first function but 
	with "_clean" added on the end.
	
	So if a test is been created for the yaffs function yaffs_foo() then 
	create these files
	test_yaffs_foo.c
		Contains int test_yaffs_foo(void); int test_yaffs_foo_clean(void);
	test_yaffs_foo.h
		Which includes "lib.h", "yaffsfs.h" header files.

	Next write the test code in these files then add these files to the Makefile.

	Add the name of the test files' object file (test_yaffs_foo.o ) to the 
	TESTFILES tag around line 50 of the Makefile.	

	Now add the test functions to the test_list[] array in quick_tests.h
	The order of the tests matters. The idea is to test each yaffs_function 
	individualy and only using tested yaffs_components before using this new 
	yaffs_function. 
	This array consists of: 
	{[test function], [the clean function], [name of the tests which will be printed when the test fails]},	
	
	So add this line to the test_list[]: {test_yaffs_foo, test_yaffs_foo_clean, "test_yaffs_foo"},

	Also include the test's .h file in the quick_test.h file: #include "test_yaffs_foo.h"
	
	The test file should now make and run(you may need to make clean first). 



	PS: yaffs_foo() is a made up function for this README (in case you want 
	to find this function in yaffs).