Skip to content
This repository has been archived by the owner on Aug 1, 2022. It is now read-only.

Latest commit

 

History

History
44 lines (24 loc) · 2.76 KB

unittest.md

File metadata and controls

44 lines (24 loc) · 2.76 KB

Unit tests

Running unit test on the developer workstation

Unit tests use the unittest package. Most of them will start a broadcaster server and two instances of Blender. The tests will remotely execute python scripts in the Blender instances, so that they connect to the server and execute Blender python code scripts to modify the current document, and thus automatically synchronize. After all command are completed, the test grabs the miser command stream from each Blender and compares them.

Running the unit test require the MIXER_BLENDER_EXE_PATH environment variable to be set with the absolute path to the Blender that will be used for testing.

To start the tests from VScode, make sure that the addon is installed in the Blender instance that will be started, possibly by launching it once via VScode Blender development addon

CI/CD on unit tests

For a first simple setup, we rely on an interactive gitlab runner setup. Issues related to service-based runners are described below.

The scripts are located in a new gitlab folder.

Skipping automatic tests

You can skip tests by including the string [skip-tests] in the commit message.

Interactive Gitlab runner

Documentation:

Installation steps:

  1. Install a gitlab runner in a folder of your choice. For this tutorial we'll use d:\gitlab_runner.
  2. Run a terminal as administrator, create folder d:\gitlab_runner\working_dir and place yourself into it in your terminal
  3. Register a runner with gitlab-runner-windows-amd64.exe register. Use blender as tag, shell as executor. The token can be found in Settings -> CI/CD page of this repository. This step should create a file config.toml in d:\gitlab_runner\working_dir.
  4. Edit d:\gitlab_runner\working_dir and add an entry cache_dir = "D:/gitlab_runner/cache" in the [[runners]] section, after the shell entry.

Then run an interactive : gitlab-runner-windows-amd64.exe run. It must run as administrator because the TSCON command requires administrator rights to disconnect a session from the remote desktop.

The builds for the runner will be put in the current working directory d:\gitlab_runner\working_dir where you started the runner.

Runner as a Windows service

Using a system service could be difficult because the user profile may not be easy to access and we also need the service to access to the desktop.

Using a service that logons with a user account requires a user account that can logon as a service as described in https://docs.gitlab.com/runner/faq/README.html#the-service-did-not-start-due-to-a-logon-failure-error-when-starting-service.