2019-11-03 10:35:03 +03:00
|
|
|
#!/usr/bin/python3
|
|
|
|
#
|
|
|
|
# Basic bcachefs functionality tests.
|
|
|
|
|
|
|
|
import re
|
|
|
|
import util
|
|
|
|
|
|
|
|
def test_help():
|
|
|
|
ret = util.run_bch(valgrind=True)
|
|
|
|
|
|
|
|
assert ret.returncode == 1
|
|
|
|
assert "missing command" in ret.stdout
|
|
|
|
assert len(ret.stderr) == 0
|
|
|
|
|
|
|
|
def test_format(tmpdir):
|
|
|
|
dev = util.device_1g(tmpdir)
|
|
|
|
ret = util.run_bch('format', dev, valgrind=True)
|
|
|
|
|
|
|
|
assert ret.returncode == 0
|
|
|
|
assert len(ret.stdout) > 0
|
|
|
|
assert len(ret.stderr) == 0
|
|
|
|
|
|
|
|
def test_fsck(tmpdir):
|
2019-11-10 06:00:56 +03:00
|
|
|
dev = util.format_1g(tmpdir)
|
2019-11-03 10:35:03 +03:00
|
|
|
|
|
|
|
ret = util.run_bch('fsck', dev, valgrind=True)
|
|
|
|
|
|
|
|
assert ret.returncode == 0
|
|
|
|
assert len(ret.stdout) > 0
|
|
|
|
assert len(ret.stderr) == 0
|
|
|
|
|
|
|
|
def test_list(tmpdir):
|
2019-11-10 06:00:56 +03:00
|
|
|
dev = util.format_1g(tmpdir)
|
2019-11-03 10:35:03 +03:00
|
|
|
|
|
|
|
ret = util.run_bch('list', dev, valgrind=True)
|
|
|
|
|
|
|
|
assert ret.returncode == 0
|
|
|
|
assert len(ret.stderr) == 0
|
|
|
|
assert "recovering from clean shutdown" in ret.stdout
|
2020-08-22 17:30:50 +03:00
|
|
|
assert len(ret.stdout.splitlines()) == 95
|
2019-11-03 10:35:03 +03:00
|
|
|
|
|
|
|
def test_list_inodes(tmpdir):
|
2019-11-10 06:00:56 +03:00
|
|
|
dev = util.format_1g(tmpdir)
|
2019-11-03 10:35:03 +03:00
|
|
|
|
|
|
|
ret = util.run_bch('list', '-b', 'inodes', dev, valgrind=True)
|
|
|
|
|
|
|
|
assert ret.returncode == 0
|
|
|
|
assert len(ret.stderr) == 0
|
|
|
|
assert len(ret.stdout.splitlines()) == (2 + 2) # 2 inodes on clean format
|
|
|
|
|
|
|
|
def test_list_dirent(tmpdir):
|
2019-11-10 06:00:56 +03:00
|
|
|
dev = util.format_1g(tmpdir)
|
2019-11-03 10:35:03 +03:00
|
|
|
|
|
|
|
ret = util.run_bch('list', '-b', 'dirents', dev, valgrind=True)
|
|
|
|
|
|
|
|
assert ret.returncode == 0
|
|
|
|
assert len(ret.stderr) == 0
|
|
|
|
assert len(ret.stdout.splitlines()) == (2 + 1) # 1 dirent
|
|
|
|
|
|
|
|
# Example:
|
|
|
|
# u64s 8 type dirent 4096:2449855786607753081
|
|
|
|
# snap 0 len 0 ver 0: lost+found -> 4097
|
|
|
|
last = ret.stdout.splitlines()[-1]
|
|
|
|
assert re.match(r'^.*type dirent.*: lost\+found ->.*$', last)
|