diff options
| author | 2022-06-24 06:01:41 +0400 | |
|---|---|---|
| committer | 2022-06-24 06:01:41 +0400 | |
| commit | c615219749e3deabe48943f763623f5d8545bf80 (patch) | |
| tree | a4dd7185e44b96cd114a8f062c4c72c8d6b626c6 /backend | |
| parent | Merge pull request #173 from adriangb/asgi-middleware (diff) | |
| parent | Make Unittests Async (diff) | |
Merge pull request #179 from python-discord/add-setup
Allow Setup For Unittests
Diffstat (limited to 'backend')
| -rw-r--r-- | backend/models/question.py | 6 | ||||
| -rw-r--r-- | backend/routes/forms/unittesting.py | 14 | 
2 files changed, 13 insertions, 7 deletions
diff --git a/backend/models/question.py b/backend/models/question.py index 5a1334a..201aa51 100644 --- a/backend/models/question.py +++ b/backend/models/question.py @@ -15,8 +15,10 @@ class Unittests(BaseModel):      @validator("tests")      def validate_tests(cls, value: _TESTS_TYPE) -> _TESTS_TYPE:          """Confirm that at least one test exists in a test suite.""" -        if isinstance(value, dict) and len(value.keys()) == 0: -            raise ValueError("Must have at least one test in a test suite.") +        if isinstance(value, dict): +            keys = len(value.keys()) - (1 if "setUp" in value.keys() else 0) +            if keys == 0: +                raise ValueError("Must have at least one test in a test suite.")          return value diff --git a/backend/routes/forms/unittesting.py b/backend/routes/forms/unittesting.py index a830775..13fa639 100644 --- a/backend/routes/forms/unittesting.py +++ b/backend/routes/forms/unittesting.py @@ -36,10 +36,14 @@ def _make_unit_code(units: dict[str, str]) -> str:      result = ""      for unit_name, unit_code in units.items(): -        result += ( -            f"\ndef test_{unit_name.lstrip('#')}(unit):"  # Function definition -            f"\n{indent(unit_code, '    ')}"  # Unit code -        ) +        # Function definition +        if unit_name == "setUp": +            result += "\ndef setUp(self):" +        else: +            result += f"\nasync def {unit_name.removeprefix('#')}(self):" + +        # Unite code +        result += f"\n{indent(unit_code, '    ')}"      return indent(result, "    ") @@ -83,7 +87,7 @@ async def execute_unittest(form_response: FormResponse, form: Form) -> list[Unit              # Tests starting with an hashtag should have censored names.              hidden_test_counter = count(1)              hidden_tests = { -                test.lstrip("#").lstrip("test_"): next(hidden_test_counter) +                test.removeprefix("#").removeprefix("test_"): next(hidden_test_counter)                  for test in question.data["unittests"]["tests"].keys()                  if test.startswith("#")              }  |