Skip to main content

Prepare assignment

Project description

Prepare assignment

Prepare assignment is a GitHub Actions inspired helper tool to prepare assignments at Fontys Venlo. The goal is to define jobs inside the prepare.yml that indicate how to convert a solution project into a student project.

Dependencies

  • Git
  • Python >=3.8

Installation

Prepare-assignment is available from PyPI.

# To install:
python3 -m pip install prepare-assignment

# To upgrade
python3 -m pip install --upgrade prepare-assignment

Executing prepare-assignment

To execute a prepare.yml simply run prepare run from the same directory.

Command line interface

Use prepare --help to which commands and flags are available.

Example prepare.yml

First we need to have tasks available that can be executed. Take for example a look at the remove task.

The tests use a testproject, which contains an example of a prepare.yml, see below for convenience.

name: Test project
jobs:
  prepare:
    - name: remove out
      uses: remove
      with:
        input:
          - "out"
          - "out.txt"
        force: true
        recursive: true
    - name: codestripper
      id: codestripper
      uses: codestripper
      with:
        include:
          - "**/*.java"
          - "pom.xml"
        working-directory: "solution"
        verbosity: 5
    - name: Test a run command with substitution
      run: echo '${{ tasks.codestripper.outputs.stripped-files }}' > out.txt

For people familiar with GitHub Actions this should look very familiar. We have jobs that indicate what should happen to prepare an assignment. The tasks are defined in their own repositories, if the uses tag doesn't have a username/organization, it will default to prepare-assignment. So for example the remove task uses the following repository: prepare-assignment/remove

Config file

It is possible to specify global options in a config file. The location of the config file can be found by running prepare without any commands.

The following settings are available:

core:
  git-mode: "ssh|https"
  verbose: int
  debug: int

Tasks

There are three different kind of tasks available:

  • Run tasks: these execute a shell command (for now only bash is supported)
  • Python tasks: these execute a python script
  • Composite tasks: these combine multiple tasks into one

Custom tasks

It is possible to create custom (python/composite) tasks.

  1. Create a repository
  2. Define the properties of the task in task.yml, these include
    • id*: unique identifier
    • name*: name of the task
    • description*: short description
    • runs*: whether it is a python or composite task
    • inputs: the inputs for the task
    • outputs: the outputs that get set by the task
  3. Validate that the task definition is correct against the json schema
  4. If python task, create a script that implements desired functionality

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

prepare_assignment-0.2.0.tar.gz (21.7 kB view details)

Uploaded Source

Built Distribution

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

prepare_assignment-0.2.0-py3-none-any.whl (32.6 kB view details)

Uploaded Python 3

File details

Details for the file prepare_assignment-0.2.0.tar.gz.

File metadata

  • Download URL: prepare_assignment-0.2.0.tar.gz
  • Upload date:
  • Size: 21.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.9.21 Linux/6.8.0-1021-azure

File hashes

Hashes for prepare_assignment-0.2.0.tar.gz
Algorithm Hash digest
SHA256 2b1f65adc488d41d1393920a8390f9a3dd86101891c3ca7c5c46779ae9e5dcfa
MD5 d49ac9d5c7abb34ad2e3a8c0a715f731
BLAKE2b-256 7bfefeb0a4668c0c68a3367d9657c72bbe31ae7e7f0751c5e77e2b125314b076

See more details on using hashes here.

File details

Details for the file prepare_assignment-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: prepare_assignment-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 32.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.9.21 Linux/6.8.0-1021-azure

File hashes

Hashes for prepare_assignment-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d3782c012d9f8eee9229c76835b05fbac8dd2d435e48cc0998aa69597ff6bb3a
MD5 ab19c923585dd5ed366eb43f85778aa3
BLAKE2b-256 3afa20259d40539693829c235cf584dc9955f5856430cc0c3314799a38a6148c

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