bash-it/test
Nils Winkler 43ef48544d
Merge pull request #1627 from NoahGorny/fix-alias-completion-plugin
plugins: Fix quotes around prec_word agruments
2020-07-15 08:54:56 +02:00
..
bash_it test: Make `rsync` optional 2020-05-11 02:30:10 +02:00
completion completion: Add bash-it doctor completion 2020-06-23 15:12:43 +03:00
fixtures Fixed comparison for SVN info parameter 2020-06-17 10:26:47 +02:00
install Refactored test setup code 2020-04-21 08:25:40 +02:00
lib lib: log: Insert log level before message prefix 2020-07-02 21:11:40 +03:00
plugins test: Add alias-completion plugin test 2020-06-28 11:37:08 +03:00
themes tests: Include lib log 2020-07-02 21:11:40 +03:00
README.md Updated test readme 2020-04-22 11:19:18 +02:00
run Updated GNU parallel detection 2020-04-21 08:25:40 +02:00
test_helper.bash test: Make `rsync` optional 2020-05-11 02:30:10 +02:00

README.md

Testing with Bats

Overview

The Bash-it unit tests leverage the Bats unit test framework for Bash. There is no need to install Bats explicitly, the test run script will automatically download and install Bats and its dependencies.

When making changes to Bash-it, the tests are automatically executed in a test build environment on Travis CI.

Test Execution

To execute the unit tests, please run the run script:

# If you are in the `test` directory:
./run

# If you are in the root `.bash_it` directory:
test/run

The run script will automatically install if it is not already present, and will then run all tests found under the test directory, including subdirectories.

To run only a subset of the tests, you can provide the name of the test subdirectory that you want to run, e.g. like this for the tests in the test/themes directory:

# If you are in the root `.bash_it` directory:
test/run test/themes

By default, the tests run in single-threaded mode. If you want to speed up the test execution, you can install the GNU parallel tool, which is supported by Bats. When using parallel, the test/run script will use a number of threads in parallel, depending on the available CPU cores of your system. This can speed up test execution significantly.

Writing Tests

When adding or modifying tests, please stick to the format and conventions of the existing test cases. The test_helper.bash script provides a couple of reusable helper functions that you should use when writing a test case, for example for setting up an isolated test environment.