micropython/tests/extmod/vfs_lfs_mount.py

115 lines
2.4 KiB
Python
Raw Normal View History

2019-10-18 07:25:48 +01:00
# Test for VfsLittle using a RAM device, with mount/umount
try:
import uos
2019-10-18 07:25:48 +01:00
uos.VfsLfs1
uos.VfsLfs2
except (ImportError, AttributeError):
print("SKIP")
raise SystemExit
2019-10-18 07:25:48 +01: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=0):
2019-10-18 07:25:48 +01:00
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=0):
2019-10-18 07:25:48 +01:00
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 07:25:48 +01:00
return len(self.data) // self.ERASE_BLOCK_SIZE
if op == 5: # block size
2019-10-18 07:25:48 +01:00
return self.ERASE_BLOCK_SIZE
if op == 6: # erase block
2019-10-18 07:25:48 +01:00
return 0
def test(vfs_class):
print("test", vfs_class)
2019-10-18 07:25:48 +01:00
bdev = RAMBlockDevice(30)
# mount bdev unformatted
try:
uos.mount(bdev, "/lfs")
except Exception as er:
print(repr(er))
2019-10-18 07:25:48 +01:00
# mkfs
vfs_class.mkfs(bdev)
# construction
vfs = vfs_class(bdev)
# mount
uos.mount(vfs, "/lfs")
2019-10-18 07:25:48 +01:00
# import
with open("/lfs/lfsmod.py", "w") as f:
2019-10-18 07:25:48 +01:00
f.write('print("hello from lfs")\n')
import lfsmod
# import package
uos.mkdir("/lfs/lfspkg")
with open("/lfs/lfspkg/__init__.py", "w") as f:
2019-10-18 07:25:48 +01:00
f.write('print("package")\n')
import lfspkg
# chdir and import module from current directory (needs "" in sys.path)
uos.mkdir("/lfs/subdir")
uos.chdir("/lfs/subdir")
uos.rename("/lfs/lfsmod.py", "/lfs/subdir/lfsmod2.py")
import lfsmod2
2019-10-18 07:25:48 +01:00
# umount
uos.umount("/lfs")
2019-10-18 07:25:48 +01:00
# mount read-only
vfs = vfs_class(bdev)
uos.mount(vfs, "/lfs", readonly=True)
# test reading works
with open("/lfs/subdir/lfsmod2.py") as f:
print("lfsmod2.py:", f.read())
# test writing fails
try:
open("/lfs/test_write", "w")
except OSError as er:
print(repr(er))
# umount
uos.umount("/lfs")
# mount bdev again
uos.mount(bdev, "/lfs")
# umount
uos.umount("/lfs")
2019-10-18 07:25:48 +01:00
# clear imported modules
usys.modules.clear()
2019-10-18 07:25:48 +01:00
2019-10-18 07:25:48 +01:00
# initialise path
import usys
usys.path.clear()
usys.path.append("/lfs")
usys.path.append("")
2019-10-18 07:25:48 +01:00
# run tests
test(uos.VfsLfs1)
test(uos.VfsLfs2)