Skip to main content

CLI tool for robust autograder chaff testing

Project description

brunotest

A coursework templating and testing engine to consolidate assignment code and ensure robust assignment quality.

The idea behind this framework is that it woul allow us to write only one solution code, and then carefully work out stencil around it (in fact, have the stencil generated automatically from the solution code).

The idea on how to do this is to use Region tags in the code, and

All of the templating will be done in a __brunotest__ hidden folder (that could be gitignored). The general use case is as follows (we'll say with the fibonacci example given in examples):

  1. Define our stencil/chaff/solution code
  2. Run brunotest to run the solution code against the tests
  3. Run brunotest stencil to run the compiled stencil code against the tests
  4. Run brunotest [chaff name] to run the compiled chaff code against the tests.
  5. Run brunotest all to run all of the code (solution, stencil, chaffs) against the tests.

Ideally, this would also be enhanced by a VSCode extension that could allow you to more easily see the different chaffs/stencil alongside the current document you are editing (maybe similar to how Markdown preview works).

Some other considerations/definitions for now:

  1. The chaff implementations will be stored in .chaff files, and:
    1. Do not require all of the regions defined in the solution to be overwritten, but regions that are not specified will remain the same.
    2. Can (somehow?) define which tests should fail and with what values, likely at the top?
      1. This may be somewhat challenging because we have to incorporate failing partial tests, test names, etc.
  2. The stencil code will be in a single .stencil file in the root directory (error on multiple found).
    1. The stencil also does not have to specify every distinct region to overwrite, but those which are not specified will be left blank.

Gradescope Autograder Specifications

The gradescope autograder, with the configuration that we use it in, has the following directory structure:

/autograder/ # Base Directory
/autograder/student # Student submission
/autograder/solution # Solution code 

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

brunotest-0.1.1.1687008168.tar.gz (7.7 kB view hashes)

Uploaded Source

Built Distribution

brunotest-0.1.1.1687008168-py3-none-any.whl (8.4 kB view hashes)

Uploaded Python 3

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