Skip to main content

Tool for developing tasks for programming competitions.

Project description

Pisek ⌛

Tool for developing tasks for programming competitions. Currently used by:

And was used by:

Install

Pisek requires Python ≥ 3.11. Install with pip:

pip install pisek

For upgrading add --upgrade:

pip install pisek --upgrade

Testing tasks

First create a config file as documented here. You can also reference the examples for Kasiopea mode and CMS mode.

pisek test

This command tests the task in the current directory. It tests all task parts (generator, checker, solutions and judge).

Task testing overview

What pisek verifies (roughly in order):

  • Samples exist
  • The generator generates inputs
    • A Kasiopea generator respects the seed and is deterministic
  • The checker accepts all inputs
    • If checker_distinguishes_subtasks=on, it rejects inputs for harder subtasks
  • The judge works
    • It accepts the samples
    • It doesn't crash on malicious output
  • The solutions finish as expected
    • They get the expected number of points
    • They succeed/fail on each subtask as expected
  • Data files (inputs and outputs) are valid
    • They are in the correct encoding
    • They don't contain unprintable characters
    • They have a newline at the end
    • The files are reasonably small
  • The task is complete
    • A CMS judge has no redundant lines in its stdout/stderr
    • If solution_for_each_subtask=on, there exists a dedicated solution for each subtask

Testing given programs

For fast testing of only the solution solve_cool.cpp use:

pisek test solution solve_cool

For testing on multiple inputs use (only in Kasiopea mode) use:

pisek test solution solve_cool -n 42

Similarly the generator can be tested using:

pisek test generator

Useful options

Test all solutions, don't stop on first failure:

pisek test --full

Test each solution on all inputs, even when the result is clear:

pisek test --all-inputs

Use a different time limit (in seconds) for testing solutions:

pisek test --timeout 5

Interpret warnings as failures (for a final check):

pisek test --strict

Cleaning

Pisek can create a lot of files used for testing. Remove them by running:

pisek clean

Visualization

For visualizing the running time for each solution and testcase:

pisek test --testing-log  # test the task
pisek visualize      # visualize

License

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/.

Copyright (c)   2019 - 2022 Václav Volhejn <vaclav.volhejn@gmail.com>
Copyright (c)   2019 - 2022 Jiří Beneš <mail@jiribenes.com>
Copyright (c)   2020 - 2022 Michal Töpfer <michal.topfer@gmail.com>
Copyright (c)   2022        Jiří Kalvoda <jirikalvoda@kam.mff.cuni.cz>
Copyright (c)   2023        Daniel Skýpala <skipy@kam.mff.cuni.cz>
Copyright (c)   2024        Benjamin Swart <benjaminswart@email.cz>

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

pisek-1.2.0.tar.gz (139.0 kB view details)

Uploaded Source

Built Distribution

pisek-1.2.0-py3-none-any.whl (171.2 kB view details)

Uploaded Python 3

File details

Details for the file pisek-1.2.0.tar.gz.

File metadata

  • Download URL: pisek-1.2.0.tar.gz
  • Upload date:
  • Size: 139.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.1.dev0+g94f810c.d20240510 CPython/3.12.4

File hashes

Hashes for pisek-1.2.0.tar.gz
Algorithm Hash digest
SHA256 3a6a1b55f3ed3497964fa347cb43b96cabaa034b56be20f51ff27c765e81425f
MD5 914f90384cc883e223f5e8a8a1b9637a
BLAKE2b-256 007236440772bcd976134be08175e7c3b01dc60995116fa1e02ece22497848d4

See more details on using hashes here.

File details

Details for the file pisek-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: pisek-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 171.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.1.dev0+g94f810c.d20240510 CPython/3.12.4

File hashes

Hashes for pisek-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 53451315be304ade8958ecd63d6dc4104b5b993bbb54d1468d3616a1750e1d83
MD5 b21d2480cd45a664a8a5a526eaabf40c
BLAKE2b-256 f40fb803fd2365071545d88971fb84c80b35796890c5f6ccd06e0850a26042a4

See more details on using hashes here.

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