Skip to content

vanderbilt-redcap/redcap_cypress_docker

Repository files navigation

REDCap Cypress Developer Toolkit

The REDCap Cypress Developer Toolkit provides an automated framework for validating REDCap’s core functionality. Automated testing helps ensure system integrity, reduces manual testing burden, and supports institutions in meeting regulatory compliance requirements (e.g., 21 CFR Part 11).

The toolkit was the brain child of Adam De Fouw, who deserves most of the credit for getting it off the ground. This and all related projects were originally developed by him and the RSVC Automated Testing Subcommittee (ATS). They are now maintained by Vanderbilt University Medical Center (VUMC). RSVC continues to contribute to updates and actively uses the toolkit for REDCap validation efforts.

This repository includes scripts to download all the necessary components for a developer to begin developing automated feature tests on their developer machine. This toolkit is based on the industry-standard Cypress Testing Framework.

If you'd like to participate in our ongoing automation efforts, see our Contribution Guidelines.

What is Automated Testing?

Automated testing involves executing pre-scripted tests against a REDCap instance to validate that core functionality works as expected. These tests:

  • Ensure system stability after software updates
  • Reduce redundant manual testing for common workflows
  • Support regulatory compliance efforts by providing structured validation

Tests are executed in a controlled test environment and should never be run on a production system, as they modify project data.

How Are Automated Tests Selected?

Not all REDCap features are suitable for automation. When determining which features should be tested automatically, the RSVC considers:

  • Reproducibility – Can the test be executed consistently across institutions?
  • Regulatory Impact – Does the feature support compliance with 21 CFR Part 11?
  • Complexity – Is automation feasible, or does the feature require manual review?
  • Test Stability – Does the test produce reliable results across different REDCap versions?

For each REDCap release, RSVC reviews system changes and determines which features should be tested manually and which can be automated.

Overview

Developer Toolkit

Software Prerequisites:

The following steps are intended to help set up a testing environment on a personal computer in order to aid with development and contribute changes back to this project. If instead you're hoping to re-run all automated tests at your institution, see Creating An Automated Testing Environment.

A developer needs the following software on their machine before installing this Developer Toolkit.

  • Git (version control)

  • Rancher Desktop - This is a drop-in replacement for Docker Desktop, which is still supported but not allowed at some organizations (like VUMC).

    • You may want to set Rancher to Automatically start on login and Start in the background under Preferences -> Application -> Behavior
    • If you've previously had Docker Desktop installed, you may have to run docker context use default before Rancher will work as expected.
  • Node.js - available for Windows, macOS, Linux

  • VS Code - This is the recommended IDE, but others may be used as well (e.g. PhpStorm). Be mindful that Visual Studio Code is most often referred to as VS Code in part to distinguish it from a different application simply called Visual Studio which we do not use.

  • Cucumber Extension for VS Code by cucumber.io

SSH Key in GitHub Account

You will need to place your public key on GitHub for this process to work correctly.

To generate a key on your local machine, most of time the command is:

ssh-keygen

Please consult GitHub's SSH documentation for more information: GitHub SSH Key Instructions

Specifically, you will need to

Developer Toolkit Installation Instructions:

  1. Open a bash compatible command prompt. On Windows, Git Bash is supported. On Mac, the built-in Terminal app is supported.
  2. Navigate to the directory where you want this project to live (e.g. your home directory). If you don't have experience navigating between different directories in a terminal, ask the AI of your choice to teach you.
  3. Run the following command to download a copy of this project to the current directory in your terminal:
    • git clone git@github.com:vanderbilt-redcap/redcap_cypress_docker.git
    • If you see a failure message that says you do not have permissions or mentions a public key, you likely need to setup an SSH Key in GitHub Account.
  4. Start the test environment by running the the following command:
    • ./run.sh
    • If you see an error message about Docker not running or an "error during connect", you will need to start your chosen docker app (likely Rancher or Docker Desktop). If it is started already, you may need to restart it and/or your computer.
  5. You will be prompted for your username and password to the REDCap Community website in order to download REDCap the first time you set up your test environment and after certain updates.
  6. The Cypress window should open after a few minutes, allowing you to select & run any RSVC feature test. Cypress will open much faster on subsequent runs.

Strategies For Developing & Debugging Features

  1. The single most useful tool is Continue Last Run.feature, found under redcap_cypress/cypress/features. The REDCap database is normally cleared between feature runs. However, executing this special feature file immediately runs whatever steps you place in it against the current state of the database. Rather than repeatedly running any features files you're working on from the beginning, you should use this file to test a small number of steps at a time to greatly reduce iteration time and significantly speed up your workflow.

  2. Execution can be paused in the middle of a feature to check details or perform manual actions by adding the following step: And I want to pause. To continue execution, press the play button in the Cypress UI.

Updating The Test Environment:

You should perform the following steps periodically to ensure your local environment includes the latest changes:

  1. Read the portion of the changelog for all REDCap versions since the one you last tested using cypress. This is important to stay informed and consider breaking changes that may be required when you choose to update to the latest version.
  2. Close cypress (if it's open)
  3. Run ./update.sh
  4. Run ./run.sh to open cypress again

Changing REDCap Versions

The master branch of redcap_cypress will be checked out by default. This will use the latest REDCap release version that has been tested. If you would like to test a different REDCap version, perform the following steps:

  1. Determine which redcap_cypress branch is closest to the REDCap version you'd like to test.
    • If you have github access to REDCap's source code you may also test REDCap changes that have not yet made it into a release yet using the dev branch.
    • While using the dev branch, you may also user your own modified version of REDCap's source code using the following command at any time (including while Cypress is running):
      • ./copy-redcap-source-to-container.sh path/to/redcap_v#.#.#
        
      • Keep in mind that this command must be run every time you change a REDCap source file. It is possible to avoid this by uncommenting the redcap_source volume in docker-compose.yml, but that is not recommended as it will come with a significant performance hit (especially on Windows).
  2. Navigate to the redcap_cypress directory and run git checkout <your-desired-branch> to checkout that branch
  3. If a branch does not exist for the exact REDCap version you'd like to test, you can modify this project to run on that version by editing the redcap_cypress/cypress.env.json.example file and updating the redcap_version variable to your desired REDCap version. This variable is copied from cypress.env.json.example into cypress.env.json every time ./run.sh is called so that the expected version of REDCap is used after ./update.sh, git pull, git checkout, etc.
  4. If you have cypress open, close it.
  5. Run ./run.sh

Contribute to Feature Tests:

  1. Create your own fork of redcap_rsvc that is based upon https://github.com/vanderbilt-redcap/redcap_rsvc

  2. Configure the cloned redcap_rsvc repository as needed to match your own Fork.

cd redcap_cypress/redcap_rsvc
git remote rename origin upstream
git remote add origin <your_fork_url_here>

Having your own fork enables you to issue pull requests to vanderbilt-redcap/redcap_rsvc after you complete a feature.

Additional Information

For more information about the innerworkings, see the REDCap Cypress Test Suite Docs

About

Start here to work with REDCap Cypress Test Framework on a developer machine. This is a Developer Toolkit to install a test environment to run REDCap Cypress against an instance of REDCap.

Resources

License

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages