Skip to main content

A collection of parameterizable tests for automatic grading.

Project description

Generic Grader

A collection of generic tests for grading programming assignments.

This project is still in very early development. Expect breaking changes.

Installation

pip install generic-grader

Usage

  1. Name the reference solution reference.py, and place it in a tests subdirectory of the directory containing the student's code.

  2. Add a configuration file for the assignment in the tests subdirectory (e.g. tests/config.py). It might look something like this:

    from parameterized import param
    from generic_grader.style import comments # Import the tests you want to use
    from generic_grader.utils.options import Options
    
    # Create tests by calling each test type's build method.
    # They should all start with the word `test_` to be discovered by unittest.
    # Adding a number after `test_` can be used to control the run order.
    # The argument is a list of `param` objects, each with an `Options` object.
    # See the Options class for more information on the available options.
    test_01_TestCommentLength = comments.build(
       [
          param(
              Options(
                  sub_module="hello_user",
                  hint="Check the volume of comments in your code.",
                  entries=("Tim the Enchanter",),
              ),
          ),
          param(
              Options(
                  sub_module="hello_user",
                  hint="Check the volume of comments in your code.",
                  entries=("King Arthur",),
              ),
          ),
       ]
    )
    
  3. Run the tests.

    python -m unittest tests/config.py
    

Contributing

  1. Clone the repo onto your machine.

    • HTTPS

      git clone https://github.com/Purdue-EBEC/generic-grader.git
      
    • SSH

      git clone git@github.com:Purdue-EBEC/generic-grader.git
      
  2. Set up a new virtual environment in the cloned repo.

    cd generic-grader
    python3.12 -m venv .env3.12
    
  3. Activate the virtual environment. If you are using VS Code, there may be a pop-up to do this automatically when working from this directory.

    • Linux/macOS

      source .env3.12/bin/activate
      
    • Windows

      .env3.12\Scripts\activate
      
  4. Install tesseract-ocr

  5. Install ghostscript

  6. Install the package. Note that this installs the package as editable, so edits will be automatically reflected in the installed package.

    pip install -e .[dev]
    

    or

    uv sync --extra dev
    
  7. Install the pre-commit hooks.

    pre-commit install
    
  8. Run the tests.

    pytest
    
  9. Make changes ...

  10. Deactivate the virtual environment.

deactivate

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

generic_grader-0.2.7.tar.gz (149.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

generic_grader-0.2.7-py3-none-any.whl (72.7 kB view details)

Uploaded Python 3

File details

Details for the file generic_grader-0.2.7.tar.gz.

File metadata

  • Download URL: generic_grader-0.2.7.tar.gz
  • Upload date:
  • Size: 149.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.18 {"installer":{"name":"uv","version":"0.9.18","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for generic_grader-0.2.7.tar.gz
Algorithm Hash digest
SHA256 55119c8c6ac48e59f460081f6a1046e1b2290dce26083f736148e254cb3627a8
MD5 d10dd2094b9f649f2d89ed4491b5efab
BLAKE2b-256 97e5f55f10db5e6b079b3b79f3a586ab115abdfe0a5f45be6969c44992da79e4

See more details on using hashes here.

File details

Details for the file generic_grader-0.2.7-py3-none-any.whl.

File metadata

  • Download URL: generic_grader-0.2.7-py3-none-any.whl
  • Upload date:
  • Size: 72.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.18 {"installer":{"name":"uv","version":"0.9.18","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for generic_grader-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 1ac068b4d40b63d99b5b98b7a23f5c73c72b26a2a39af6d054bfdc082913a574
MD5 b27e611bd211c27fa2b4d3fd226eeceb
BLAKE2b-256 a0520ad8e84c2457a77238f9ea4b1982cd791f96c92140da56d09d605dffab41

See more details on using hashes here.

Supported by

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