changeset 6a8d11bcec52 in modules/marketing_automation:default
details:
https://hg.tryton.org/modules/marketing_automation?cmd=changeset&node=6a8d11bcec52
description:
Replace test setuptools command by unittest discover
issue9215
review389851002
diffstat:
setup.py | 6 +++---
tests/__init__.py | 8 --------
tests/test_marketing_automation.py | 26 --------------------------
tests/test_module.py | 12 ++++++++++++
tests/test_scenario.py | 22 ++++++++++++++++++++++
tox.ini | 3 ++-
6 files changed, 39 insertions(+), 38 deletions(-)
diffs (120 lines):
diff -r d1c85da83a06 -r 6a8d11bcec52 setup.py
--- a/setup.py Tue Apr 12 10:35:40 2022 +0200
+++ b/setup.py Sat Apr 16 18:30:17 2022 +0200
@@ -141,13 +141,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]
marketing_automation = trytond.modules.marketing_automation
""",
- test_suite='tests',
- test_loader='trytond.test_loader:Loader',
- tests_require=tests_require,
)
diff -r d1c85da83a06 -r 6a8d11bcec52 tests/__init__.py
--- a/tests/__init__.py Tue Apr 12 10:35:40 2022 +0200
+++ b/tests/__init__.py Sat Apr 16 18:30:17 2022 +0200
@@ -1,10 +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.marketing_automation.tests.test_marketing_automation
import \
- suite # noqa: E501
-except ImportError:
- from .test_marketing_automation import suite
-
-__all__ = ['suite']
diff -r d1c85da83a06 -r 6a8d11bcec52 tests/test_marketing_automation.py
--- a/tests/test_marketing_automation.py Tue Apr 12 10:35:40 2022 +0200
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,26 +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
-
-from trytond.tests.test_tryton import (
- ModuleTestCase, doctest_checker, doctest_teardown)
-from trytond.tests.test_tryton import suite as test_suite
-
-
-class MarketingAutomationTestCase(ModuleTestCase):
- 'Test Marketing Automation module'
- module = 'marketing_automation'
-
-
-def suite():
- suite = test_suite()
- suite.addTests(unittest.TestLoader().loadTestsFromTestCase(
- MarketingAutomationTestCase))
- suite.addTests(doctest.DocFileSuite(
- 'scenario_marketing_automation.rst',
- tearDown=doctest_teardown, encoding='utf-8',
- checker=doctest_checker,
- optionflags=doctest.REPORT_ONLY_FIRST_FAILURE))
- return suite
diff -r d1c85da83a06 -r 6a8d11bcec52 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 MarketingAutomationTestCase(ModuleTestCase):
+ 'Test Marketing Automation module'
+ module = 'marketing_automation'
+
+
+del ModuleTestCase
diff -r d1c85da83a06 -r 6a8d11bcec52 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 d1c85da83a06 -r 6a8d11bcec52 tox.ini
--- a/tox.ini Tue Apr 12 10:35:40 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=.*/marketing_automation/* setup.py test
+ coverage run --include=.*/marketing_automation/* -m unittest discover -s
tests
coverage report --include=.*/marketing_automation/* --omit=*/tests/*
deps =
coverage