2020-07-29 21:03:00 +02:00
|
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
import os
|
2020-08-05 11:10:14 +02:00
|
|
|
|
import subprocess
|
2020-08-05 14:28:55 +02:00
|
|
|
|
import importlib
|
2020-08-07 00:00:33 +02:00
|
|
|
|
import tempfile
|
|
|
|
|
from unittest.mock import patch
|
2020-07-29 21:03:00 +02:00
|
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
from click.testing import CliRunner
|
2020-08-05 11:10:14 +02:00
|
|
|
|
from configparser import ConfigParser
|
2020-07-29 21:03:00 +02:00
|
|
|
|
|
2020-08-05 11:10:14 +02:00
|
|
|
|
from halfapi import __version__
|
2020-07-29 21:03:00 +02:00
|
|
|
|
from halfapi.cli import cli
|
2020-08-05 14:28:55 +02:00
|
|
|
|
Cli = cli.cli
|
2020-07-29 21:03:00 +02:00
|
|
|
|
|
2020-08-05 11:10:14 +02:00
|
|
|
|
PROJNAME = os.environ.get('PROJ','tmp_api')
|
|
|
|
|
|
|
|
|
|
|
2021-12-01 12:20:01 +01:00
|
|
|
|
def test_options(runner):
|
|
|
|
|
# Wrong command
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
|
r = runner.invoke(Cli, ['foobar'])
|
2020-07-29 21:03:00 +02:00
|
|
|
|
assert r.exit_code == 2
|
|
|
|
|
|
2021-12-01 12:20:01 +01:00
|
|
|
|
# Test existing commands
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
|
r = runner.invoke(Cli, ['--help'])
|
|
|
|
|
assert r.exit_code == 0
|
|
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
|
r = runner.invoke(Cli, ['--version'])
|
|
|
|
|
assert r.exit_code == 0
|
|
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
|
r = runner.invoke(Cli, ['init', '--help'])
|
|
|
|
|
assert r.exit_code == 0
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_init_project_fail(runner):
|
|
|
|
|
# Missing argument (project)
|
|
|
|
|
testproject = 'testproject'
|
|
|
|
|
r = runner.invoke(Cli, ['init'])
|
|
|
|
|
assert r.exit_code == 2
|
|
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
|
# Fail : Wrong project name
|
|
|
|
|
r = runner.invoke(Cli, ['init', 'test*-project'])
|
|
|
|
|
assert r.exit_code == 1
|
|
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
|
# Fail : Already existing folder
|
|
|
|
|
os.mkdir(testproject)
|
|
|
|
|
r = runner.invoke(Cli, ['init', testproject])
|
|
|
|
|
assert r.exit_code == 1
|
|
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
|
# Fail : Already existing nod
|
|
|
|
|
os.mknod(testproject)
|
|
|
|
|
r = runner.invoke(Cli, ['init', testproject])
|
|
|
|
|
assert r.exit_code == 1
|
|
|
|
|
|
|
|
|
|
def test_init_project(runner):
|
|
|
|
|
"""
|
|
|
|
|
"""
|
|
|
|
|
cp = ConfigParser()
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
|
env = {
|
|
|
|
|
'HALFAPI_CONF_DIR': '.halfapi'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res = runner.invoke(Cli, ['init', PROJNAME], env=env)
|
|
|
|
|
try:
|
|
|
|
|
assert os.path.isdir(PROJNAME)
|
|
|
|
|
assert os.path.isdir(os.path.join(PROJNAME, '.halfapi'))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# .halfapi/config check
|
|
|
|
|
assert os.path.isfile(os.path.join(PROJNAME, '.halfapi', 'config'))
|
|
|
|
|
cp.read(os.path.join(PROJNAME, '.halfapi', 'config'))
|
|
|
|
|
assert cp.has_section('project')
|
|
|
|
|
assert cp.has_option('project', 'name')
|
|
|
|
|
assert cp.get('project', 'name') == PROJNAME
|
|
|
|
|
assert cp.get('project', 'halfapi_version') == __version__
|
|
|
|
|
assert cp.has_section('domain')
|
|
|
|
|
except AssertionError as exc:
|
|
|
|
|
subprocess.run(['tree', '-a', os.getcwd()])
|
|
|
|
|
raise exc
|
|
|
|
|
|
|
|
|
|
assert res.exit_code == 0
|
|
|
|
|
assert res.exception is None
|