Skip to main content

A general-purpose autograder written primarily in Python 3.

Project description

lograder

A Python library for building programming assignment autograders. The central abstraction is a Pipeline of Step instances -- each step validates input, runs a process, and passes results forward.

Input -> Check -> Mixin -> Build -> Test

Installation

pip install lograder
# or for development:
pip install -e ".[dev]"

Minimal example

from pathlib import Path
from lograder.pipeline.config import config
from lograder.pipeline.input.local_directory import LocalDirectory
from lograder.pipeline.check.project.simple_project import CMakeManifestCheck
from lograder.pipeline.build.cmake import CMakeBuild
from lograder.pipeline.test.output_compare import OutputCompareTest, OutputCompareCase
from lograder.pipeline.score import TestCaseScorer, AllOrNothingScorer, GradescopeConfig
from lograder.pipeline.pipeline import Pipeline

# Define test cases
cases = [
    OutputCompareCase(name="hello", args=[], expected_stdout="Hello, World!\n"),
    OutputCompareCase(name="echo",  args=["foo"], expected_stdout="foo\n"),
]

# Build the pipeline
pipeline = Pipeline()
pipeline.add(inp   := LocalDirectory())
pipeline.add(check := CMakeManifestCheck())
pipeline.add(build := CMakeBuild())
pipeline.add(tests := OutputCompareTest("hello", cases))

# Attach scorers
build.scorer = AllOrNothingScorer(10.0, label="Build")
tests.scorer = TestCaseScorer({"hello": 40.0, "echo": 50.0}, label="Correctness")

# Run
with config(root_directory=Path("/autograder/submission")):
    score = pipeline()

score.write_results_json(config=GradescopeConfig(visibility="visible"))

Documentation

Doc Contents
Getting started First autograder in 5 minutes
Concepts Pipeline, Step, Result, Manifest, Artifact
Input LocalDirectory, EnvironmentConfig
Check Manifest checks, SourceCheck, constraints
Build CMakeBuild, MakefileBuild, BashScriptBuild, PrebuiltArtifacts
Test All 9 test step types with full examples
Scoring Scorers, Gradescope output, results.json
Process layer TypedExecutable, CLIArgs, registry
Output / layouts Logging, HTML report, custom layouts
Examples Complete worked autograders

Design principles

  • Errors as values. Steps return Result[Ok, Err] rather than raising. A fatal Err return stops the pipeline; a yielded Err is logged and execution continues.
  • Typed data flow. Each step declares its input and output types. pipeline.validate_step_types() catches mismatches before the first submission runs.
  • No magic. Every process invocation goes through a TypedExecutable with validated CLIArgs. You can see exactly what command was run and what it produced.
  • Library only. lograder has no CLI and no service. You write a Python script; lograder is a collection of reusable building blocks.

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

lograder-0.2.3.tar.gz (108.5 kB view details)

Uploaded Source

Built Distribution

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

lograder-0.2.3-py3-none-any.whl (164.1 kB view details)

Uploaded Python 3

File details

Details for the file lograder-0.2.3.tar.gz.

File metadata

  • Download URL: lograder-0.2.3.tar.gz
  • Upload date:
  • Size: 108.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for lograder-0.2.3.tar.gz
Algorithm Hash digest
SHA256 7943f201ec2d3e81f6d69edeb869e04ac824eb67a4e177a2e695ad2d59a52cff
MD5 dd0820c45a49e765c30f315f5aff72f0
BLAKE2b-256 2f336cfb8c7c70a87d6afb2056c1029145b7eb4f9f87decee3d03693f37fd79f

See more details on using hashes here.

File details

Details for the file lograder-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: lograder-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 164.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for lograder-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ac443b3c83bda715eee1de32e2a35bf7d407dd8912bc16e4647c93f317e33a5d
MD5 7402df57be0d36adf16a32a8d61b4d51
BLAKE2b-256 933f6a64aaa947cfa62c71044520331b70a6b7b6c6b1866c3343345339994378

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