This testing tool allows you to execute and record any commands inside a docker containr, replay them, and validate whether your results are accurate.
The installation of the tool is very simple. All you need to do is clone the repository and start using it!
git clone https://github.com/manticoresoftware/clt.git
cd clt
./clt help
We have prebuilt binaries for use in a Linux environment, for both amd64 and arm64. It's automatically detected based on the platform you're using. Binaries for OSX and Windows are currently not available, but you can build them for your purpose if required. Remember, all tests run in a container environment using Docker, so your machine should have Docker installed.
- Begin by recording your test in interactive mode by executing the
record
command as follows:
./clt record centos:7
Here, centos:7 is the docker image that you want to use for tests. You can incorporate the --no-refine
option if you wish to omit the refine step and execute the test later.
You can see the file which is used to write your recording as a first string, it looks like this:
Recording data to file: ./tests/centos:7_20230714_161043.rec
-
Next, perform various commands in interactive mode. Once you're done, press
^D
to stop and record your test results. -
To validate and replay it, execute the following command:
./clt test -t ./tests/centos:7_20230714_161043.rec -d centos:7
echo $?
./tests/centos:7_20230714_161043.rec
is your actual pass to the file you recroded on the step 1.
This will display the exit code and print the diff (if outputs vary while you replay it). If the exit code equals 1, everything is fine. Otherwise, you should examine the diff created by the cmp tool and introduce the necessary changes to the file, provided you executed it with the --no-refine
option.
The -d
flag is used for debug output and displays the diff, not just the exit code.
You can locate the complete output replayed in the same file name but with a .rep extension. In this case, it's test.rep.
CLT provides a ready-to-use GitHub action to run all tests located in your tests
folder, or any that you specify. Here is an example of how to use it:
name: CLT tests
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
jobs:
clt:
name: Run CLT tests
strategy:
fail-fast: false
matrix:
image: [ "ubuntu:bionic", "ubuntu:focal", "ubuntu:jammy", "debian:buster", "debian:bullseye", "debian:bookworm" ]
runs-on: ubuntu-22.04
steps:
- uses: manticoresoftware/[email protected]
with:
image: ${{ matrix.image }}
test_prefix: test/clt-tests/
run_args: -e TELEMETRY=0
The code is self-explanatory and covers almost everything that the current template offers.
Once you've successfully captured your commands in interactive mode and stored them into a .rec
file, the next step is to refine the test (if required). This is achieved by running the comparator which highlights the disparities between the initial output and replayed output.
For creating dynamic content that effortlessly passes tests, you can utilize regular expressions (regex). Position the appropriate regex within the command output section, enclosed between #!/
and /!#
marks. To illustrate, the regex #!/[0-9]+/!#
can be utilized to match any numerical value composed of digits 0 through 9, irrespective of its length.
To streamline this process, we've introduced patterns. We already offer several predefined patterns within the .patterns
file. However, you possess the capability to define your own by appending your definitions to the .patterns
file located at the root of your project. The format must comply with the VARIABLE NAME[space]RAW REGEX
rule. A typical .patterns
file may resemble:
SEMVER [0-9]+\.[0-9]+\.[0-9]+
YEAR [0-9]{4}
IPADDR [0-9]+\.[0-9]+\.[0-9]+\.[0-9]+
COMMITDATE [a-z0-9]{7}@[0-9]{6}
Upon defining, you can use %{IPADDR}
as a substitute for #!/[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+/!#
to match any IP address occurring in outputs.
We've also integrated an additional feature known as "Reusable blocks". Simply extract your flow comprising inputs and outputs into a file bearing a .recb
extension and incorporate it within the main .rec
file by inserting the following code:
––– block: block/my-block –––
This command will seek the block/my-block.recb
file within the directory relative to the .rec
file where it's positioned.
By default, we attempt to locate the nano
or vim
editors during the refine stage. To customize this, you can set the CLT_EDITOR
environment variable to any editor of your choosing. For instance, to run with vscode, simply input export CLT_EDITOR=vscode
, save it to your .bashrc
, and everything will open in your preferred editor.
Build aarch and amd64 static cross for Linux:
./bin/cross-build
git add .
git commit -m '...'
This one-liner removes control characters and console codes/colors from recorded terminal output:
cat output.rec | sed -e "s/\x1b\[.\{1,5\}m//g"
- Use
^D
only once when closing yourclt
environment; for other exits, useexit
. - Avoid using
^C
,^V
,^Z
, and other magic controls as they might not function correctly. - Reverse search (
^R
) is currently unsupported, so do not use it to record. - Complete your tests in the
clt>
shell and press^D
to terminate the session and finish recordings. - Use a simple default terminal, like iTerm. Using the VS Code terminal may lead to unusual behavior due to various settings.
- Currently, there is a limitation that requires entering commands only when the prompt is available. This can lead to inaccurate result validation due to the TTY workflow.
Not all keyboard and Bash controls are supported. Here is the list of supported keystrokes:
- Input characters from the keyboard.
- Left and right arrows.
- Backspace and delete.
- CTRL+a and CTRL+e
To re-run and confirm that tests are successful, we look for .rec files and compile them into a ready-to-use version on the fly. We then utilize these compiled versions to execute each command in sequence, generating a .rep file. Subsequently, we use the cmp tool to compare the results with the compiled version of the .rec files.
There are several types of files:
Extension | Description |
---|---|
.rec | Original record of the input commands and their outputs. It may contain links to block files. |
.recb | Record block file, contains reusable blocks that can be included in .rec files. |
.rep | Replay file that contains the results of replaying the .recc file. |