Skip to main content

A homework checker for a 3d Modeling class

Project description

Grader

Grader is a custom assignment checker for a 3D modeling class, but it is flexible enough that it could be useful for some other purpose. Written by Luis Naranjo

Usage

When grader is run for the first time it creates a folder called ‘grader’ in My Documents (Windows) or Documents (Mac).

Here are the contents of ‘grader’:

settings.conf

students.txt

grader_files

log.txt

settings.conf

Settings

This file is where the projects are defined.

The file starts out with the following program settings:

show members

This controls whether the contents of a student’s missing project are to be reported missing or not.

It can be either True or False

For example:

show members = True

Putting this in settings.conf would make the grader report each missing file within a missing project.

If it were set to false, the grader would only report that the project is missing.

capitalization

This controls the capitalization of the student projects.

The grader relies on the consistency of the project/exercise naming.

Students are not the most reliable for correct formatting, so grader includes a way to normalize all of the files/folders in the grader_files folder.

capitalization has the following possible values: capitalize, lower, upper, title

capitalize only capitalizes the first word.

lower makes everything lower case.

upper makes everything upper case.

title capitalizes every word.

For example:

capitalization = lower

This would make every folder and file in the grader_files folder lowercase.

Note:

  • Watch out for upper and title, they can mess up your file extensions.

  • If you don’t set this correctly, grader won’t function.

log

This controls where grader’s results are reported.

It can be either True or False

If it is True, the results are recorded in My Documents/grader/log.txt

If it is False, the results are printed to the command line and not saved.

Projects

You can define as many projects as you want

Each project can have as many exercises as you want.

Each exercise can have as many file extensions as you want.

For example:

[project 3]
exercise 1 = .jpg,.3dm
exercise 2 = .3dm

Notice that exercise 1 has two file extensions, and they are separated by commas, not spaces.

If we only had one student (naranjo) defined in students.txt, grader would look for the following files and folders in grader_files\:

naranjo project 3\ (folder)

naranjo exercise 1.jpg (inside of naranjo project 3)

naranjo exercise 1.3dm (inside of naranjo project 3)

naranjo exercise 2.3dm (inside of naranjo project 3)

students.txt

This is where the students are defined.

students.txt is very simple.

Each line in the file should have the last name of the student, and nothing more.

Do not skip any lines.

This will work:

depp
clooney
naranjo

This will not:

depp

clooney

naranjo

grader_files

This is the folder where you put the student projects. Each folder should be named according to the following convention (things enclosed by brackets are variables):

{lastname} {projectname}

The exercises contained in these folders should match the following convention:

{lastname} {exercisename}

log.txt

Results can be stored here.

This is controlled via the log variable in settings.conf

Installation

Grader is written in python2.7.3, so python must be installed before it can be run.

There is a great guide on how to install here: http://docs.python-guide.org/en/latest/index.html

It has only one dependency (configobj), which is bundled with the program.

It is available on the python package index at http://pypi.python.org/pypi/grader

Source code is up on https://github.com/doubledubba/grader

Once it is installed, grader sets up a console script called ‘grader’.

This allows you to open the command prompt/terminal and type ‘grader’ and hit enter.

This should activate grader.

What you would see on the command prompt depends on what you set your log variable as in settings.config

Grader also adds a batch file (grader.bat) which automates this process for clicking.

If you are on Windows, you should be able to click this to run grader.

A similar file is created for Linux and Mac operating systems called grader.sh

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

grader-1.2.zip (60.4 kB view details)

Uploaded Source

grader-1.2.tar.gz (50.2 kB view details)

Uploaded Source

File details

Details for the file grader-1.2.zip.

File metadata

  • Download URL: grader-1.2.zip
  • Upload date:
  • Size: 60.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for grader-1.2.zip
Algorithm Hash digest
SHA256 b4e8bc3121ec04f2fbad592679dd4313cc82a18f13b374fbe971e07c6df08ce8
MD5 6dbb49ad3922a57d579d8d86c3b87a1c
BLAKE2b-256 9babac18497b25d3ce9907ea44a55a503da3ac8824244df71c3dc53b6f6451ef

See more details on using hashes here.

File details

Details for the file grader-1.2.tar.gz.

File metadata

  • Download URL: grader-1.2.tar.gz
  • Upload date:
  • Size: 50.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for grader-1.2.tar.gz
Algorithm Hash digest
SHA256 9fce6b4a62fcbfc3f6b48322c99ee11babe054dc82d3570815e0367771b2e591
MD5 541971bb521a126a071c7ff70e2786d9
BLAKE2b-256 762865ae5f11fa6e6c44f532d8057dff807b26c005501c533790853abed0f628

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