Skip to content

Latest commit

 

History

History
83 lines (49 loc) · 3.57 KB

File metadata and controls

83 lines (49 loc) · 3.57 KB

run-custom-tests

Executes arbitrary tests within a given directory; it runs a shell script by default, but can also run pnpm (for NodeJS) or cargo (for Rust).

Example

steps:
  - uses: giancosta86/aurora-github/actions/run-custom-tests@v5
    with:
      root-directory: client-tests

Remarks

  • You should not call this action for unit tests when using verify-rust-crate or verify-npm-package - they are automatically run by the workflow itself.

  • This action is already called by verify-rust-wasm to optionally run the tests in the client-tests directory.

  • This action is already called by verify-npm-package to optionally run the tests in the tests directory.

How it works

  1. If root-directory does not exist:

    • if optional is true, exit the action with no error

    • otherwise, crash the workflow

  2. Detect the test type and act accordingly:

    • If a file named like script-file exists in the root directory, run it using script-shell; consequently, there is no need to mark the file as executable

    • Otherwise, if a file named package.json exists in the root directory:

      1. run setup-nodejs-context with different inputs according to the dedicated-env flag:

        • if it is true, install run the action in full - passing the related inputs, such as frozen-lockfile and registry-url

        • otherwise, just install the package dependencies - forwarding the frozen-lockfile input

      2. run the verify script in the scripts section of package.json

    • Otherwise, if a file named Cargo.toml exists in the root directory:

      1. if the dedicated-env input is true, run check-rust-versions to enforce a specific Rust toolkit

      2. run cargo test with the --all-features flag

    • Otherwise:

      • if optional is true, exit the action with no error

      • otherwise, crash the workflow

Requirements

Inputs 📥

Name Type Description Default value
optional boolean Exit with no error if the tests cannot be run false
script-file string Relative path to the script file verify.sh
script-shell string The shell used to run script-file bash
dedicated-env boolean Set up a context-specific, dedicated environment false
registry-url string The URL of the npm registry Official npm registry
frozen-lockfile boolean Fail if "pnpm-lock.yaml" is missing or outdated true
root-directory string The directory containing the tests
shell string The shell used to run commands bash

Further references