Skip to main content

my own CS111 grader.

Project description

MyGrader - Your Own CS111 Grader

Maintainability Rating Quality Gate Status

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.

Table of Contents

Usage

  1. 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
    
  2. 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)
    
  3. 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 named test_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: If True, 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 Information

Project Status

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!

Project Classifiers

  • Development Status: 3 - Alpha
  • Intended Audience: Developers
  • License: MIT License
  • Programming Language: Python 3.8, 3.9, 3.10, 3.11

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mygrader-0.42a0.tar.gz (12.1 kB view details)

Uploaded Source

File details

Details for the file mygrader-0.42a0.tar.gz.

File metadata

  • Download URL: mygrader-0.42a0.tar.gz
  • Upload date:
  • Size: 12.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for mygrader-0.42a0.tar.gz
Algorithm Hash digest
SHA256 c46c1ac780a88781c382be3c7ce03b099061eedcd518c805c18400da8998b16f
MD5 e9f07ae6f5118a08790144ea1cd45255
BLAKE2b-256 88e30a4a8eab1ebff0e540ce5964d537656047f03534a7216563fb3fb6692cb0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page