This project is designed to streamline the process of testing your code against expected outputs on competitive programming platforms such as Codeforces. It helps you manage bigger and multiple test cases efficiently and aids in debugging.
- Automates the testing process for multiple test cases.
- Simplifies debugging by comparing your output with the expected output.
- Provides a clear structure to manage inputs and outputs.
-
Clone this repository:
git clone https://github.com/AbdulselamAbdurehman/Automated-Testing.git
-
Navigate to the cloned directory:
cd Automated-Testing
- Copy and paste the sample inputs into the
input.txt
file. - Copy and paste the expected outputs into the
output.txt
file. - Ensure your solution code is in
main.py
. - Run the handler script:
python handler.py
- The handler script assumes that the first line of the input file contains the number of test cases. Comment out or remove the debugging prints before running the handler.
- There should be only one valid output per test case. This means the handler will fail where there can be multiple valid answers and you are required to give just one among the possible.
When your code fails on some tests, handler will tell you where your output differed from the expected output. To debug your code with print statements, run your test cases directly in main.py
. Keep in mind that any debugging prints will confuse the handler and cause it to take is as an error.
Here’s an example for testing a program that prints the square of a given number for the given number of tests:
3
2
5
7
4
25
49
t = int(input())
for _ in range(t):
print(int(input())**2)
- Ensure your
input.txt
,output.txt
, andmain.py
are set up as shown above. - Run the handler script:
python handler.py
- The handler will execute
main.py
, capture its output, and compare it tooutput.txt
, providing feedback on which test cases passed or failed:All tests passed
Feel free to customize the project further to suit your needs or Request Addional programming languages support!