django_example_ynh/tests/test_project_setup.py

136 lines
3.9 KiB
Python
Raw Normal View History

2022-09-19 08:49:01 +02:00
import difflib
2020-12-28 20:14:39 +01:00
import os
import shutil
import subprocess
from pathlib import Path
2022-08-12 17:56:02 +02:00
import tomli
2022-09-19 08:49:01 +02:00
from bx_django_utils.filename import clean_filename
from bx_py_utils.path import assert_is_dir, assert_is_file
from django_tools.unittest_utils.project_setup import check_editor_config
2022-10-04 09:14:04 +02:00
from django_yunohost_integration.test_utils import assert_project_version
2022-12-21 19:19:37 +01:00
from django_example import __version__
2020-12-28 20:14:39 +01:00
PACKAGE_ROOT = Path(__file__).parent.parent
2020-12-28 20:14:39 +01:00
def assert_file_contains_string(file_path, string):
with file_path.open('r') as f:
for line in f:
if string in line:
return
raise AssertionError(f'File {file_path} does not contain {string!r} !')
def test_version():
2022-10-04 09:14:04 +02:00
assert_project_version(
2022-12-21 19:19:37 +01:00
current_version=__version__,
github_project_url='https://github.com/jedie/django-example',
2022-10-04 09:14:04 +02:00
)
2022-08-12 17:56:02 +02:00
pyproject_toml_path = Path(PACKAGE_ROOT, 'pyproject.toml')
pyproject_toml = tomli.loads(pyproject_toml_path.read_text(encoding='UTF-8'))
pyproject_version = pyproject_toml['tool']['poetry']['version']
assert pyproject_version.startswith(
f'{__version__}+ynh'
), f'{pyproject_version!r} does not start with "{__version__}+ynh"'
# pyproject.toml needs a PEP 440 conform version and used "+ynh"
# the YunoHost syntax is: "~ynh", just "convert this:
manifest_version = pyproject_version.replace('+', '~')
2020-12-28 20:14:39 +01:00
2022-08-12 17:56:02 +02:00
assert_file_contains_string(
file_path=Path(PACKAGE_ROOT, 'manifest.json'),
string=f'"version": "{manifest_version}"',
2022-08-12 17:56:02 +02:00
)
2020-12-28 20:14:39 +01:00
2022-09-19 08:49:01 +02:00
def poetry_check_output(*args):
2020-12-28 20:14:39 +01:00
poerty_bin = shutil.which('poetry')
output = subprocess.check_output(
2022-09-19 08:49:01 +02:00
(poerty_bin,) + args,
2022-08-12 17:56:02 +02:00
text=True,
2020-12-28 20:14:39 +01:00
env=os.environ,
stderr=subprocess.STDOUT,
cwd=str(PACKAGE_ROOT),
2020-12-28 20:14:39 +01:00
)
print(output)
2022-09-19 08:49:01 +02:00
return output
def test_poetry_check():
output = poetry_check_output('check')
2020-12-28 20:14:39 +01:00
assert output == 'All set!\n'
2022-09-19 08:49:01 +02:00
def test_requirements_txt():
requirements_txt = PACKAGE_ROOT / 'conf' / 'requirements.txt'
assert_is_file(requirements_txt)
output = poetry_check_output('export', '-f', 'requirements.txt')
assert 'Warning' not in output
current_content = requirements_txt.read_text()
diff = '\n'.join(
difflib.unified_diff(
current_content.splitlines(),
output.splitlines(),
fromfile=str(requirements_txt),
tofile='FRESH EXPORT',
)
)
print(diff)
assert diff == '', f'{requirements_txt} is not up-to-date! (Hint: call: "make update")'
def test_screenshot_filenames():
"""
https://forum.yunohost.org/t/yunohost-bot-cant-handle-spaces-in-screenshots/19483
"""
screenshot_path = PACKAGE_ROOT / 'doc' / 'screenshots'
assert_is_dir(screenshot_path)
renamed = []
for file_path in screenshot_path.iterdir():
file_name = file_path.name
if file_name.startswith('.'):
continue
cleaned_name = clean_filename(file_name)
if cleaned_name != file_name:
new_path = file_path.with_name(cleaned_name)
file_path.rename(new_path)
renamed.append(f'{file_name!r} renamed to {cleaned_name!r}')
assert not renamed, f'Bad screenshots file names found: {", ".join(renamed)}'
def test_check_editor_config():
check_editor_config(package_root=PACKAGE_ROOT)
2022-12-21 20:02:02 +01:00
def _call_make(*args):
make_bin = shutil.which('make')
assert make_bin
return subprocess.check_output(
(make_bin,) + args,
text=True,
env=dict(PATH=os.environ['PATH']),
stderr=subprocess.STDOUT,
cwd=str(PACKAGE_ROOT),
)
def test_check_code_style():
# First try:
try:
_call_make('lint')
except subprocess.CalledProcessError:
# Fix and test again:
_call_make('fix-code-style')
try:
_call_make('lint')
except subprocess.CalledProcessError as err:
raise AssertionError(f'Linting error:\n{"-"*100}\n{err.stdout}\n{"-"*100}')