Use this site to automatically generate all required components for autograding an assignment on Gradescope: https://tbrown122387.github.io/autograder_site/.
Edit: Heroku isn't as cheap as it used to be, so the site---despite still being live---will not let you download the generated autograding bundles. If and when we ever secure funding again, that will change.
The gradeR
package helps grade your students's assignment submissions that are R
Scripts (.r
or .R
files). If you want to use gradeR
for grading submissions on your own laptop or desktop, please see the vignette here.
Instead, this vignette describes how to use the Gradescope autograder with a helper function from gradeR
. If you have already read the "getting started" vignette, and you work for an institution/university that has an appropriate subscription to this service, then this is probably useful information for you.
For each assignment you make, you might consider cloning this repository, modifying the student-facing assignment provided in example_hw_assignment/
, and then modifying the files required by Gradescope provided in autograding_code_and_data/
.
Students submit their assignments to Gradescope, and afterwards, their code is run and checked on Gradescope servers. The benefit is that students get feedback much more quickly, and your computer doesn't need to stay busy all day running student code.
The downside is that everything becomes a bit more complicated--but that's what this repository is for. It provides a template for each assignment: both the student-facing assignment description, as well as the the code you have to give Gradescope.
The autograding code for each Gradescope assignment is comprised of several files. We have provided all of these files in the directory autograding_code_and_data.
1. setup.sh
is a Linux Bash script that the Gradescope servers run to install R
and any R
packages that are required.
For those of you have little to no experience with shell scripting, do not despair! This repository provides an example file (see here) that will be easy to modify. Note that the name of this file must be setup.sh
because that is what Gradescope expects.
Roughly speaking, the more complicated this file is, the longer it will take for Gradescope to set up the autograder. The shorter it is, the faster it will be, but there will be fewer packages that students can use for assignments.
This can have any name you want, and it will usually change depending on what assignment you're grading. In this example, we call it assignment1_grading_file.r
.
This file contains testthat
tests, which is another R
package that gradeR
depends on. The example should be pretty self explanatory, but for those looking for more detail, see the original gradeR
vignette, or the documentation for the testthat
package.
Note that by default, each test case has its visibility set to "hidden." If you would like a test to be visible to the students, make sure to include the phrase "(visible)" in the name of the particular test.
This can be named anything you want, too, but we call it grade_one_submission.r
. Thanks to gradeR
, this one is pretty simple--it just calls gradeR::calcGradesForGradescope()
. This function runs a single student's .R
file submission, checks it against the provided testthat
tests, and nicely formats the output in a way that Gradescope expects.
This file must have this name, because Gradescope expects this. This small program is run every time a single student submission needs to be graded. It copies a single student submission into the directory that the Gradescope server expects, and then it runs the previously-mentioned file (which we called grade_one_submission.R
).
For example, our example homework assignment asked students to read in the file called data.csv
. This particular csv file can be found in our directory with all the other autograding files.
After all of these files have been written, they are then compressed into a single .zip
file (as described by Gradescope here), and then uploaded to Gradescope. Gradescope takes care of the rest.
Note that it is still possible to use Gradescope's autograder without the gradeR
package. For an example of how to do that, please see this Github repo.
To make your own assignment, log on to Gradescope and then start a new programming assignment. Then, download/clone this repository and make some customizations to the files. After you have made the changes, zip those files up, and upload it to Gradescope.
A word of warning: uploading the zip file can take several minutes. It is basically installing a fresh operating system and a bunch of software every time you upload this zip. The more complicated your setup.sh
file is, the longer this will take.
If you are unfamiliar with their website, please see the instructions that they provide here.
There are a few things to do when you customize this to your own assignment:
-
Make sure that each student's submission is named the same. In our example, we assume all submissions are named
assignment1.R
-
Make sure
grade_one_submission.r
references the correct filenames. For us, we choseassignment1.R
andassignment1_tests.R
-
Make sure your assignment instructions feature the same warnings in our example assignment here. This isn't absolutely required, but it is helpful for the students.
-
Make sure your
setup.sh
installs all packages that student code requires (and ideally, no unnecessary packages). -
Make sure
run_autograder
uses the correct filenames. The directories are what Gradescope expects, so don't change those. -
Double check your test visibilities. Remember, by default all tests are hidden from students. If you would like a test to be visible, just insert the phrase "(visible)" into the name of the test file. For example, that is done on the first test here..
-
Make sure the max score you enter on Gradescope is the same as the total number of tests you have.
-
After you have uploaded your autograder zip file, click the "Test Autograder" and upload your solutions as a test to make sure everything works. This must also have the same name as all the other student submissions.