Update BattFS in order to use the new kblock interface.
[bertos.git] / bertos / fs / battfs_test.c
1 /**
2  * \file
3  * <!--
4  * This file is part of BeRTOS.
5  *
6  * Bertos is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19  *
20  * As a special exception, you may use this file as part of a free software
21  * library without restriction.  Specifically, if other files instantiate
22  * templates or use macros or inline functions from this file, or you compile
23  * this file and link it with other files to produce an executable, this
24  * file does not by itself cause the resulting executable to be covered by
25  * the GNU General Public License.  This exception does not however
26  * invalidate any other reasons why the executable file might be covered by
27  * the GNU General Public License.
28  *
29  * Copyright 2007, 2008 Develer S.r.l. (http://www.develer.com/)
30  * -->
31  *
32  * \brief BattFS Test.
33  *
34  * \version $Id$
35  * \author Francesco Sacchi <batt@develer.com>
36  */
37
38 #include <fs/battfs.h>
39 #include <io/kblock_file.h>
40
41 #include <cfg/debug.h>
42 #include <cfg/test.h>
43
44 #include <stdio.h>
45 #include <stdlib.h>
46 #include <string.h>
47
48 #define FILE_SIZE 32768
49 #define PAGE_SIZE 128
50
51 #define DATA_SIZE (PAGE_SIZE - BATTFS_HEADER_LEN)
52 #define PAGE_COUNT (FILE_SIZE / PAGE_SIZE)
53
54 #if UNIT_TEST
55
56 const char test_filename[]="battfs_disk.bin";
57
58 static uint8_t page_buffer[PAGE_SIZE];
59 static pgcnt_t page_array[PAGE_COUNT];
60
61 static void testCheck(BattFsSuper *disk, pgcnt_t *reference)
62 {
63         ASSERT(battfs_fsck(disk));
64
65         for (int i = 0; i < disk->page_count; i++)
66         {
67                 if (disk->page_array[i] != reference[i])
68                 {
69                         kprintf("Error at addr %d: page_array read", i);
70                         for (pgcnt_t i = 0; i < disk->page_count; i++)
71                         {
72                                 if (!(i % 16))
73                                         kputchar('\n');
74                                 kprintf("%04d ", disk->page_array[i]);
75                         }
76                         kputchar('\n');
77                         kprintf("Expected:");
78                         for (pgcnt_t i = 0; i < disk->page_count; i++)
79                         {
80                                 if (!(i % 16))
81                                         kputchar('\n');
82                                 kprintf("%04d ", reference[i]);
83                         }
84                         kputchar('\n');
85                         battfs_umount(disk);
86                         exit(2);
87                 }
88         }
89
90         ASSERT(battfs_fsck(disk));
91         ASSERT(battfs_umount(disk));
92 }
93
94 static void diskNew(BattFsSuper *disk)
95 {
96         pgcnt_t ref[PAGE_COUNT];
97
98         TRACEMSG("1: disk new\n");
99
100         FILE *fpt = fopen(test_filename, "w+");
101
102         for (int i = 0; i < FILE_SIZE; i++)
103                 fputc(0xff, fpt);
104
105         for (int i = 0; i < PAGE_COUNT; i++)
106                 ref[i] = i;
107
108         KBlockFile f;
109         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
110         battfs_mount(disk, &f.b, page_array, sizeof(page_array));
111
112         testCheck(disk, ref);
113         TRACEMSG("1: passed\n");
114 }
115
116 static void disk1File(BattFsSuper *disk)
117 {
118         pgcnt_t ref[PAGE_COUNT];
119         TRACEMSG("2: disk full with 1 contiguos file\n");
120
121         FILE *fp = fopen(test_filename, "w+");
122         for (int i = 0; i < FILE_SIZE; i++)
123                 fputc(0xff, fp);
124
125         KBlockFile f;
126         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, PAGE_COUNT);
127
128         for (int i = 0; i < PAGE_COUNT; i++)
129         {
130                 battfs_writeTestBlock(&f.b, i, 0, 0, DATA_SIZE, i);
131                 ref[i] = i;
132         }
133
134         battfs_mount(disk, &f.b, page_array, sizeof(page_array));
135
136         testCheck(disk, ref);
137         TRACEMSG("2: passed\n");
138 }
139
140
141 static void diskHalfFile(BattFsSuper *disk)
142 {
143         pgcnt_t ref[PAGE_COUNT];
144         TRACEMSG("3: disk half full with 1 contiguos file, rest unformatted\n");
145
146
147         FILE *fp = fopen(test_filename, "w+");
148         for (int i = 0; i < FILE_SIZE; i++)
149                 fputc(0xff, fp);
150
151         KBlockFile f;
152         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, PAGE_COUNT);
153
154         for (int i = 0; i < PAGE_COUNT / 2; i++)
155         {
156                 battfs_writeTestBlock(&f.b, i, 0, 0, DATA_SIZE, i);
157                 ref[i] = i;
158         }
159         fseek(fp, FILE_SIZE / 2, SEEK_SET);
160         for (int i = FILE_SIZE / 2; i < FILE_SIZE; i++)
161                 fputc(0xff, fp);
162
163         for (int i = PAGE_COUNT / 2; i < PAGE_COUNT; i++)
164         {
165                 ref[i] = i;
166         }
167
168         battfs_mount(disk, &f.b, page_array, sizeof(page_array));
169
170         testCheck(disk, ref);
171         TRACEMSG("3: passed\n");
172 }
173
174
175 static void oldSeq1(BattFsSuper *disk)
176 {
177         pgcnt_t ref[4];
178         TRACEMSG("6: 1 file with 1 old seq num, 1 free block\n");
179
180         FILE *fp = fopen(test_filename, "w+");
181         for (int i = 0; i < PAGE_SIZE * 4; i++)
182                 fputc(0xff, fp);
183         KBlockFile f;
184         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 4);
185
186         // page, inode, seq, fill, pgoff
187         battfs_writeTestBlock(&f.b, 0, 0, 0, DATA_SIZE, 0);
188         battfs_writeTestBlock(&f.b, 1, 0, 0, DATA_SIZE, 1);
189         battfs_writeTestBlock(&f.b, 2, 0, 1, DATA_SIZE, 1);
190         battfs_eraseBlock(&f.b, 3);
191
192         ref[0] = 0;
193         ref[1] = 2;
194         ref[2] = 1;
195         ref[3] = 3;
196
197         battfs_mount(disk, &f.b, page_array, sizeof(page_array));
198
199         testCheck(disk, ref);
200         TRACEMSG("6: passed\n");
201 }
202
203 static void oldSeq2(BattFsSuper *disk)
204 {
205         pgcnt_t ref[4];
206         TRACEMSG("7: 1 file with 1 old seq num, 1 free block\n");
207
208         FILE *fp = fopen(test_filename, "w+");
209         for (int i = 0; i < PAGE_SIZE * 4; i++)
210                 fputc(0xff, fp);
211         KBlockFile f;
212         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 4);
213
214         // page, inode, seq, fill, pgoff
215         battfs_writeTestBlock(&f.b, 0, 0, 0, DATA_SIZE, 0);
216         battfs_writeTestBlock(&f.b, 1, 0, 1, DATA_SIZE, 1);
217         battfs_writeTestBlock(&f.b, 2, 0, 0, DATA_SIZE, 1);
218         battfs_eraseBlock(&f.b, 3);
219
220         ref[0] = 0;
221         ref[1] = 1;
222         ref[2] = 2;
223         ref[3] = 3;
224
225         battfs_mount(disk, &f.b, page_array, sizeof(page_array));
226         testCheck(disk, ref);
227         TRACEMSG("7: passed\n");
228 }
229
230 static void oldSeq3(BattFsSuper *disk)
231 {
232         pgcnt_t ref[4];
233         TRACEMSG("8: 1 file with 1 old seq num, 1 free block\n");
234
235
236         FILE *fp = fopen(test_filename, "w+");
237         for (int i = 0; i < PAGE_SIZE * 4; i++)
238                 fputc(0xff, fp);
239         KBlockFile f;
240         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 4);
241
242         // page, inode, seq, fill, pgoff
243         battfs_eraseBlock(&f.b, 0);
244         battfs_writeTestBlock(&f.b, 1, 0, 0, DATA_SIZE, 0);
245         battfs_writeTestBlock(&f.b, 2, 0, 1, DATA_SIZE, 1);
246         battfs_writeTestBlock(&f.b, 3, 0, 0, DATA_SIZE, 1);
247
248         ref[0] = 1;
249         ref[1] = 2;
250         ref[2] = 0;
251         ref[3] = 3;
252
253         battfs_mount(disk, &f.b, page_array, sizeof(page_array));
254         testCheck(disk, ref);
255         TRACEMSG("8: passed\n");
256 }
257
258 static void oldSeq2File(BattFsSuper *disk)
259 {
260         pgcnt_t ref[8];
261         TRACEMSG("9: 2 file with old seq num, 2 free block\n");
262
263
264         FILE *fp = fopen(test_filename, "w+");
265         for (int i = 0; i < PAGE_SIZE * 8; i++)
266                 fputc(0xff, fp);
267         KBlockFile f;
268         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 8);
269
270         // page, inode, seq, fill, pgoff
271         battfs_eraseBlock(&f.b, 0);
272         battfs_writeTestBlock(&f.b, 1, 0, 0, DATA_SIZE, 0);
273         battfs_writeTestBlock(&f.b, 2, 0, 3, DATA_SIZE, 1);
274         battfs_writeTestBlock(&f.b, 3, 0, 0, DATA_SIZE, 1);
275         battfs_eraseBlock(&f.b, 4);
276         battfs_writeTestBlock(&f.b, 5, 4, 0, DATA_SIZE, 0);
277         battfs_writeTestBlock(&f.b, 6, 4, 1, DATA_SIZE, 1);
278         battfs_writeTestBlock(&f.b, 7, 4, 0, DATA_SIZE, 1);
279
280
281         ref[0] = 1;
282         ref[1] = 2;
283         ref[2] = 5;
284         ref[3] = 6;
285         ref[4] = 0;
286         ref[5] = 3;
287         ref[6] = 4;
288         ref[7] = 7;
289
290         battfs_mount(disk, &f.b, page_array, sizeof(page_array));
291         testCheck(disk, ref);
292         TRACEMSG("9: passed\n");
293 }
294
295 static void openFile(BattFsSuper *disk)
296 {
297         BattFs fd1;
298         BattFs fd2;
299         TRACEMSG("10: open file test, inode 0 and inode 4\n");
300
301         FILE *fp = fopen(test_filename, "w+");
302         for (int i = 0; i < PAGE_SIZE * 8; i++)
303                 fputc(0xff, fp);
304         KBlockFile f;
305         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 8);
306
307
308         int PAGE_FILL = PAGE_SIZE - BATTFS_HEADER_LEN;
309         inode_t INODE = 0;
310         inode_t INODE2 = 4;
311         inode_t INEXISTENT_INODE = 123;
312         unsigned int MODE = 0;
313
314         // page, inode, seq, fill, pgoff
315         battfs_eraseBlock(&f.b, 0);
316         battfs_writeTestBlock(&f.b, 1, INODE, 0, PAGE_FILL, 0);
317         battfs_writeTestBlock(&f.b, 2, INODE, 3, PAGE_FILL, 1);
318         battfs_writeTestBlock(&f.b, 3, INODE, 0, PAGE_FILL, 1);
319         battfs_eraseBlock(&f.b, 4);
320         battfs_writeTestBlock(&f.b, 5, INODE2, 0, PAGE_FILL, 0);
321         battfs_writeTestBlock(&f.b, 6, INODE2, 1, PAGE_FILL, 1);
322         battfs_writeTestBlock(&f.b, 7, INODE2, 0, PAGE_FILL, 1);
323
324         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
325         ASSERT(battfs_fsck(disk));
326         ASSERT(!battfs_fileExists(disk, INEXISTENT_INODE));
327
328         ASSERT(battfs_fileExists(disk, INODE));
329         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
330         ASSERT(fd1.fd.size == PAGE_FILL * 2);
331         ASSERT(fd1.fd.seek_pos == 0);
332         ASSERT(fd1.mode == MODE);
333         ASSERT(fd1.inode == INODE);
334         ASSERT(fd1.start == &disk->page_array[0]);
335         ASSERT(fd1.disk == disk);
336         ASSERT(LIST_HEAD(&disk->file_opened_list) == &fd1.link);
337
338         ASSERT(kfile_reopen(&fd1.fd) == &fd1.fd);
339         ASSERT(fd1.fd.size == PAGE_FILL * 2);
340         ASSERT(fd1.fd.seek_pos == 0);
341         ASSERT(fd1.mode == MODE);
342         ASSERT(fd1.inode == INODE);
343         ASSERT(fd1.start == &disk->page_array[0]);
344         ASSERT(fd1.disk == disk);
345         ASSERT(LIST_HEAD(&disk->file_opened_list) == &fd1.link);
346
347         ASSERT(battfs_fileExists(disk, INODE2));
348         ASSERT(battfs_fileopen(disk, &fd2, INODE2, MODE));
349         ASSERT(fd2.fd.size == PAGE_FILL * 2);
350         ASSERT(fd2.fd.seek_pos == 0);
351         ASSERT(fd2.mode == MODE);
352         ASSERT(fd2.inode == INODE2);
353         ASSERT(fd2.start == &disk->page_array[2]);
354         ASSERT(fd2.disk == disk);
355         ASSERT(LIST_HEAD(&disk->file_opened_list)->succ == &fd2.link);
356
357         ASSERT(kfile_close(&fd1.fd) == 0);
358         ASSERT(kfile_error(&fd1.fd) == 0);
359         ASSERT(kfile_close(&fd2.fd) == 0);
360         ASSERT(kfile_error(&fd2.fd) == 0);
361         ASSERT(LIST_EMPTY(&disk->file_opened_list));
362         ASSERT(battfs_fsck(disk));
363         ASSERT(battfs_umount(disk));
364
365         TRACEMSG("10: passed\n");
366 }
367
368 static void readFile(BattFsSuper *disk)
369 {
370         BattFs fd1;
371         uint8_t buf[16];
372
373         TRACEMSG("11: read file test\n");
374
375         FILE *fp = fopen(test_filename, "w+");
376         for (int i = 0; i < PAGE_SIZE * 8; i++)
377                 fputc(0xff, fp);
378         KBlockFile f;
379         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 8);
380
381
382         unsigned int PAGE_FILL = PAGE_SIZE - BATTFS_HEADER_LEN;
383         inode_t INODE = 0;
384         inode_t INODE2 = 4;
385         unsigned int MODE = 0;
386
387         battfs_eraseBlock(&f.b, 0);
388         battfs_writeTestBlock(&f.b, 1, INODE, 0, PAGE_FILL, 0);
389         battfs_writeTestBlock(&f.b, 2, INODE, 3, PAGE_FILL, 1);
390         battfs_writeTestBlock(&f.b, 3, INODE, 0, PAGE_FILL, 1);
391         battfs_eraseBlock(&f.b, 4);
392         battfs_writeTestBlock(&f.b, 5, INODE2, 0, PAGE_FILL, 0);
393         battfs_writeTestBlock(&f.b, 6, INODE2, 1, PAGE_FILL, 1);
394         battfs_writeTestBlock(&f.b, 7, INODE2, 0, PAGE_FILL, 1);
395
396         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
397         ASSERT(battfs_fsck(disk));
398         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
399         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
400         ASSERT(fd1.fd.seek_pos == sizeof(buf));
401         for (size_t i = 0; i < sizeof(buf); i++)
402                 ASSERT(buf[i] == 0xff);
403
404         ASSERT(kfile_close(&fd1.fd) == 0);
405         ASSERT(kfile_error(&fd1.fd) == 0);
406         ASSERT(battfs_fsck(disk));
407         ASSERT(battfs_umount(disk));
408
409         TRACEMSG("11: passed\n");
410 }
411
412 static void readAcross(BattFsSuper *disk)
413 {
414         BattFs fd1;
415
416         TRACEMSG("12: read file test across page boundary and seek test\n");
417
418         FILE *fp = fopen(test_filename, "w+");
419         for (int i = 0; i < PAGE_SIZE * 8; i++)
420                 fputc(0xff, fp);
421         KBlockFile f;
422         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 8);
423
424         const unsigned int PAGE_FILL = PAGE_SIZE - BATTFS_HEADER_LEN;
425         inode_t INODE = 0;
426         unsigned int MODE = 0;
427         uint8_t buf[PAGE_FILL + BATTFS_HEADER_LEN / 2];
428
429         battfs_eraseBlock(&f.b, 0);
430         battfs_writeTestBlock(&f.b, 1, INODE, 0, PAGE_FILL, 0);
431         battfs_writeTestBlock(&f.b, 2, INODE, 3, PAGE_FILL, 1);
432         battfs_writeTestBlock(&f.b, 3, INODE, 0, PAGE_FILL, 1);
433         battfs_eraseBlock(&f.b, 4);
434         battfs_writeTestBlock(&f.b, 5, INODE, 0, PAGE_FILL, 2);
435         battfs_writeTestBlock(&f.b, 6, INODE, 1, PAGE_FILL, 3);
436         battfs_writeTestBlock(&f.b, 7, INODE, 0, PAGE_FILL, 3);
437
438         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
439         ASSERT(battfs_fsck(disk));
440         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
441
442         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
443         ASSERT(fd1.fd.seek_pos == (kfile_off_t)sizeof(buf));
444         for (size_t i = 0; i < sizeof(buf); i++)
445                 ASSERT(buf[i] == 0xff);
446
447         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
448         ASSERT(fd1.fd.seek_pos == (kfile_off_t)sizeof(buf) * 2);
449         for (size_t i = 0; i < sizeof(buf); i++)
450                 ASSERT(buf[i] == 0xff);
451
452         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
453         ASSERT(fd1.fd.seek_pos == (kfile_off_t)sizeof(buf) * 3);
454         for (size_t i = 0; i < sizeof(buf); i++)
455                 ASSERT(buf[i] == 0xff);
456
457         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == PAGE_FILL * 4 - sizeof(buf) * 3);
458         ASSERT(fd1.fd.seek_pos == (kfile_off_t)fd1.fd.size);
459         for (size_t i = 0; i < PAGE_FILL * 4 - sizeof(buf) * 3; i++)
460                 ASSERT(buf[i] == 0xff);
461
462         ASSERT(kfile_seek(&fd1.fd, 0, KSM_SEEK_SET) == 0);
463         ASSERT(fd1.fd.seek_pos == 0);
464
465         ASSERT(kfile_seek(&fd1.fd, 0, KSM_SEEK_END) == (kfile_off_t)fd1.fd.size);
466         ASSERT(fd1.fd.seek_pos = (kfile_off_t)fd1.fd.size);
467
468         ASSERT(kfile_close(&fd1.fd) == 0);
469         ASSERT(kfile_error(&fd1.fd) == 0);
470         ASSERT(battfs_fsck(disk));
471         ASSERT(battfs_umount(disk));
472
473         TRACEMSG("12: passed\n");
474 }
475
476
477 static void writeFile(BattFsSuper *disk)
478 {
479         BattFs fd1;
480         uint8_t buf[PAGE_SIZE - BATTFS_HEADER_LEN];
481
482         TRACEMSG("13: write file test\n");
483
484         FILE *fp = fopen(test_filename, "w+");
485         for (int i = 0; i < PAGE_SIZE * 8; i++)
486                 fputc(0xff, fp);
487         KBlockFile f;
488         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 8);
489
490
491         unsigned int PAGE_FILL = PAGE_SIZE - BATTFS_HEADER_LEN;
492         inode_t INODE = 0;
493         inode_t INODE2 = 4;
494         unsigned int MODE = 0;
495
496         battfs_eraseBlock(&f.b, 0);
497         battfs_writeTestBlock(&f.b, 1, INODE, 0, PAGE_FILL, 0);
498         battfs_writeTestBlock(&f.b, 2, INODE, 3, PAGE_FILL, 1);
499         battfs_writeTestBlock(&f.b, 3, INODE, 0, PAGE_FILL, 1);
500         battfs_eraseBlock(&f.b, 4);
501         battfs_writeTestBlock(&f.b, 5, INODE2, 0, PAGE_FILL, 0);
502         battfs_writeTestBlock(&f.b, 6, INODE2, 1, PAGE_FILL, 1);
503         battfs_writeTestBlock(&f.b, 7, INODE2, 0, PAGE_FILL, 1);
504
505         for (size_t i = 0; i < sizeof(buf); i++)
506                 buf[i] = i;
507
508         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
509         ASSERT(battfs_fsck(disk));
510         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
511         ASSERT(kfile_write(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
512         ASSERT(fd1.fd.seek_pos == sizeof(buf));
513         ASSERT(kfile_seek(&fd1.fd, 0, KSM_SEEK_SET) == 0);
514         ASSERT(fd1.fd.seek_pos == 0);
515
516         memset(buf, 0, sizeof(buf));
517         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
518         for (size_t i = 0; i < sizeof(buf); i++)
519                 ASSERT(buf[i] == i);
520
521         ASSERT(kfile_close(&fd1.fd) == 0);
522         ASSERT(kfile_error(&fd1.fd) == 0);
523         ASSERT(battfs_fsck(disk));
524         ASSERT(battfs_umount(disk));
525
526         TRACEMSG("13: passed\n");
527 }
528
529 static void writeAcross(BattFsSuper *disk)
530 {
531         BattFs fd1;
532
533         TRACEMSG("14: write file test across page boundary and seek test\n");
534
535         FILE *fp = fopen(test_filename, "w+");
536         for (int i = 0; i < PAGE_SIZE * 8; i++)
537                 fputc(0xff, fp);
538         KBlockFile f;
539         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 8);
540
541         const unsigned int PAGE_FILL = PAGE_SIZE - BATTFS_HEADER_LEN;
542         inode_t INODE = 0;
543         unsigned int MODE = 0;
544         uint8_t buf[PAGE_FILL + BATTFS_HEADER_LEN / 2];
545
546         battfs_eraseBlock(&f.b, 0);
547         battfs_writeTestBlock(&f.b, 1, INODE, 0, PAGE_FILL, 0);
548         battfs_writeTestBlock(&f.b, 2, INODE, 3, PAGE_FILL, 1);
549         battfs_writeTestBlock(&f.b, 3, INODE, 0, PAGE_FILL, 1);
550         battfs_eraseBlock(&f.b, 4);
551         battfs_writeTestBlock(&f.b, 5, INODE, 0, PAGE_FILL, 2);
552         battfs_writeTestBlock(&f.b, 6, INODE, 1, PAGE_FILL, 3);
553         battfs_writeTestBlock(&f.b, 7, INODE, 0, PAGE_FILL, 3);
554
555         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
556         ASSERT(battfs_fsck(disk));
557         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
558
559         uint8_t val = 0;
560         for (size_t i = 0; i < sizeof(buf); i++)
561                 buf[i] = val++;
562         ASSERT(kfile_write(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
563         ASSERT(fd1.fd.seek_pos == (kfile_off_t)sizeof(buf));
564
565         for (size_t i = 0; i < sizeof(buf); i++)
566                 buf[i] = val++;
567         ASSERT(kfile_write(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
568         ASSERT(fd1.fd.seek_pos == (kfile_off_t)sizeof(buf) * 2);
569
570         for (size_t i = 0; i < sizeof(buf); i++)
571                 buf[i] = val++;
572         ASSERT(kfile_write(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
573         ASSERT(fd1.fd.seek_pos == (kfile_off_t)sizeof(buf) * 3);
574
575         ASSERT(kfile_seek(&fd1.fd, 0, KSM_SEEK_SET) == 0);
576         ASSERT(fd1.fd.seek_pos == 0);
577         val = 0;
578
579         memset(buf, 0, sizeof(buf));
580         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
581         for (size_t i = 0; i < sizeof(buf); i++)
582                 ASSERT(buf[i] == val++);
583
584         memset(buf, 0, sizeof(buf));
585         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
586         for (size_t i = 0; i < sizeof(buf); i++)
587                 ASSERT(buf[i] == val++);
588
589         memset(buf, 0, sizeof(buf));
590         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
591         for (size_t i = 0; i < sizeof(buf); i++)
592                 ASSERT(buf[i] == val++);
593
594         ASSERT(fd1.fd.seek_pos == (kfile_off_t)sizeof(buf) * 3);
595
596         ASSERT(kfile_close(&fd1.fd) == 0);
597         ASSERT(kfile_error(&fd1.fd) == 0);
598         ASSERT(battfs_fsck(disk));
599         ASSERT(battfs_umount(disk));
600
601         TRACEMSG("14: passed\n");
602 }
603
604 static void createFile(BattFsSuper *disk)
605 {
606         TRACEMSG("15: file creation on new disk\n");
607
608         FILE *fpt = fopen(test_filename, "w+");
609         for (int i = 0; i < FILE_SIZE; i++)
610                 fputc(0xff, fpt);
611         KBlockFile f;
612         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
613
614         BattFs fd1;
615         inode_t INODE = 0;
616         unsigned int MODE = BATTFS_CREATE;
617
618         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
619         ASSERT(battfs_fsck(disk));
620         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
621         for (int i = 0; i < FILE_SIZE / 2; i++)
622                 ASSERT(kfile_putc(i, &fd1.fd) != EOF);
623
624         ASSERT(fd1.fd.seek_pos == FILE_SIZE / 2);
625         ASSERT(fd1.fd.size == FILE_SIZE / 2);
626         ASSERT(kfile_close(&fd1.fd) == 0);
627         ASSERT(kfile_error(&fd1.fd) == 0);
628         ASSERT(battfs_fsck(disk));
629         ASSERT(battfs_umount(disk));
630
631         fpt = fopen(test_filename, "r+");
632         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
633
634         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
635         ASSERT(battfs_fsck(disk));
636         ASSERT(battfs_fileopen(disk, &fd1, INODE, 0));
637         ASSERT(fd1.fd.size == FILE_SIZE / 2);
638         ASSERT(fd1.fd.seek_pos == 0);
639
640         uint8_t buf[FILE_SIZE / 2];
641         memset(buf, 0, sizeof(buf));
642         ASSERT(kfile_read(&fd1.fd, buf, FILE_SIZE / 2) == FILE_SIZE / 2);
643
644         for (int i = 0; i < FILE_SIZE / 2; i++)
645                 ASSERT(buf[i] == (i & 0xff));
646
647         ASSERT(fd1.fd.seek_pos == FILE_SIZE / 2);
648         ASSERT(kfile_close(&fd1.fd) == 0);
649         ASSERT(kfile_error(&fd1.fd) == 0);
650         ASSERT(battfs_fsck(disk));
651         ASSERT(battfs_umount(disk));
652
653
654         TRACEMSG("15: passed\n");
655 }
656
657 static void multipleWrite(BattFsSuper *disk)
658 {
659         TRACEMSG("16: multiple write on file\n");
660
661         FILE *fpt = fopen(test_filename, "w+");
662         for (int i = 0; i < FILE_SIZE; i++)
663                 fputc(0xff, fpt);
664         KBlockFile f;
665         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
666
667
668         BattFs fd1;
669         inode_t INODE = 0;
670         unsigned int MODE = BATTFS_CREATE;
671         uint8_t buf[1000];
672
673         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
674         ASSERT(battfs_fsck(disk));
675         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
676
677         int j;
678         for (j = 1; j < 1013; j++)
679         {
680                 for (unsigned i = 0; i < sizeof(buf); i++)
681                         buf[i] = j+i;
682
683                 ASSERT(kfile_write(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
684                 ASSERT(fd1.fd.seek_pos == sizeof(buf));
685                 ASSERT(fd1.fd.size == sizeof(buf));
686                 ASSERT(kfile_seek(&fd1.fd, 0, KSM_SEEK_SET) == 0);
687                 memset(buf, 0, sizeof(buf));
688                 ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
689                 ASSERT(fd1.fd.seek_pos == sizeof(buf));
690                 for (unsigned i = 0; i < sizeof(buf); i++)
691                         ASSERT(buf[i] == ((j+i) & 0xff));
692                 ASSERT(kfile_seek(&fd1.fd, 0, KSM_SEEK_SET) == 0);
693                 ASSERT(disk->free_bytes == disk->disk_size - sizeof(buf));
694         }
695         ASSERT(kfile_close(&fd1.fd) == 0);
696         ASSERT(kfile_error(&fd1.fd) == 0);
697         ASSERT(battfs_fsck(disk));
698         ASSERT(battfs_umount(disk));
699
700         fpt = fopen(test_filename, "r+");
701         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
702
703         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
704         ASSERT(battfs_fsck(disk));
705         ASSERT(disk->free_bytes == disk->disk_size - sizeof(buf));
706         ASSERT(battfs_fileopen(disk, &fd1, INODE, 0));
707         ASSERT(fd1.fd.size == sizeof(buf));
708         memset(buf, 0, sizeof(buf));
709         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
710         for (unsigned i = 0; i < sizeof(buf); i++)
711                         ASSERT(buf[i] == ((j-1+i) & 0xff));
712         ASSERT(kfile_close(&fd1.fd) == 0);
713         ASSERT(kfile_error(&fd1.fd) == 0);
714         ASSERT(battfs_fsck(disk));
715         ASSERT(battfs_umount(disk));
716
717
718         TRACEMSG("16: passed\n");
719 }
720
721 static void increaseFile(BattFsSuper *disk)
722 {
723         TRACEMSG("17: increasing dimension of a file with multiple open files.\n");
724
725         FILE *fpt = fopen(test_filename, "w+");
726         for (int i = 0; i < FILE_SIZE / 10; i++)
727                 fputc(0xff, fpt);
728
729         KBlockFile f;
730         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT / 10);
731
732
733         BattFs fd1,fd2;
734         inode_t INODE1 = 1, INODE2 = 2;
735         unsigned int MODE = BATTFS_CREATE;
736         uint8_t buf[1000];
737
738         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
739         ASSERT(battfs_fsck(disk));
740         ASSERT(battfs_fileopen(disk, &fd1, INODE1, MODE));
741         ASSERT(battfs_fileopen(disk, &fd2, INODE2, MODE));
742         for (unsigned i = 0; i < sizeof(buf); i++)
743                 ASSERT(kfile_putc(i, &fd2.fd) != EOF);
744         ASSERT(kfile_seek(&fd2.fd, 0, KSM_SEEK_SET) == 0);
745         memset(buf, 0, sizeof(buf));
746         ASSERT(kfile_read(&fd2.fd, buf, sizeof(buf)) == sizeof(buf));
747
748         for (unsigned i = 0; i < sizeof(buf); i++)
749                 ASSERT(buf[i] == (i & 0xff));
750         ASSERT(kfile_seek(&fd2.fd, 0, KSM_SEEK_SET) == 0);
751
752         for (unsigned i = 0; i < sizeof(buf); i++)
753                 ASSERT(kfile_putc(i, &fd1.fd) != EOF);
754
755         memset(buf, 0, sizeof(buf));
756         ASSERT(kfile_read(&fd2.fd, buf, sizeof(buf)) == sizeof(buf));
757
758         for (unsigned i = 0; i < sizeof(buf); i++)
759                 ASSERT(buf[i] == (i & 0xff));
760
761         ASSERT(kfile_close(&fd1.fd) == 0);
762         ASSERT(kfile_error(&fd1.fd) == 0);
763         ASSERT(kfile_close(&fd2.fd) == 0);
764         ASSERT(kfile_error(&fd2.fd) == 0);
765         ASSERT(battfs_fsck(disk));
766         ASSERT(battfs_umount(disk));
767
768         TRACEMSG("17: passed\n");
769 }
770
771 static void readEOF(BattFsSuper *disk)
772 {
773         BattFs fd1;
774         uint8_t buf[16];
775
776         TRACEMSG("18: reading over EOF test\n");
777
778         FILE *fp = fopen(test_filename, "w+");
779         for (int i = 0; i < PAGE_SIZE * 8; i++)
780                 fputc(0xff, fp);
781         KBlockFile f;
782         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 8);
783
784
785         unsigned int PAGE_FILL = PAGE_SIZE - BATTFS_HEADER_LEN;
786         inode_t INODE = 0;
787         inode_t INODE2 = 4;
788         unsigned int MODE = 0;
789
790         battfs_eraseBlock(&f.b, 0);
791         battfs_writeTestBlock(&f.b, 1, INODE, 0, PAGE_FILL, 0);
792         battfs_writeTestBlock(&f.b, 2, INODE, 3, PAGE_FILL, 1);
793         battfs_writeTestBlock(&f.b, 3, INODE, 0, PAGE_FILL, 1);
794         battfs_eraseBlock(&f.b, 4);
795         battfs_writeTestBlock(&f.b, 5, INODE2, 0, PAGE_FILL, 0);
796         battfs_writeTestBlock(&f.b, 6, INODE2, 1, PAGE_FILL, 1);
797         battfs_writeTestBlock(&f.b, 7, INODE2, 0, PAGE_FILL, 1);
798
799         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
800         ASSERT(battfs_fsck(disk));
801         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
802         ASSERT(kfile_seek(&fd1.fd, fd1.fd.size + 10, SEEK_SET) == fd1.fd.size + 10);
803         ASSERT(fd1.fd.seek_pos == fd1.fd.size + 10);
804         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == 0);
805
806         ASSERT(kfile_close(&fd1.fd) == 0);
807         ASSERT(kfile_error(&fd1.fd) == 0);
808         ASSERT(battfs_fsck(disk));
809         ASSERT(battfs_umount(disk));
810
811         TRACEMSG("18: passed\n");
812 }
813
814 static void writeEOF(BattFsSuper *disk)
815 {
816         TRACEMSG("19: writing over EOF test\n");
817
818         FILE *fpt = fopen(test_filename, "w+");
819         for (int i = 0; i < FILE_SIZE / 5; i++)
820                 fputc(0xff, fpt);
821         KBlockFile f;
822         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT / 5);
823
824         BattFs fd1;
825         inode_t INODE = 0;
826         unsigned int MODE = BATTFS_CREATE;
827         uint8_t buf[FILE_SIZE / 13];
828
829         for (int i = 0; i < 2; i++)
830                 buf[i] = i;
831
832         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
833         ASSERT(battfs_fsck(disk));
834         disk_size_t prev_free = disk->free_bytes;
835         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
836         ASSERT(fd1.fd.size == 0);
837
838         ASSERT(kfile_seek(&fd1.fd, 2, KSM_SEEK_END) == 2);
839         ASSERT(kfile_write(&fd1.fd, buf, 2));
840         ASSERT(fd1.fd.seek_pos == 4);
841         ASSERT(fd1.fd.size == 4);
842         ASSERT(disk->free_bytes == prev_free - 4);
843         ASSERT(kfile_seek(&fd1.fd, 0, KSM_SEEK_SET) == 0);
844         memset(buf, 0, 2);
845         ASSERT(kfile_read(&fd1.fd, buf, 2) == 2);
846         for (int i = 0; i < 2; i++)
847                 ASSERT(buf[i] == 0);
848
849         memset(buf, 0, 2);
850         ASSERT(kfile_read(&fd1.fd, buf, 2) == 2);
851         for (int i = 0; i < 2; i++)
852                 ASSERT(buf[i] == (i & 0xff));
853
854         ASSERT(kfile_seek(&fd1.fd, sizeof(buf), KSM_SEEK_END) == sizeof(buf) + 4);
855         for (unsigned i = 0; i < sizeof(buf); i++)
856                 buf[i] = i;
857         ASSERT(kfile_write(&fd1.fd, buf, sizeof(buf)));
858         ASSERT(fd1.fd.seek_pos == sizeof(buf) * 2 + 4);
859         ASSERT(fd1.fd.size == sizeof(buf) * 2 + 4);
860         ASSERT(disk->free_bytes == prev_free - sizeof(buf) * 2 - 4);
861
862         ASSERT(kfile_seek(&fd1.fd, 0, KSM_SEEK_SET) == 0);
863
864         memset(buf, 0, 2);
865         ASSERT(kfile_read(&fd1.fd, buf, 2) == 2);
866         ASSERT(fd1.fd.seek_pos == 2);
867         for (int i = 0; i < 2; i++)
868                 ASSERT(buf[i] == 0);
869
870         memset(buf, 0, 2);
871         ASSERT(kfile_read(&fd1.fd, buf, 2) == 2);
872         ASSERT(fd1.fd.seek_pos == 4);
873         for (int i = 0; i < 2; i++)
874                 ASSERT(buf[i] == (i & 0xff));
875
876         memset(buf, 0, 4);
877         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
878         ASSERT(fd1.fd.seek_pos == sizeof(buf) + 4);
879         for (unsigned i = 0; i < sizeof(buf); i++)
880                 ASSERT(buf[i] == 0);
881
882         memset(buf, 0, sizeof(buf));
883         ASSERT(kfile_read(&fd1.fd, buf, sizeof(buf)) == sizeof(buf));
884         for (unsigned i = 0; i < sizeof(buf); i++)
885                 ASSERT(buf[i] == (i & 0xff));
886
887         ASSERT(kfile_close(&fd1.fd) == 0);
888         ASSERT(kfile_error(&fd1.fd) == 0);
889         ASSERT(battfs_fsck(disk));
890         ASSERT(battfs_umount(disk));
891
892         TRACEMSG("19: passed\n");
893
894 }
895
896 static void endOfSpace(BattFsSuper *disk)
897 {
898         TRACEMSG("20: what happens when disk space is over?\n");
899         BattFs fd1;
900         uint8_t buf[(PAGE_SIZE - BATTFS_HEADER_LEN) * 5];
901
902         FILE *fp = fopen(test_filename, "w+");
903         for (int i = 0; i < PAGE_SIZE * 4; i++)
904                 fputc(0xff, fp);
905         KBlockFile f;
906         kblockfile_init(&f, fp, page_buffer, PAGE_SIZE, 4);
907
908         unsigned int PAGE_FILL = PAGE_SIZE - BATTFS_HEADER_LEN;
909         inode_t INODE = 0;
910         unsigned int MODE = BATTFS_CREATE;
911
912         battfs_eraseBlock(&f.b, 0);
913         battfs_eraseBlock(&f.b, 1);
914         battfs_eraseBlock(&f.b, 2);
915         battfs_eraseBlock(&f.b, 3);
916
917         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
918         ASSERT(battfs_fsck(disk));
919         ASSERT(battfs_fileopen(disk, &fd1, INODE, MODE));
920         ASSERT(kfile_write(&fd1.fd, buf, sizeof(buf)) == PAGE_FILL * 4);
921         ASSERT(fd1.fd.size == (kfile_off_t)(PAGE_FILL * 4));
922         ASSERT(fd1.fd.seek_pos == (kfile_off_t)(PAGE_FILL * 4));
923         ASSERT(disk->free_bytes == 0);
924
925         ASSERT(kfile_close(&fd1.fd) == 0);
926         ASSERT(kfile_error(&fd1.fd) == BATTFS_DISK_SPACEOVER_ERR);
927         ASSERT(battfs_fsck(disk));
928         ASSERT(battfs_umount(disk));
929
930         TRACEMSG("20: passed\n");
931 }
932
933
934 static void multipleFilesRW(BattFsSuper *disk)
935 {
936         TRACEMSG("21: multiple files read/write test\n");
937
938         FILE *fpt = fopen(test_filename, "w+");
939         for (int i = 0; i < FILE_SIZE; i++)
940                 fputc(0xff, fpt);
941         KBlockFile f;
942         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
943
944         #define N_FILES 10
945         BattFs fd[N_FILES];
946         unsigned int MODE = BATTFS_CREATE;
947         uint32_t buf[FILE_SIZE / (4 * N_FILES * sizeof(uint32_t))];
948
949         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
950         ASSERT(battfs_fsck(disk));
951         for (inode_t i = 0; i < N_FILES; i++)
952                 ASSERT(battfs_fileopen(disk, &fd[i], i, MODE));
953
954         for (int i = N_FILES - 1; i >= 0; i--)
955         {
956                 for (uint32_t j = 0; j < countof(buf); j++)
957                         buf[j] = j+i;
958
959                 ASSERT(kfile_write(&fd[i].fd, buf, sizeof(buf)) == sizeof(buf));
960                 ASSERT(fd[i].fd.size == sizeof(buf));
961                 ASSERT(fd[i].fd.seek_pos == sizeof(buf));
962                 ASSERT(kfile_seek(&fd[i].fd, 0, SEEK_SET) == 0);
963         }
964
965         for (inode_t i = 0; i < N_FILES; i++)
966         {
967                 memset(buf, 0, sizeof(buf));
968                 ASSERT(kfile_read(&fd[i].fd, buf, sizeof(buf)) == sizeof(buf));
969
970                 for (uint32_t j = 0; j < countof(buf); j++)
971                         ASSERT(buf[j] == j+i);
972
973                 ASSERT(fd[i].fd.size == sizeof(buf));
974                 ASSERT(fd[i].fd.seek_pos == sizeof(buf));
975                 ASSERT(kfile_seek(&fd[i].fd, 0, SEEK_SET) == 0);
976         }
977
978         for (inode_t i = 0; i < N_FILES; i++)
979         {
980                 ASSERT(kfile_close(&fd[i].fd) == 0);
981                 ASSERT(kfile_error(&fd[i].fd) == 0);
982         }
983
984         ASSERT(battfs_fsck(disk));
985         ASSERT(battfs_umount(disk));
986
987         fpt = fopen(test_filename, "r+");
988         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
989
990         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
991         ASSERT(battfs_fsck(disk));
992
993         for (inode_t i = 0; i < N_FILES; i++)
994                 ASSERT(battfs_fileopen(disk, &fd[i], i, 0));
995
996         for (inode_t i = 0; i < N_FILES; i++)
997         {
998                 memset(buf, 0, sizeof(buf));
999                 ASSERT(kfile_read(&fd[i].fd, buf, sizeof(buf)) == sizeof(buf));
1000
1001                 for (uint32_t j = 0; j < countof(buf); j++)
1002                         ASSERT(buf[j] == j+i);
1003
1004                 ASSERT(fd[i].fd.size == sizeof(buf));
1005                 ASSERT(fd[i].fd.seek_pos == sizeof(buf));
1006                 ASSERT(kfile_seek(&fd[i].fd, 0, SEEK_SET) == 0);
1007         }
1008
1009         for (inode_t i = 0; i < N_FILES; i++)
1010         {
1011                 ASSERT(kfile_close(&fd[i].fd) == 0);
1012                 ASSERT(kfile_error(&fd[i].fd) == 0);
1013         }
1014
1015         ASSERT(battfs_umount(disk));
1016         TRACEMSG("21: passed\n");
1017 }
1018
1019
1020 static void openAllFiles(BattFsSuper *disk)
1021 {
1022         TRACEMSG("22: try to open a lot of files\n");
1023
1024         FILE *fpt = fopen(test_filename, "w+");
1025         for (int i = 0; i < FILE_SIZE; i++)
1026                 fputc(0xff, fpt);
1027         KBlockFile f;
1028         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
1029
1030         BattFs fd[BATTFS_MAX_FILES];
1031         unsigned int MODE = BATTFS_CREATE;
1032
1033         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
1034         ASSERT(battfs_fsck(disk));
1035         for (unsigned i = 0; i < countof(fd); i++)
1036                 ASSERT(battfs_fileopen(disk, &fd[i], i, MODE));
1037
1038         ASSERT(battfs_fsck(disk));
1039
1040         for (unsigned i = 0; i < countof(fd); i++)
1041         {
1042                 ASSERT(kfile_close(&fd[i].fd) == 0);
1043                 ASSERT(kfile_error(&fd[i].fd) == 0);
1044         }
1045
1046         ASSERT(battfs_fsck(disk));
1047         ASSERT(battfs_umount(disk));
1048
1049
1050         fpt = fopen(test_filename, "r+");
1051         kblockfile_init(&f, fpt, page_buffer, PAGE_SIZE, PAGE_COUNT);
1052
1053         ASSERT(battfs_mount(disk, &f.b, page_array, sizeof(page_array)));
1054         ASSERT(battfs_fsck(disk));
1055
1056
1057         for (unsigned i = 0; i < countof(fd); i++)
1058                 ASSERT(battfs_fileopen(disk, &fd[i], i, MODE));
1059
1060         ASSERT(battfs_fsck(disk));
1061
1062         for (unsigned i = 0; i < countof(fd); i++)
1063         {
1064                 ASSERT(kfile_close(&fd[i].fd) == 0);
1065                 ASSERT(kfile_error(&fd[i].fd) == 0);
1066         }
1067
1068         ASSERT(battfs_fsck(disk));
1069         ASSERT(battfs_umount(disk));
1070         TRACEMSG("22: passed\n");
1071 }
1072
1073
1074 int battfs_testRun(void)
1075 {
1076         BattFsSuper disk;
1077
1078         diskNew(&disk);
1079         disk1File(&disk);
1080         diskHalfFile(&disk);
1081         oldSeq1(&disk);
1082         oldSeq2(&disk);
1083         oldSeq3(&disk);
1084         oldSeq2File(&disk);
1085         openFile(&disk);
1086         readFile(&disk);
1087         readAcross(&disk);
1088         writeFile(&disk);
1089         writeAcross(&disk);
1090         createFile(&disk);
1091         multipleWrite(&disk);
1092         increaseFile(&disk);
1093         readEOF(&disk);
1094         writeEOF(&disk);
1095         endOfSpace(&disk);
1096         multipleFilesRW(&disk);
1097         openAllFiles(&disk);
1098
1099         kprintf("All tests passed!\n");
1100
1101         return 0;
1102 }
1103
1104 int battfs_testSetup(void)
1105 {
1106         return 0;
1107 }
1108
1109 int battfs_testTearDown(void)
1110 {
1111         return 0;
1112 }
1113
1114 TEST_MAIN(battfs);
1115
1116 #endif // _TEST