mim/tests/test_run.py

61 lines
2.0 KiB
Python
Raw Normal View History

2021-05-20 00:03:43 +08:00
import os.path as osp
import tempfile
import time
from click.testing import CliRunner
from mim.commands.install import cli as install
from mim.commands.run import cli as run
from mim.utils import download_from_file, extract_tar, is_installed
2021-05-20 09:18:31 +00:00
dataset_url = 'https://download.openmmlab.com/mim/dataset.tar'
cfg_url = 'https://download.openmmlab.com/mim/resnet18_b16x8_custom.py'
ckpt_url = 'https://download.openmmlab.com/mim/epoch_3.pth'
2021-05-20 00:03:43 +08:00
def setup_module():
runner = CliRunner()
if not is_installed('mmcls'):
result = runner.invoke(install, ['mmcls', '--yes'])
assert result.exit_code == 0
def test_run():
runner = CliRunner()
with tempfile.TemporaryDirectory() as temp_root:
if not osp.exists(f'{temp_root}/dataset'):
download_from_file(dataset_url, f'{temp_root}/dataset.tar')
extract_tar(f'{temp_root}/dataset.tar', f'{temp_root}/')
if not osp.exists(f'{temp_root}/config.py'):
download_from_file(cfg_url, f'{temp_root}/config.py')
if not osp.exists(f'{temp_root}/ckpt.pth'):
download_from_file(ckpt_url, f'{temp_root}/ckpt.pth')
# wait for the download task to complete
time.sleep(5)
result = runner.invoke(run, [
'mmcls', 'train', f'{temp_root}/config.py', '--gpus=1',
f'--work-dir={temp_root}'
])
assert result.exit_code == 0
result = runner.invoke(run, [
'mmcls', 'test', f'{temp_root}/config.py', f'{temp_root}/ckpt.pth',
'--metrics=accuracy'
])
assert result.exit_code == 0
result = runner.invoke(run, [
'mmcls', 'xxx', f'{temp_root}/config.py', f'{temp_root}/ckpt.pth',
'--metrics=accuracy'
])
assert result.exit_code != 0
result = runner.invoke(run, [
'mmcls', 'test', f'{temp_root}/xxx.py', f'{temp_root}/ckpt.pth',
'--metrics=accuracy'
])
assert result.exit_code != 0