/autograder

A generic Autograder framework

Primary LanguagePHP

AutoGrader

Table of Contents

Introduction

AutoGrader is a project that aims to

  • have students turn-in code online,
  • raise and queue the grading tasks, and
  • grade them automatically given a set of instructor-defined test cases.

The three functions are designed as three separate modules which are connected by APIs. Each module can be used separately.

Advantages

Compared some other auto-grading systems like Web-CAT (http://web-cat.org/), this AutoGrader has several notable advantages:

  • light-weight components and less overheads
  • virtually no influence on student code (the system does not require #includeing or importing special libraries),
  • easier to access OS kernel and control system calls when needed,
  • sandbox for controller file I/O and networking (whether to enable sandbox or not is defined by each test case),
  • flexible and extensible APIs to design test cases,
  • what to write in the grading feedback is totally up to the instructor,
  • distributed grader hosts...

And thus it is better used for grading C/C++/assembly assignments, especially those involving systems programming.

File Structure

The file hierarchy of the project is as below:

  • grader the grader daemon and worker parts and the superclass of grader test cases.
  • log is the default directory to store log files. Excluded from Git and will be created by inst.sh.
  • submissions the default directory to save submissions that are sent to the web. Excluded from Git and will be created by setup.sh.
  • utils has some handy utility programs that will ease instructors' life.
  • default stores the default data files used in the project.
  • dump stores the MySQL database dumps and an import script.
  • web stores the web application. The root dir of the web server should be pointed here.
  • setup.sh is the installation script.
  • start.sh will start the grader daemon in background.

Most directories have a specific README.md that gives more details.

Set-up

Install

Properly configure the timezone of your server so that all components inherit the system tzdata.

First fetch the source code through git:

git clone https://github.com/xybu92/autograder

and then run ./setup.sh and follow its instructions.

The commands inside this script may not apply to your server configurations and you may need to set up your httpd and mysqld manually.

The default sandbox (not included) is UMLBox, of which the source is available through git:

git clone https://github.com/xybu92/umlbox-dash

If you need another sandbox, the corresponding arguments inside grader/grader.py should be changed.

Configure

  • Copy grader/grader.json.def to grader/grader.json and update its MySQL credentials and API keys (which will be used to authenticate with web component).
  • Copy web/app/config/globals.ini.def to web/app/config/globals.ini and update its MySQL credentials and API keys (to match the ones used in grader).
  • Log in to web interface with default admin account admin and password 123, and change the rest of the settings in admin panel.

API

For the definitions about the data and API, and the tutorial for writing test suites, refer to API.md.

Supplements

Reference Environment

To ensure fair and transparent grading of C/C++ assignments, it is better to define the reference environment the same as the one that hosts the grader and provide students the reference environment (without installing AutoGrader), probably in the form of a VM.

Support

For technical support, contact Xiangyu Bu.