Skip to content

A Github action to test your plugin in Tutor (Open edX distribution)

License

Notifications You must be signed in to change notification settings

eduNEXT/integration-test-in-tutor

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Open edX Plugin Integration Tests with Tutor

A GitHub Action to test your Open edX plugin (Django app) within Tutor (Open edX distribution). This action automates the setup of a Tutor environment, installs your plugin, runs migrations, and executes your integration tests in an isolated environment.

Example Usage

name: Integration Tests
on: [pull_request]

jobs:
  integration-test:
    runs-on: ubuntu-latest

    strategy:
      matrix:
        tutor_version: ["<18.0.0", "==18.0.3", "<19.0.0", "main"]

    steps:
      - name: Run Integration Tests
        uses: eduNEXT/integration-test-in-tutor@main
        with:
          app_name: "eox-test"
          tutor_version: ${{ matrix.tutor_version }}
          tutor_plugins: "plugin1 plugin2"
          inline_tutor_plugins_folder: "plugins"
          tutor_extra_commands_path: "scripts/extra_commands.sh"
          shell_file_to_run: "tests/integration.sh"
          openedx_extra_pip_requirements: "package1==1.0 package2>=2.0"
          fixtures_file: "fixtures/test_data.json"
          openedx_imports_test_file_path: "eox_test/edxapp_wrapper/test_backends.py"

Inputs

app_name

Required
The name of your plugin/application to test. This should match the directory name of your plugin.

  • Example: "eox-tenant"

tutor_version

Required
The version of Tutor where you want to run the integration tests. You can specify:

  • A specific version number (e.g., "==18.0.3").
  • A comparison operator with a version (e.g., "<18.0.0").
  • The string "main" to use the latest development version.

Important

This action is officially supported and tested with Tutor versions corresponding to the current and immediate previous Open edX releases, as well as the main (formerly known as nightly) build. Using other Tutor versions is not guaranteed to be supported.

python_version

Optional
The python version to run the integration tests with. Make sure to use a version fully supported by the plugin.

tutor_plugins

Optional
The list of Tutor Index plugins to install as a space-separated string. Only plugins available in the official Tutor plugin index can be installed using this option. For more information, you can refer to the official Tutor documentation.

  • Example: "plugin1 plugin2"

inline_tutor_plugins_folder

Optional
The path to the folder containing the inline Tutor plugins to install. This path is relative to your plugin directory.

  • Example: "plugins"

tutor_extra_commands_path

Optional The path to the shell script that contains extra Tutor commands to run after installing Tutor. This path is relative to your plugin directory.

  • Example: "scripts/extra_commands.sh"

shell_file_to_run

Optional
The path to the shell script that runs your integration tests. This path is relative to your plugin directory.

  • Default: "scripts/execute_integration_tests.sh"
  • Example: "tests/integration.sh"

openedx_extra_pip_requirements

Optional
Extra pip requirements to install in Open edX. These are additional Python packages your plugin depends on. Provide them as a space-separated string.

  • Example: "package1==1.0 package2>=2.0"

fixtures_file

Optional
The path to the fixtures file of your plugin to load initial data for the tests. This path is relative to your plugin directory.

  • Example: "fixtures/test_data.json"

openedx_imports_test_file_path

Optional
The path to the Python file in your plugin that contains the test function for validating Open edX imports. This path is relative to your plugin directory.

  • Example: "eox_test/edxapp_wrapper/test_backends.py"

Overview

This GitHub Action automates the process of setting up a Tutor Open edX environment to test your plugin. It performs the following steps:

  1. Set up Python version: Configures the Python version to ensure that tests are executed in an environment fully supported by our plugins.

  2. Checkout Plugin Code: Checks out your plugin code into a directory specified by app_name.

  3. Adjust Permissions: Modifies file permissions to ensure that all files and directories are accessible, preventing permission-related errors during Tutor operations.

  4. Set Up Plugins Directory: Creates a directory to store the inline Tutor plugins.

  5. Set Tutor Environment Variables: Sets necessary environment variables for Tutor.

  6. Create Virtual Environments: Creates isolated Python virtual environments for installing Tutor and for running the integration tests.

  7. Install and Prepare Tutor: Installs the specified version of Tutor.

    • If tutor_version is set to "main", clones the Tutor repository from the main branch.
    • Saves Tutor configuration.
  8. Install and Enable Tutor Plugins (Optional): Installs and enables the specified Tutor plugins specified in tutor_plugins input.

  9. Copy patches.yml to Plugins Directory: Copies the patches.yml file to the plugins folder. This inline Tutor plugin configures the web server and Open edX settings, to enable running integration tests from the plugin with multiple sites.

  10. Launch Tutor: Launches the Open edX platform using Tutor with the specified configuration.

  11. Add Mount for Plugin: Mounts your plugin into the LMS and CMS containers.

  12. Recreate Containers: Recreates the LMS and CMS containers to apply the changes.

  13. Install Open edX Plugin as an Editable Package: Installs your plugin in editable mode inside both LMS and CMS containers.

  14. Copy Inline Tutor Plugins to the Plugins Folder: Copies the inline Tutor plugins of your plugin to the plugins folder.

  15. Enable Inline Tutor Plugins: Installs the inline Tutor plugins inside the plugins folder.

  16. Install Extra Requirements: Installs any additional Python packages specified in openedx_extra_pip_requirements.

  17. Run Migrations and Restart Services: Applies database migrations and restarts Tutor services.

  18. Import Demo Course: Imports the Open edX demo course for testing purposes.

  19. Test Open edX Imports in Plugin (Optional): Runs pytest to validate Open edX imports in your plugin if openedx_imports_test_file_path is provided. The only two dependencies installed to run these tests are pytest and pytest-django, so ensure that your import tests do not require any extra packages that are not in the plugin's base requirements.

  20. Load Initial Data for the Tests (Optional): Loads initial data from a fixtures file into the LMS if fixtures_file is provided.

  21. Check LMS Heartbeat: Verifies that the LMS is running by hitting the heartbeat endpoint.

  22. Set DEMO_COURSE_ID Environment Variable:
    Sets the DEMO_COURSE_ID environment variable based on the Tutor version. This variable allows you to refer to the demo course in your tests, which can be helpful when you need to interact with course content during testing.

    Usage in Your Tests:
    In your test code, you can access the DEMO_COURSE_ID environment variable to get the identifier of the demo course. For example:

    import os
    
    DEMO_COURSE_ID = os.environ.get("DEMO_COURSE_ID")
    # Use DEMO_COURSE_ID in your tests
  23. Run Extra Tutor Commands (Optional): Executes the shell script specified in tutor_extra_commands_path to run additional Tutor commands after installing Tutor.

  24. Run Integration Tests: Activates the test virtual environment and runs your integration tests using the specified shell script.

Notes

  • Using the "main" Version of Tutor:
    The "main" option allows you to test your plugin against the latest development code of Tutor. This is useful for ensuring compatibility with upcoming features or changes. Be aware that the main version may be less stable and could introduce breaking changes. When using "main", the action clones the Tutor repository from the main branch and uses pre-built Tutor images that are published daily to Docker Hub. These images include the latest changes from the master branch at the time of the build. This approach significantly reduces the execution time and conserves the runner's resources by eliminating the overhead of building images during the workflow.

  • Paths: Ensure that the paths provided in the inputs are relative to your plugin directory.

  • Optional Steps: Steps involving openedx_imports_test_file_path, openedx_extra_pip_requirements, fixtures_file, tutor_extra_commands_path, inline_tutor_plugins_folder and tutor_plugins are optional and will only run if the corresponding inputs are provided.

  • Tutor Versions: Use the matrix strategy to test your plugin against multiple Tutor versions, including the main build.

  • Dependencies: If your integration tests require additional dependencies, specify them in openedx_extra_pip_requirements or handle them within your shell_file_to_run.

  • Maintaining Python Versions:

    It's crucial to align the Python version in your virtual environments with the versions supported by the specified Tutor versions. Mismatched Python versions can lead to unexpected errors during Tutor operations and plugin integrations.

    If you need to specify a Python version different from the default provided by the runner, you can add an input to set the desired Python version. For example:

    - name: Run Integration Tests
      uses: eduNEXT/integration-test-in-tutor@main
      with:
        app_name: 'eox-test'
        tutor_version: ${{ matrix.tutor_version }}
        python-version: '3.X'  # Specify the required Python version here

    If you're testing against multiple Tutor versions that require different Python versions, you can consider expanding your matrix to include Python versions. For example:

    strategy:
      matrix:
        include:
          - tutor_version: '<18.0.0'
            python_version: '3.8'
          - tutor_version: '<19.0.0'
            python_version: '3.9'
          - tutor_version: 'main'
            python_version: '3.10'

    Then, adjust the step to use both matrix.tutor_version and matrix.python_version.

    steps:
      - name: Run Integration Tests
        uses: eduNEXT/integration-test-in-tutor@main
        with:
          app_name: 'eox-test'
          tutor_version: ${{ matrix.tutor_version }}
          python_version: ${{ matrix.python_version }}  # Utilize matrix.

Contributing

Contributions are welcome! Please open an issue or submit a pull request for any enhancements or bug fixes.

About

A Github action to test your plugin in Tutor (Open edX distribution)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •