Skip to content

Bridges the gap between waterproof's exercise sheets and momotor's automated grading

License

Notifications You must be signed in to change notification settings

impermeable/waterproof-momotor

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

51 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

waterproof_momotor

Bridges the gap between waterproof's exercise sheets and momotor's automated grading

Installation

Install with pip install [root].

Intended use

This repository contains:

  • recipe and checklets to give to momotor, located in /recipe/checklets/
  • utility functions to interact with waterproof and coqc, located in /waterproof_momotor/

Checklets

The recipe/checklets to give to momotor, located in /recipe/checklets/, hold the main routines to check waterproof notebook's correctness. Currently, there are:

  • the ValidateIntegrity checklet (at /recipe/checklets/validate_integrity) that (should) check whether the student handed in the same notebook as the master notebook (but possibly with their own code).
  • the ValidateContent checklet (at /recipe/checklets/validate_content) that (should) check whether the student's code is acceptable (no illegal syntax) and compiles in CoqC, hence solves the exercises. We rate each exercise separately, so for this we iteratively replace only ONE of the student's code blocks in the master notebook, and check if it (still) compiles and hence successfully proves everything.

Example use of utility functions

We start by importing our code.

from waterproof_momotor import *

Then, we import the notebook with worked out solutions and the student's submission.

master_notebook = load_file('some/waterproof/file.wpn')
student_notebook = load_file('some/waterproof/file.wpe')

You can extract the Coq code from this notebook in various ways, for instance by calling notebook.code_blocks(). These can be manually checked for illegal syntax such as Admitted..

The first check we can do can be whether the student's submission actually corresponds to the exercises in the master notebook. One way to check this is by evaluating whether the student notebook is the same as the master notebook outside of input blocks, as the student should not have been able to change this:

master_notebook.non_input_equals(student_notebook)

Then, moving on to more interesting checks involving Coq code compilation using coqc, we can run the code of a notebook, for instance master_notebook, through coqc as follows:

master_code = wp_formatter(master_notebook, post_amble='')
result = coqc(master_code)

Full API

TODO?

About

Bridges the gap between waterproof's exercise sheets and momotor's automated grading

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages