Skip to main content

Zucchini is an automatic grader tool for use in grading programming assignments.

Project description

Zucchini

https://img.shields.io/pypi/v/zucchini.svg https://travis-ci.com/zucchini/zucchini.svg?branch=master Documentation Status Updates

Zucchini is an automatic grader tool for use in grading programming assignments.

Installation

$ pip install --user zucchini
$ zucc --help

Getting Started with Development

After cloning this repo and installing virtualenv, run

$ virtualenv -p python3 venv
$ . venv/bin/activate
$ pip install -r requirements.txt
$ pip install -r requirements_dev.txt
$ zucc --help

Features

  • Unified grading infrastructure: eliminates maintenance load of ad-hoc per-assignment graders

  • Separates test results from computed grades: graders provide test results which are stored on disk, and then zucchini calculates grade based on the weight of each test. That is, graders do not perform grade calculation; they only gather information about students’ work

  • Simple configuration: update one YAML file and store your graders in git repositories for all your TAs

  • Relative weighting: no more twiddling with weights to get them to add up to 100

  • Import submissions from Gradescope, Canvas Assignments, or Canvas Quizzes

  • No more copy-and-pasting grades and commments: automated upload of Canvas grades and gradelogs

  • Flatten (extract) archived submissions

  • Gradescope integration: generate a Gradescope autograder tarball for an assignment with one command

Credits

  • Austin Adams (@ausbin) for creating lc3grade, which eventually became zucchini

  • Cem Gokmen (@skyman) for suggesting converting lc3grade into a generalized autograder for more than just C and LC-3 homeworks, and creating the initial structure of zucchini

  • Patrick Tam (@pjztam) for implementing a bunch of graders, gradelogs, and gradelog upload

  • Kexin Zhang (@kexin-zhang) for exploring Canvas bulk submission downloads and for creating the demo downloader, which changed our lives

  • Travis Adams (@travis-adams) for nothing

History

0.1.0 (2017-12-17)

  • First release on PyPI.

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

zucchini-2.2.21.tar.gz (75.1 kB view details)

Uploaded Source

Built Distribution

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

zucchini-2.2.21-py2.py3-none-any.whl (75.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file zucchini-2.2.21.tar.gz.

File metadata

  • Download URL: zucchini-2.2.21.tar.gz
  • Upload date:
  • Size: 75.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for zucchini-2.2.21.tar.gz
Algorithm Hash digest
SHA256 8843ead78b38cc6bedb0e405aaf0940117161384511e69c955da32805343a44c
MD5 30d497f696575927cc2e739db9e9b8df
BLAKE2b-256 87309f8dae9268c117703eac7dc835ac2a5d6163c16dac3e8f789a4285046497

See more details on using hashes here.

File details

Details for the file zucchini-2.2.21-py2.py3-none-any.whl.

File metadata

  • Download URL: zucchini-2.2.21-py2.py3-none-any.whl
  • Upload date:
  • Size: 75.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for zucchini-2.2.21-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 1e752a6f296dd5653bd0a3d5b68003ea872381db8fab0b1bf7db2ff229c54c7d
MD5 16da00f88491f556b8a7bd616cd9c7c2
BLAKE2b-256 45fe095c17b75511942143f14c10f7c977a04ee74aaa7bac84262fb27422ac50

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