circuitpython/tests/extmod/vfs_lfs_error.py

122 lines
2.6 KiB
Python
Raw Normal View History

2019-10-18 02:25:48 -04:00
# Test for VfsLittle using a RAM device, testing error handling
try:
import uos
2019-10-18 02:25:48 -04:00
uos.VfsLfs1
uos.VfsLfs2
except (ImportError, AttributeError):
print("SKIP")
raise SystemExit
2019-10-18 02:25:48 -04:00
class RAMBlockDevice:
ERASE_BLOCK_SIZE = 1024
def __init__(self, blocks):
self.data = bytearray(blocks * self.ERASE_BLOCK_SIZE)
def readblocks(self, block, buf, off):
addr = block * self.ERASE_BLOCK_SIZE + off
for i in range(len(buf)):
buf[i] = self.data[addr + i]
def writeblocks(self, block, buf, off):
addr = block * self.ERASE_BLOCK_SIZE + off
for i in range(len(buf)):
self.data[addr + i] = buf[i]
def ioctl(self, op, arg):
if op == 4: # block count
2019-10-18 02:25:48 -04:00
return len(self.data) // self.ERASE_BLOCK_SIZE
if op == 5: # block size
2019-10-18 02:25:48 -04:00
return self.ERASE_BLOCK_SIZE
if op == 6: # erase block
2019-10-18 02:25:48 -04:00
return 0
2019-10-18 02:25:48 -04:00
def test(bdev, vfs_class):
print("test", vfs_class)
2019-10-18 02:25:48 -04:00
# mkfs with too-small block device
try:
vfs_class.mkfs(RAMBlockDevice(1))
except OSError:
print("mkfs OSError")
2019-10-18 02:25:48 -04:00
# mount with invalid filesystem
try:
vfs_class(bdev)
except OSError:
print("mount OSError")
2019-10-18 02:25:48 -04:00
# set up for following tests
vfs_class.mkfs(bdev)
vfs = vfs_class(bdev)
with vfs.open("testfile", "w") as f:
f.write("test")
vfs.mkdir("testdir")
2019-10-18 02:25:48 -04:00
# ilistdir
try:
vfs.ilistdir("noexist")
2019-10-18 02:25:48 -04:00
except OSError:
print("ilistdir OSError")
2019-10-18 02:25:48 -04:00
# remove
try:
vfs.remove("noexist")
2019-10-18 02:25:48 -04:00
except OSError:
print("remove OSError")
2019-10-18 02:25:48 -04:00
# rmdir
try:
vfs.rmdir("noexist")
2019-10-18 02:25:48 -04:00
except OSError:
print("rmdir OSError")
2019-10-18 02:25:48 -04:00
# rename
try:
vfs.rename("noexist", "somethingelse")
2019-10-18 02:25:48 -04:00
except OSError:
print("rename OSError")
2019-10-18 02:25:48 -04:00
# mkdir
try:
vfs.mkdir("testdir")
2019-10-18 02:25:48 -04:00
except OSError:
print("mkdir OSError")
2019-10-18 02:25:48 -04:00
# chdir to nonexistent
try:
vfs.chdir("noexist")
2019-10-18 02:25:48 -04:00
except OSError:
print("chdir OSError")
print(vfs.getcwd()) # check still at root
2019-10-18 02:25:48 -04:00
# chdir to file
try:
vfs.chdir("testfile")
2019-10-18 02:25:48 -04:00
except OSError:
print("chdir OSError")
print(vfs.getcwd()) # check still at root
2019-10-18 02:25:48 -04:00
# stat
try:
vfs.stat("noexist")
2019-10-18 02:25:48 -04:00
except OSError:
print("stat OSError")
2019-10-18 02:25:48 -04:00
# error during seek
with vfs.open("testfile", "r") as f:
f.seek(1 << 30) # SEEK_SET
2019-10-18 02:25:48 -04:00
try:
f.seek(1 << 30, 1) # SEEK_CUR
2019-10-18 02:25:48 -04:00
except OSError:
print("seek OSError")
2019-10-18 02:25:48 -04:00
bdev = RAMBlockDevice(30)
test(bdev, uos.VfsLfs1)
test(bdev, uos.VfsLfs2)