This project is a judger system designed to compile and run C++, Java, and Python programs inside Docker containers. It ensure that the program stays within specified time and memory limits and handles the cleanup of generated files and artifacts. It also takes input files and compares them with the expected and actual output of the code, providing an appropriate verdict for the program (i.e., TLE, MLE, RE, CE, AC, WA).
-
Isolation using Docker to ensure a secure and consistent execution environment.
-
Compile and run C++, Java, and Python programs inside Docker containers.
-
Handle input test case data for the programs.
-
Compare expected and actual output to provide verdicts (TLE, MLE, RE, CE, AC, WA).
-
Clean up generated files and artifacts after execution.
Clone the project
git clone https://github.com/AbhishekBhosale46/OnlineJudge-Judger
Go to the project directory
cd judger
Install dependencies
pip install docker
To run the judger, you need to call the run_judger function with the appropriate parameters. Here's an example of how to use it:
from src import judger
print(
judger.run_judger(
language='cpp',
time_limit=1,
memory_limit=128,
judger_vol_path=r"PATH_TO_CONTAINER_VOL",
src_code_path=r".\tests\cpp\cpp_test.cpp",
expected_out_path=r".\tests\cpp\cpp_op.txt",
)
)
print(
judger.run_judger(
language='py',
time_limit=1,
memory_limit=128,
std_in="10\n5",
judger_vol_path=r"PATH_TO_CONTAINER_VOL",
src_code="a=int(input())\nb=int(input())\nprint('Sum is', a+b)",
expected_out="Sum is 15"
)
)
Contributions are welcome! Please fork the repository and submit a pull request for any improvements or bug fixes.
- Fork the repository.
- Create a new branch (git checkout -b feature-branch).
- Make your changes.
- Commit your changes (git commit -m 'Add some feature').
- Push to the branch (git push origin feature-branch).
- Open a pull request.