edit-mode-vs-play-mode-tests.md 2.6 KB

Edit Mode vs. Play Mode tests

Let’s clarify a bit what Play Mode and Edit Mode test means from the Unity Test Framework perspective:

Edit Mode tests

Edit Mode tests (also known as Editor tests) are only run in the Unity Editor and have access to the Editor code in addition to the game code.

With Edit Mode tests it is possible to test any of your Editor extensions using the UnityTest attribute. For Edit Mode tests, your test code runs in the EditorApplication.update callback loop.

Note: You can also control entering and exiting Play Mode from your Edit Mode test. This allow your test to make changes before entering Play Mode.

Edit Mode tests should meet one of the following conditions:

  • They should have an assembly definition with reference to nunit.framework.dll and has only the Editor as a target platform:
    "includePlatforms": [
        "Editor"
    ],
  • Legacy condition: put tests in the project’s Editor folder.

Play Mode tests

You can run Play Mode tests as a standalone in a Player or inside the Editor. Play Mode tests allow you to exercise your game code, as the tests run as coroutines if marked with the UnityTest attribute.

Play Mode tests should correspond to the following conditions:

  • Have an assembly definition with reference to nunit.framework.dll.
  • Have the test scripts located in a folder with the .asmdef file.
  • The test assembly should reference an assembly within the code that you need to test.
    "references": [
        "NewAssembly"
    ],
    "optionalUnityReferences": [
        "TestAssemblies"
   ],
    "includePlatforms": [],

Recommendations

Attributes

Use the NUnit Test attribute instead of the UnityTest attribute, unless you need to yield special instructions, in Edit Mode, or if you need to skip a frame or wait for a certain amount of time in Play Mode.

References

It is possible for your Test Assemblies to reference the test tools in UnityEngine.TestRunner and UnityEditor.TestRunner. The latter is only available in Edit Mode. You can specify these references in the Assembly Definition References on the Assembly Definition.