my own CS111 grader.
Project description
MyGrader - Your Own CS111 Grader
The MyGrader project is a custom testing framework designed to help you test your user-defined functions efficiently. It generates test cases, runs them against your functions, and provides detailed summaries of the test results. This can be particularly useful for students and developers working on programming assignments.
MyGrader is currently in the alpha development stage. It's actively being worked on and improved. Feel free to contribute and help make it even better!
Switching to Stable Version
If you're currently on the candidate
branch and want to switch to a stable version of MyGrader, you can follow these
steps:
-
Browse the Releases
Visit the Releases page on GitHub to find the list of available releases.
-
Select a Stable Release
From the list of releases, choose the stable version you want to switch to. Stable versions are typically tagged with names like
stable0.44
.
Table of Contents
Usage
-
Define Your User-Defined Function
Begin by defining the user-defined function you want to test. For example, let's say you have a function
calculate_new_price
that calculates the new price of an item after applying a discount:def calculate_new_price(old_price): # ... (your code here) ... return new_price
-
Use the Tester Class
Utilize the
Tester
class from MyGrader to test your function. Create a Python script (e.g.,test_my_function.py
) with the following code:from mygrader import mygrader # Define your user-defined function def calculate_new_price(old_price): # ... (your code here) ... return new_price if __name__ == '__main__': tester = mygrader.Tester(year=2023, runtime_limit=0.4, log_option="print") tester.run_test(calculate_new_price, num_test_cases=1000)
-
View the Test Summary
After running the tests, you'll see a summary of the results. If you set
log_option
to'print'
, the summary will be printed to the console. If you set it to'write'
, the summary will be saved to a file namedtest_summary.md
.
Installation
Install the MyGrader package using pip:
pip install mygrader
Attributes
year
: The year of class (Assignments are assigned by year).runtime_limit
: The maximum runtime allowed for test cases (in seconds)log_option
: The logging option ("print" or "write") for the test summary.debug
: IfTrue
, enable debug mode for additional information.
Methods
run_test(user_func, num_test_cases=100, show_table=False)
: Run tests for the specified user-defined function.return_type(func)
: Return the return type of a given function.capture_printed_text(func, *args)
: Capture the printed output of a function.__dir__()
: Return the list of available functions for the given year.__repr__()
: Return a string representation of available functions for the given year.__str__()
: Return a string representation of the Tester class for the given year.
Contributing
Contributions to the MyGrader project are welcome! If you encounter issues or have ideas for improvements, please open an issue or submit a pull request on GitHub.
License
This project is licensed under the MIT License - see the LICENSE file for details.
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
File details
Details for the file mygrader-0.45a4.tar.gz
.
File metadata
- Download URL: mygrader-0.45a4.tar.gz
- Upload date:
- Size: 15.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 39aaed77184cfb7b56d9a836c9485c322b6c2bc20b42d7e901012bcc80923403 |
|
MD5 | abbe76904a99e33cf1d1da2d7afdc42e |
|
BLAKE2b-256 | 2568bdfecc3222c3ce5d3319aeb9da57a41c4cbe7481681302d6022b2a52e2c5 |