Skip to main content

Some helpers to help writing correction bots, use by hackinscience.org.

Project description

Correction Helper

Project

This is just a set of tools to help writing correction bots in Python for Python.

It is used for hackinscience, but could be used elsewhere.

Security considerations

Running student code is probably really unsafe, unless you trust your students not to drop you a backdoor.

This projet does not help with security in any ways, maybe take a look at firejail if you have trust issues (Yes you can use correction-helper inside firejail).

Usage

To install it, run: pip install correction-helper.

In your checking code, you can use it like this:

The student_code decorator

This decorator is aimed to catch most problems that could happen in student code, use it simply as:

with student_code():
    their_function()

Find a more complete example in the examples/ directory.

Allowed parameters for student_code, and their default values

print_prefix="Your code printed:"

Message to display before the student prints (in case print_allowed is False or None).

It's allowed to give a list of strings, in which case they'll be separated by "\n\n", useful to render markdown paragraphs.

too_slow_message="Your program looks too slow, looks like an infinite loop."

Message to display in case the code runs slower than the given timeout (defaults to 1s).

It's allowed to give a list of strings, in which case they'll be separated by "\n\n", useful to render markdown paragraphs.

prefix=()

A prefix for print_prefix, exception_prefix, and too_slow_message=, usefull to deduplicate strings, like:

with student_code(
    prefix="While calling blahblah('bar')",
    print_prefix="it printed:",
    exception_prefix="it raised:",
    too_slow_message="it took more than 1s, had to kill it.",
):
    blahblah('bar')

friendly=False

To use, or not friendly-traceback instead of bare Python exceptions.

print_allowed=True

To allow or deny the student to print to stdout and stderr.

  • True: Prints are allowed (and displayed).
  • None: Prints are allowed (but not displayed).
  • False: Prints are disallowed (and displayed).

In all cases you can read what they printed using the value of the context manager:

with student_code(print_allowed=None) as run:
    their_function()
assert run.err == ""
assert run.out == "42"

Good practices

Write the student checking code a you would write unit test for your own 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

correction_helper-2026.3.tar.gz (12.6 kB view details)

Uploaded Source

Built Distribution

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

correction_helper-2026.3-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file correction_helper-2026.3.tar.gz.

File metadata

  • Download URL: correction_helper-2026.3.tar.gz
  • Upload date:
  • Size: 12.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for correction_helper-2026.3.tar.gz
Algorithm Hash digest
SHA256 8aaa369b4ed65b98e7ca90b3ce83c370a434383c600532cfdcaa869d4f29dade
MD5 09952fbae79d66211a0d5471ee538c04
BLAKE2b-256 f3d92e051327bf48c2e0d918dfd6691cc5c5cbd2d41dca9a4bfa011f1e7d435f

See more details on using hashes here.

File details

Details for the file correction_helper-2026.3-py3-none-any.whl.

File metadata

File hashes

Hashes for correction_helper-2026.3-py3-none-any.whl
Algorithm Hash digest
SHA256 03340f2397b18caa72dcfa02c7e0f6993d3d52a692aa213f30e6c2410fe6b10e
MD5 95c83ded196d7f6652b137553425a47d
BLAKE2b-256 00e55c184a6cd84768565478cb046ecbd9f7df79ab0812b7e016f6e2d10400ff

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