CLI tool for testing algorithms.
Project description
Tess
Manage your algorithms' implementations to be run against prepared and auto-generated test cases. Apply Stress Testing to detect issues when implementing new algorithms. Compare algorithms written in different languages with ease.
Installation
Tess hasn't been tested on Windows, so if you are on a Windows machine, we recommend you to use a Linux distribution. You can access this link to learn how to install it.
Dependencies
Before installing Tess, please make sure you have installed these dependencies:
Download
Run the next command from your terminal to download and install Tess:
pip install tess-cli
Setup
After installing Tess and all its dependencies, it is recommended to enable the auto-completion feature for your terminal. Tess supports auto-completion for bash, zsh, and fish shells. Run the next command to create a shell script that will be used by your terminal to recognize Tess commands.
tess auto-complete /location/where/you/want/to/store/the/script.sh
A file named tess-completion.sh will be created at your specified
location. Now, you need to add the next line to your .bashrc or .zshrc file.
. /location/tess-completion.sh
Remember to replace the path with the one where the file was created in the previous step.
If you are using MacOSX you might have issues with the zsh terminal. If,
after sourcing from your .zshrc the auto-completion script you see an error,
or the Tess commands are not being auto-completed, you can add two extra lines
on top of the previous one to enable the auto-completion for the shell. Your
.zshrc file should look like this:
autoload -Uz compinit
compinit
. /location/tess-completion.sh
Now, you should be able to start using Tess with its auto-completion feature on.
Getting Started
After completing the installation and setup of the auto-completion feature, you're ready to go. Now, let's create your first Tess project for a very simple algorithmic problem, computing the sum of an array of numbers.
Project Initialization
The first step is to initialize a Tess project; for that, you have this command:
tess init -e
That command will create the required project structure for Tess to work. By
default, Tess will create a couple of sample files for you to test the tool but,
we want an empty project to work with, that's why the -e option.
If you want the sample files from one of the supported languages run this command:
tess init -l [py|cpp|java]
Now, you should see three directories (solutions, cases, build) and one
file named generator.py.
Project Structure
Any Tess project will have the next structure:
- Solutions: Here you have to save all your source files containing the implementations for a given algorithm. Avoid creating new sub-directories here, otherwise Tess won't be able to find your source files.
- Cases: This directory will contain files containing the test cases needed to
test manually our algorithms, this files usually are
.txtfiles but, you can use any valid input file extension. - Build: All the compiled files will be here.
This project structure is created by default, do not modify the location or name of any of the directories or the
generator.pyfile.
Running an Algorithm
To run an algorithm from the solutions directory you have to type the next
command:
tess run FILENAME [TESTCASE]
Where the FILENAME is the name of the source file of your algorithm, i.e.
sum.cpp and the TESTCASE is an optional argument, where you can specify the
name of one of the test cases that you have in you cases directory. Let's say
you have a sum.cpp file in your solutions directory and two test cases in
your cases directory (sample-1.in, sample-2.in); if you want to run all
your test cases you simply call the run command like this:
tess run sum.cpp
Without passing the TESTCASE argument, otherwise if you want to run the sample-1.in test case, you should pass it as the TESTCASE argument, like this:
tess run sum.cpp sample-1.in
Important: It's highly recommended to use the auto-completion script to find the available files for every command quick and easy. If you are not using this feature, remember to use the file names as arguments, not its absolute or relative paths.
Debug Mode
Tess has a simple yet, useful feature to allow you to debug your algorithms
using native comments. To use this feature you need to append the @log
annotation to your comments; this annotation will tell Tess to uncomment those
lines of code whenever you run the algorithm in debug mode, which can be done
using this option:
tess run --debug sum.cpp
Log Annotation Rules
For this annotation to work properly, please always append the annotation next to the open comment symbol used by the programming language of your preference. For single line comments you have to leave just one white space between the annotation and the actual code you want to be executed when the comments are removed; for block comments the annotation should be alone in the opening line.
Here you can see examples of how to use the annotation properly:
Python
def fn():
#@log print('This is a single line debug comment.')
"""@log
print('This is a block debug comment.')
"""
pass
Always try to keep the indentation correct when working with Python.
C++/Java
void fn() {
//@log std::cout << "This is a single line debug comment.\n";
/*@log
std::cout << "This is a block debug comment.\n";
*/
}
Stress Testing
To execute a stress testing you need at least two algorithms; one that will work as a Model and another one that will be the Solution to be tested. The model is usually a naive implementation to solve an algorithmic problem, this model could be very inefficient and slow but, will give us the right answer to the problem. On the other hand, we have the solution, which is the new, efficient and optimized algorithm that we've created. Often times, things does not work as expected and we are not going to have infinite number of prepared test cases to find bugs, here's where stress testing and Tess come in.
To execute the stress testing you can type in your terminal this command:
tess stress MODEL SOLUTION
Passing the names of the files that you want to treat as the model and the solution.
Important: When working with C++ or Java, remember to compile the source files before executing the stress testing. You can use this command to do so:
tess build [FILENAME]
The Generator
When you press <ENTER>, a prompt will ask you for some arguments:
Arguments (separated by spaces):
You can think of them like the arguments you pass to a console program, i.e.
./myprogram arg1 arg2. These arguments are used by the generator.py sitting
in the root of your Tess project. This generator file is the one responsible for
the creation of the auto-generated test cases that will be executed during the
stress testing process.
For instance, if you pass the next arguments to the stress testing command:
Arguments (separtaed by spaces): 10 Hello
You can access them from the generator file like this:
def test_case(args, random) -> str:
num = int(args[0]) # 10
greet = args[1] # Hello
pass
The arguments array is zero-indexed.
You can use those arguments to modify the behaviour of your randomly generated test cases.
The generator have a second parameter called random, this is just a reference of the random object used by Python to generate pseudo-random numbers.
You can change the seed of this random instance using the
--seedoption available from thestresscommand.
Finally, after you implement the logic needed to generate your desired test case, you have to return a string containing the test case with the required format to be read by your algorithms from the standard I/O.
If you initialize the project with the sample files, you can see a simple implementation of the generator that produces random test cases.
The Execution
At this point you should have these things ready:
- A model or naive (but correct) algorithm.
- A solution that you want to test for correctness.
- A generator that will produce strings following the input format needed by your algorithms.
Now, you can run the stress testing and hope that your new algorithm is correct.
The stress testing will run infinitely, you have to abort the process to stop
it by typing CTLR+C; or you can pass the --number option to the stress
command letting Tess know how many test cases do you want to created before
stopping the process.
One last option that you can pass to the stress command is the --line one.
This option is useful when some algorithms output does not need to be evaluated
completely. For example, you have an algorithms that outputs these two lines:
8
4 2
If you want to compare just the first line, you can use the command above telling Tess to just compare the first line when is executing the stress testing and ignore the second one. For this you can run the stress command like this:
tess stress model.py solution --line 1
Important: C++ and Java files are passed to the stress command with the names of their compiled versions, not their source files.
Usage
For a complete list of the commands, options, and usage of Tess, please use the help command:
tess --help
tess COMMAND --help
Contribute
Tess is the result of the testing practices learned from the Algorithmic Toolbox course offered by Coursera. It is a work in progress, aiming to help other students like me enrolled in the Data Structures and Algorithms Specialization to test their algorithms using the stress testing approach suggested in the course easing the process and allowing the students to use different programming languages to create their models and solutions.
How can I contribute?
Tess is a new tool looking to grow and help more students and anyone who is interested and needs to test algorithms in an efficient and simple way, without restricting you to use a particular programming language or IDE. Currently, Tess is supporting three programming languages, Python, C++, and Java; one of the main goals of Tess is to give support to more programming languages but, as the code base grows and more features are added, the need for a more reliable and flexible code is critical to achieving this. Here you can find a list of tasks that would help the project to grow and improve the user's experience:
- Unit testing: This is the top priority at this point.
- Testing and reporting issues: You can contribute using the tool and reporting any bugs to my email.
- Documentation: This documentation could be incomplete. Any contributions to improve it would be very helpful. The code is not documented, this is critical to make it easier for more developers to join in, task that I have to begin as soon as possible.
- OOP migration: Any contributions refactoring code to make it more object-oriented would be very appreciated.
Please feel free to contact me to report something else that is not part of this documentation or if you want more information about the project and how to contribute.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tess-cli-0.1.1.tar.gz.
File metadata
- Download URL: tess-cli-0.1.1.tar.gz
- Upload date:
- Size: 21.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.22.0 setuptools/51.1.2 requests-toolbelt/0.9.1 tqdm/4.55.2 CPython/3.8.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
88c434b1b4bde1f16afb39e2f9f664e551e280743b9065e8dcf88cda5b57bf32
|
|
| MD5 |
8d56150bd09d771f7ca94c07a7775647
|
|
| BLAKE2b-256 |
bcd98fca02a553bdf295f140259227e4461746e25dc40b18abd645c9172b09cb
|
File details
Details for the file tess_cli-0.1.1-py3-none-any.whl.
File metadata
- Download URL: tess_cli-0.1.1-py3-none-any.whl
- Upload date:
- Size: 22.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.22.0 setuptools/51.1.2 requests-toolbelt/0.9.1 tqdm/4.55.2 CPython/3.8.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eaace5b1ec2eded05dcf688f2b689f4e8ccda662501aa32cfefb4cf16830b6a5
|
|
| MD5 |
fe7cd8577da595b7a7bc91425375a26a
|
|
| BLAKE2b-256 |
6075ca3ed91ebe62938abba06d35409b95a60b9ca76eff41d6577f9752ff8f77
|