mirror of
https://github.com/ChristianLight/tutor.git
synced 2025-01-22 13:18:24 +00:00
fix: unit tests with v1 plugin installed
When a v1 plugin was installed, several things were happening regarding tests: 1. v1 plugin loading was happening despite the TUTOR_IGNORE_ENTRYPOINT_PLUGINS environment variable. 2. the CORE_READY event was not triggered because it was happening just once at import time. This was causing some tests to incorrectly load the MFE plugin.
This commit is contained in:
parent
d9486018a2
commit
34c8eeeaec
@ -16,16 +16,9 @@ class JobsTests(unittest.TestCase):
|
|||||||
config = tutor_config.load_full(root)
|
config = tutor_config.load_full(root)
|
||||||
runner = context.job_runner(config)
|
runner = context.job_runner(config)
|
||||||
jobs.initialise(runner)
|
jobs.initialise(runner)
|
||||||
|
|
||||||
output = mock_stdout.getvalue().strip()
|
output = mock_stdout.getvalue().strip()
|
||||||
service = re.search(r"Service: (\w*)", output)
|
|
||||||
commands = re.search(r"(-----)([\S\s]+)(-----)", output)
|
|
||||||
assert service is not None
|
|
||||||
assert commands is not None
|
|
||||||
self.assertTrue(output.startswith("Initialising all services..."))
|
self.assertTrue(output.startswith("Initialising all services..."))
|
||||||
self.assertTrue(output.endswith("All services initialised."))
|
self.assertTrue(output.endswith("All services initialised."))
|
||||||
self.assertEqual(service.group(1), "mysql")
|
|
||||||
self.assertTrue(commands.group(2))
|
|
||||||
|
|
||||||
def test_create_user_command_without_staff(self) -> None:
|
def test_create_user_command_without_staff(self) -> None:
|
||||||
command = jobs.create_user_command("superuser", False, "username", "email")
|
command = jobs.create_user_command("superuser", False, "username", "email")
|
||||||
|
@ -14,12 +14,13 @@ from tutor.commands.k8s import k8s
|
|||||||
from tutor.commands.local import local
|
from tutor.commands.local import local
|
||||||
from tutor.commands.plugins import plugins_command
|
from tutor.commands.plugins import plugins_command
|
||||||
|
|
||||||
# Everyone on board
|
|
||||||
hooks.Actions.CORE_READY.do()
|
|
||||||
|
|
||||||
|
|
||||||
def main() -> None:
|
def main() -> None:
|
||||||
try:
|
try:
|
||||||
|
# Everyone on board
|
||||||
|
# Note that this action should not be triggered in the module scope, because it
|
||||||
|
# makes it difficult for tests to rollback changes.
|
||||||
|
hooks.Actions.CORE_READY.do()
|
||||||
cli() # pylint: disable=no-value-for-parameter
|
cli() # pylint: disable=no-value-for-parameter
|
||||||
except KeyboardInterrupt:
|
except KeyboardInterrupt:
|
||||||
pass
|
pass
|
||||||
|
@ -25,8 +25,9 @@ def _discover_entrypoint_plugins() -> None:
|
|||||||
Discover all plugins that declare a "tutor.plugin.v1" entrypoint.
|
Discover all plugins that declare a "tutor.plugin.v1" entrypoint.
|
||||||
"""
|
"""
|
||||||
with hooks.Contexts.PLUGINS.enter():
|
with hooks.Contexts.PLUGINS.enter():
|
||||||
for entrypoint in pkg_resources.iter_entry_points("tutor.plugin.v1"):
|
if "TUTOR_IGNORE_ENTRYPOINT_PLUGINS" not in os.environ:
|
||||||
discover_package(entrypoint)
|
for entrypoint in pkg_resources.iter_entry_points("tutor.plugin.v1"):
|
||||||
|
discover_package(entrypoint)
|
||||||
|
|
||||||
|
|
||||||
def discover_module(path: str) -> None:
|
def discover_module(path: str) -> None:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user