mirror of
https://github.com/YunoHost-Apps/django_example_ynh.git
synced 2024-09-03 18:26:21 +02:00
expand tests
This commit is contained in:
parent
816564be80
commit
76fbfeee87
1 changed files with 50 additions and 2 deletions
|
@ -1,9 +1,12 @@
|
||||||
|
import difflib
|
||||||
import os
|
import os
|
||||||
import shutil
|
import shutil
|
||||||
import subprocess
|
import subprocess
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
import tomli
|
import tomli
|
||||||
|
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
|
from django_tools.unittest_utils.project_setup import check_editor_config
|
||||||
|
|
||||||
import django_yunohost_integration
|
import django_yunohost_integration
|
||||||
|
@ -38,19 +41,64 @@ def test_version():
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def test_poetry_check():
|
def poetry_check_output(*args):
|
||||||
poerty_bin = shutil.which('poetry')
|
poerty_bin = shutil.which('poetry')
|
||||||
|
|
||||||
output = subprocess.check_output(
|
output = subprocess.check_output(
|
||||||
[poerty_bin, 'check'],
|
(poerty_bin,) + args,
|
||||||
text=True,
|
text=True,
|
||||||
env=os.environ,
|
env=os.environ,
|
||||||
stderr=subprocess.STDOUT,
|
stderr=subprocess.STDOUT,
|
||||||
cwd=str(PACKAGE_ROOT),
|
cwd=str(PACKAGE_ROOT),
|
||||||
)
|
)
|
||||||
print(output)
|
print(output)
|
||||||
|
return output
|
||||||
|
|
||||||
|
|
||||||
|
def test_poetry_check():
|
||||||
|
output = poetry_check_output('check')
|
||||||
assert output == 'All set!\n'
|
assert output == 'All set!\n'
|
||||||
|
|
||||||
|
|
||||||
|
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():
|
def test_check_editor_config():
|
||||||
check_editor_config(package_root=PACKAGE_ROOT)
|
check_editor_config(package_root=PACKAGE_ROOT)
|
||||||
|
|
Loading…
Reference in a new issue