changeset af3fa5c78f6b in modules/analytic_sale:default
details:
https://hg.tryton.org/modules/analytic_sale?cmd=changeset&node=af3fa5c78f6b
description:
Replace test setuptools command by unittest discover
issue9215
review389851002
diffstat:
setup.py | 6 +++---
tests/__init__.py | 7 -------
tests/test_analytic_sale.py | 24 ------------------------
tests/test_module.py | 12 ++++++++++++
tests/test_scenario.py | 22 ++++++++++++++++++++++
tox.ini | 3 ++-
6 files changed, 39 insertions(+), 35 deletions(-)
diffs (117 lines):
diff -r f9f5bdc60c69 -r af3fa5c78f6b setup.py
--- a/setup.py Mon Apr 11 22:29:29 2022 +0200
+++ b/setup.py Sat Apr 16 18:30:17 2022 +0200
@@ -137,13 +137,13 @@
license='GPL-3',
python_requires='>=3.7',
install_requires=requires,
+ extras_require={
+ 'test': tests_require,
+ },
dependency_links=dependency_links,
zip_safe=False,
entry_points="""
[trytond.modules]
analytic_sale = trytond.modules.analytic_sale
""",
- test_suite='tests',
- test_loader='trytond.test_loader:Loader',
- tests_require=tests_require,
)
diff -r f9f5bdc60c69 -r af3fa5c78f6b tests/__init__.py
--- a/tests/__init__.py Mon Apr 11 22:29:29 2022 +0200
+++ b/tests/__init__.py Sat Apr 16 18:30:17 2022 +0200
@@ -1,9 +1,2 @@
# This file is part of Tryton. The COPYRIGHT file at the top level of
# this repository contains the full copyright notices and license terms.
-
-try:
- from trytond.modules.analytic_sale.tests.test_analytic_sale import suite
-except ImportError:
- from .test_analytic_sale import suite
-
-__all__ = ['suite']
diff -r f9f5bdc60c69 -r af3fa5c78f6b tests/test_analytic_sale.py
--- a/tests/test_analytic_sale.py Mon Apr 11 22:29:29 2022 +0200
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,24 +0,0 @@
-# This file is part of Tryton. The COPYRIGHT file at the top level of
-# this repository contains the full copyright notices and license terms.
-import doctest
-import unittest
-
-import trytond.tests.test_tryton
-from trytond.tests.test_tryton import (
- ModuleTestCase, doctest_checker, doctest_teardown)
-
-
-class AnalyticSaleTestCase(ModuleTestCase):
- 'Test AnalyticSale module'
- module = 'analytic_sale'
-
-
-def suite():
- suite = trytond.tests.test_tryton.suite()
- suite.addTests(unittest.TestLoader().loadTestsFromTestCase(
- AnalyticSaleTestCase))
- suite.addTests(doctest.DocFileSuite('scenario_analytic_sale.rst',
- tearDown=doctest_teardown, encoding='utf-8',
- checker=doctest_checker,
- optionflags=doctest.REPORT_ONLY_FIRST_FAILURE))
- return suite
diff -r f9f5bdc60c69 -r af3fa5c78f6b tests/test_module.py
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/test_module.py Sat Apr 16 18:30:17 2022 +0200
@@ -0,0 +1,12 @@
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
+
+from trytond.tests.test_tryton import ModuleTestCase
+
+
+class AnalyticSaleTestCase(ModuleTestCase):
+ 'Test AnalyticSale module'
+ module = 'analytic_sale'
+
+
+del ModuleTestCase
diff -r f9f5bdc60c69 -r af3fa5c78f6b tests/test_scenario.py
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/test_scenario.py Sat Apr 16 18:30:17 2022 +0200
@@ -0,0 +1,22 @@
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
+
+import doctest
+import glob
+import os
+
+from trytond.tests.test_tryton import doctest_checker, doctest_teardown
+
+
+def load_tests(loader, tests, pattern):
+ cwd = os.getcwd()
+ try:
+ os.chdir(os.path.dirname(__file__))
+ for scenario in glob.glob('*.rst'):
+ tests.addTests(doctest.DocFileSuite(
+ scenario, tearDown=doctest_teardown, encoding='utf-8',
+ checker=doctest_checker,
+ optionflags=doctest.REPORT_ONLY_FIRST_FAILURE))
+ finally:
+ os.chdir(cwd)
+ return tests
diff -r f9f5bdc60c69 -r af3fa5c78f6b tox.ini
--- a/tox.ini Mon Apr 11 22:29:29 2022 +0200
+++ b/tox.ini Sat Apr 16 18:30:17 2022 +0200
@@ -2,8 +2,9 @@
envlist = {py37,py38,py39,py310}-{sqlite,postgresql}
[testenv]
+extras = test
commands =
- coverage run --include=.*/analytic_sale/* setup.py test
+ coverage run --include=.*/analytic_sale/* -m unittest discover -s tests
coverage report --include=.*/analytic_sale/* --omit=*/tests/*
deps =
coverage