A management system for creating and maintaining autograders compatible with @philipritchey's autograder system.
Documentation
- Setting up a Deployment
- Setting up a Development Environment
- Setting up a Testing Environment
- Contact the Development Team
Links
- Code Climate
- Heroku Deployment
- GitHub Projects
- Team Working Agreement
- Presentation and Demonstration Video
This application will streamline the process of creating auto-graded assignments by providing a GUI to generate new assignment GitHub repositories and interactively create new tests. All the GitHub repositories need to be created under the organization for the course.
First, you need to have a GitHub account. Go to your GitHub account and follow these steps:
- In the upper-right corner of any page on GitHub, click your profile photo, then click Settings.
- In the "Access" section of the sidebar, click Organizations.
- Next to the "Organizations" header, click New organization.
- Follow the prompts to create your organization.
In the Organization, you may want to give different roles to the different members (you don’t want to give write permissions to everyone). There are some predefined roles in GitHub:
- All-repository read
- All-repository write
- All-repository triage
- All-repository maintain
- All-repository admin
- CI/CD admin
Lastly, your organization must contain a fork of the Autograder Core repository. This repository contains core autograder functionality that is common to all assignments. When a student submits their work to Gradescope, both the assignment-specific repository, as well as this repository, are cloned into the autograder environment to run tests on the submission.
- Navigate to the GitHub repository: https://github.com/AutograderFrontend/autograder-core.
- Click either the “Fork” button at the top of the window or the “fork this repo” link in the README.
- Set the “Owner” field to the name of your newly-created GitHub Organization.
- You may optionally change the repository name, but you must then make sure that your
GITHUB_AUTOGRADER_CORE_REPO
environment variable (discussed below in the Heroku setup documentation) matches the new name. - Click “Create fork”.
- In the upper-right corner of GitHub, select your profile photo, then click Your organizations.
- Next to the organization, click Settings.
- In the "Access" section of the sidebar, click Organization roles, then click Role assignments.
- Click New role assignment.
- Search for users or teams that you want to assign a role to, then select the role you want to give to these users and teams.
- Click Add new assignment.
A user or team can have multiple organization roles. However, you can only assign one role at a time.
- In the upper-right corner of GitHub, select your profile photo, then click Your organizations.
- Next to the organization, click Settings.
- In the "Access" section of the sidebar, click Organization roles, then click Role assignments.
- Optionally, to filter by role assignments for users, click the Users tab. To filter by role assignments for teams, click the Teams tab.
- To view role assignments, to the right of the user or team, click NUMBER roles.
- In the upper-right corner of GitHub, select your profile photo, then click Your organizations.
- Next to the organization, click Settings.
- In the "Access" section of the sidebar, click Organization roles, then click Role assignments.
- Optionally, to filter by role assignments for users, click the Users tab. To filter by role assignments for teams, click the Teams tab.
- To delete a role, to the right of the role, click NUMBER roles. Then click Remove.
- In the pop-up window, click Remove.
- Visit Heroku's Signup Page.
- Fill in the required details (name, email, password, etc.).
- Verify your email address via the confirmation link sent to your inbox.
- Log in to the Heroku dashboard at https://dashboard.heroku.com/.
- Download the Heroku CLI from the Heroku CLI Download Page.
OR
Install it based on your operating system:
- macOS: Use Homebrew:
brew tap heroku/brew && brew install heroku
- Ubuntu/Debian: Use Snap:
sudo snap install --classic heroku
- Windows: Download and run the installer from the Heroku CLI page.
heroku --version
Log in to your Heroku account:
heroku login
This will open a browser window for you to log in.
In your Rails project directory, create a new Heroku app:
heroku create <app-name>
NOTE: If you don’t provide
<app-name>
, Heroku will generate a random name for your app.
The application requires Git to be installed in the Heroku environment for functionality like cloning the repository to local.
- The Heroku application stack will automatically be set to
heroku-24
, but this stack does not have Git in it. - To install Git, change the stack to
heroku-22
where Git is already included using the command:heroku stack:set heroku-22 --app <your-app-name>
- To ensure that Git is installed, execute the command:
heroku run "git --version"
Once the application is created on Heroku, we need to connect the database to the application.
All apps on Heroku use the PostgreSQL database. For Ruby/Rails apps to do so, they must include the pg
gem. However, we don't want to use this gem while developing, since we're using SQLite for that.
Make sure that the Gemfile
has the following two configurations:
group :production do
gem 'pg' # for Heroku deployment
end
group :development, :test do
gem 'sqlite3'
end
Run bundle install
to download the dependencies.
Once the gem is installed, the PostgreSQL database plan needs to be attached as an add-on to the application. The database can be added on through the Heroku CLI or Heroku interface.
For the current load, Heroku’s essential-0
plan is sufficient. The Essential-0 plan for Heroku Postgres is a production-grade database plan that offers 1GB of storage and a connection limit of 20.
Run the following command to add the essential-0
plan to your Heroku app:
heroku addons:create heroku-postgresql:essential-0
This creates a more robust database suitable for production use with increased storage and performance.
- Log In to the Heroku Dashboard
- Go to Heroku Dashboard.
- Log in with your Heroku credentials.
- Select your application that we created earlier
- Locate and click on your application in the list of apps on the dashboard.
- Navigate to the Resources Tab
- Once on your app's page, click the Resources tab in the top menu.
- This tab shows all the add-ons currently attached to your app.
- Search for the Add-on
- In the Add-ons section, type the name of the add-on you want to attach, such as Heroku Postgres.
- Select Heroku Postgres from the dropdown list.
- Select the Plan
- A pop-up will appear asking you to choose a plan. Select
Essential-0
(or your desired plan). - Confirm your choice by clicking the Submit or Provision button.
- A pop-up will appear asking you to choose a plan. Select
- Verify the Add-on
- After provisioning, the new add-on will appear in the Add-ons section of the Resources tab.
- You can click on the add-on’s name to open its management dashboard for further configuration and monitoring.
NOTE: The provisioning might take some time, so wait for a few minutes or check the progress on Heroku Dashboard.
Heroku will automatically set the DATABASE_URL
environment variable for your app once the add-on is attached.
To verify that the environment variable is setup, run the command:
heroku config
Look for an entry like this:
DATABASE_URL: postgres://username:password@hostname:port/dbname
To verify on Heroku interface, navigate to the Settings tab and click Reveal Config Vars. You should see the key DATABASE_URL
with the correct URL value. (Check the Edit Config Vars section to know more.)
Once the database is attached to the application, we need to configure it for production. To do this, add the following part in config/database.yml
:
production:
<<: *default
database: <%= ENV['DATABASE_URL'] %>
You can manage config variables via Heroku CLI or through the interface.
The heroku config
commands of the Heroku CLI make it easy to manage your app’s config vars.
- To view current config values:
heroku config
This command shows all current config values. You can also query specific values:
heroku config:get GITHUB_USERNAME
- To set a config variable, use:
heroku config:set GITHUB_USERNAME=joesmith
- To remove a config variable:
heroku config:unset GITHUB_USERNAME
You can edit config vars from your app’s Settings tab in the Heroku Dashboard.
GITHUB_TEMPLATE_REPO_URL
:philipritchey/autograded-assignment-template
[This is the template based on which the professor will create the assignment.]GITHUB_COURSE_ORGANIZATION
:AutograderFrontend
(The way code is setup, keep the same organization name even if you are creating a new one.)ASSIGNMENTS_BASE_PATH
:/app/assignment-repos/
[This is the base path where the assignments will be cloned.]GITHUB_AUTOGRADER_CORE_REPO
:autograder-core
Before deploying the application, there are certain prerequisites:
- If the Procfile is not present, create a file named “Procfile” with no extension.
- Generate a puma config file if it does not exist using the command:
bundle exec puma --config config/puma.rb
- Ensure that the Procfile contains the following line that executes the Puma web server:
web: bundle exec puma -C config/puma.rb
Generate and add the secret key base to the application:
heroku config:set SECRET_KEY_BASE=$(rails secret)
Follow these steps to deploy the application:
- In your project directory, execute the command
heroku login
to connect to Heroku. - Add Heroku as a remote to your Git repository:
heroku git:remote -a <heroku-app-name>
- Verify that Heroku is added to the remote by executing:
git remote
- Push your changes to Heroku:
git push heroku main
Once the changes are pushed to heroku main
, complete the following post-deployment tasks:
- Migrations
Run database migrations:
heroku run rails db:migrate
- Seed the Database
If needed, seed the database:
heroku run rails db:seed
- Restart Dynos
Restart Heroku dynos:
heroku restart
- Verify the App
Verify that the app is running correctly:
heroku open
Create an OAuth app:
-
Go to your GitHub account settings.
-
Navigate to Developer settings > OAuth apps > New OAuth App.
-
Provide the following details:
- Application name: Your app’s name.
- Homepage URL: The full URL to your app (e.g.,
https://your-heroku-app.herokuapp.com
). - Authorization callback URL:
https://your-heroku-app.herokuapp.com/auth/github/callback
.
-
Click Register application.
After registering, you'll receive a GITHUB_CLIENT_ID
and GITHUB_CLIENT_SECRET
. Add these as environment variables in Heroku.
If some functionality is not working correctly on the deployed application, check the Heroku logs to find the root cause:
heroku logs --tail
Step-0: Clone our project repository from here.
The Ruby version used for the development of our application is 3.3.2
. If your Ruby version is different, we recommend matching ours to avoid any conflicts with dependencies. You may follow the steps given here for installing Ruby.
-
If
rails
is not present already, to install it, do this:gem install rails
-
If
bundler
is not present already, to install it, do this:gem install bundler
-
If Heroku Command Line (CLI) tool is not present already, to install it, follow the instructions here.
-
Check the
ruby
,rails
,bundler
andheroku CLI
versions using the following:ruby -v && rails -v && bundle -v && heroku -v
-
Install
pkg-config
using this command:sudo apt-get update && sudo apt-get install pkg-config
The migration files are already present under the db/migrate
folder. So, no need to create any new migration files.
To apply the migration and create the database table for development, simply run:
rails db:migrate
Next, let us install the necessary gems:
All the gems needed are already present in the Gemfile
. So, no need to add other gems.
To install all the Gem files, simply run:
bundle install
Now, we need to create and register an OAuth app under your personal account or under any organization you have administrative access to. Here, you should open it under the organization.
Currently, GitHub only allows for a single callback URL, so a second OAuth Application should be made to work with the development environment.
- In the upper-right corner of any page on GitHub, click your profile photo, then click Settings.
- In the left sidebar, click Developer settings.
- In the left sidebar, click OAuth apps.
- Click New OAuth App. (If you haven't created an app before, this button will say, "Register a new application.")
- In Application name, type the name of your app.
- In Homepage URL, type the full URL to your local app's website:
http://127.0.0.1:3000/
- In Authorization callback URL, type the callback URL of your local app.
For example:NOTE: Ensure that the callback URL is configured inhttp://127.0.0.1:3000/auth/github/callback
routes.rb
. - If your OAuth app will use the device flow to identify and authorize users, click Enable Device Flow. For more information about the device flow, see [Authorizing OAuth apps] (https://docs.github.com/en/apps/oauth-apps/building-oauth-apps/authorizing-oauth-apps#device-flow).
After registering the OAuth, you will get a GITHUB_CLIENT_ID
, and you will need to generate a GITHUB_CLIENT_SECRET
.
-
Attach these two lines to
config/local_env.yml
:GITHUB_CLIENT_ID: "<GITHUB_CLIENT_ID_OAUTH>" GITHUB_CLIENT_SECRET: "<GITHUB_CLIENT_SECRET_OAUTH>"
-
Now run
rails server
on your terminal, and visithttp://127.0.0.1:3000/
, to visit the homepage of the local version of the application.
Caution:
Do not push the local_env.yml
file containing the additions of GITHUB_CLIENT_ID
and GITHUB_CLIENT_SECRET
information to the main repository (this should already be added to your .gitignore
). These two values were included in the local_env.yml
file just to allow you to run rails server
and test the app during development.
You may survey the application routes currently present to get a better idea of which controller action gets called when a certain URI is fetched:
- Run Rails Routes Command: Use the following command in your terminal to list all defined routes:
rails routes
It is also a good idea for you to get acquainted with the models and controllers present within our application before you start the development. A brief introduction is provided as follows:
-
ApplicationRecord:
Base class for all models.
Provides shared functionality for ActiveRecord models. -
Assignment:
Represents assignments in the application. -
Permission:
Represents permissions associated with users or assignments.
Used for managing access control. -
TestGrouping:
Represents groupings of tests within assignments.
Used for organizing related tests. -
Test:
Represents individual tests associated with assignments or groupings. -
User:
Represents an application user.
-
ApplicationController:
Base controller for all other controllers.
Handles shared functionality such as authentication and error handling. -
AssignmentsController:
Manages operations related to assignments.
Includes actions for viewing assignments, updating users assigned to an assignment, searching assignments, managing directory structures. -
PagesController:
Manages redirection to Assignments page for logged-in users.
Includes actions for redirecting to assignments for a logged-in user. -
SessionsController:
Manages user sessions.
Includes actions for logging in via GitHub, handling login failures, and logging out.
Verifies organizational membership during login. -
TestGroupingsController:
Manages groupings of tests.
Includes actions for creating and deleting test groupings. -
TestsController:
Manages individual tests.
Includes actions for configuring test metadata. -
UsersController:
Handles user-related operations.
Includes actions for viewing users, managing user assignments.
Our application employs a robust testing framework comprising the following tools:
- RSpec: For developing unit tests.
- Cucumber: For acceptance testing.
- Capybara: Facilitates automated front-end testing.
- Selenium/Chrome: Used as a JavaScript driver for some tests.
- WebMock: Stubs HTTP requests in our test suite.
- SimpleCov: Measures both line and branch coverage to ensure > 90% test coverage.
- RuboCop: Static code analysis and code formatting.
- RSpec tests are located under the
/spec
directory. - Cucumber feature and step files are located under the
/features
directory.
To allow Capybara to use the Chrome driver, install it using the following command:
sudo apt install chromium-chromedriver
To execute the test suite, use the following command:
bundle exec rspec && bundle exec cucumber
For any inquiries, concerns, or feedback related to the development, testing, deployment, or usage of this application, please reach out to our team. You may also create a GitHub Issue.
- Md Hasan Al Banna: [email protected]
- Riddhi Ghate: [email protected]
- Ryan Gonzalez: [email protected]
- Qinyao Hou: [email protected]
- Saksham Mehta: [email protected]
- Mainak Sarkar: [email protected]
- Max Smith: [email protected]