Here is an ordered list of todos and other things to work on for this framework:
- Merge in JUnit 4 tests support and bug fixes #3
- Merge in few Frontend #2
- Fix security vulnerabilities (ask @JHawk0224 )
- Make sure default tests are always run (from Gradescope files), e.g. even if student tests don’t pass (so default tests need to be uploaded to Gradescope every time the TA submits the autograder). Also make sure these default tests are run first to prevent server crashes affecting them.
- Finish implementing visibility levels for tests (e.g. see actual content of tests depending on visibility flag, or just name and description, or what outputs to students when run in Gradescope). Also integrate with default tests so some can be completely hidden while others are displayed.
- Have 3 options for each of 3 categories: visible for everyone, visible for admins only, visible to user only
- Categories: Determining who the test case code is visible for, determining who can see the details of the test case (the Gradescope output of it), and determining who can see the error logs for the test case
- Ensure owner of private tests can see error logs (not just Gradescope output) depending on visibility level
- Give useful feedback to students if tests.json is formatted incorrectly, e.g. if the test type field isn’t there, if it isn’t valid json, etc. Also ensure that the required fields are there like name, etc.
- Add support for running scripts as test cases
- Set up/allow only https (port 443), also Elastic IP and A record for domain name
- Keep a log of the autograder’s backend’s print statement (at least most recent 1000 or so) to see why server goes down if so
- Add backend support for unliking and undisliking and integrate with frontend
- Since run student code, they could add to/modify the gradescope output, or run things with environment variables (e.g. send requests to backend as Gradescope), need to increase security
- Add limit to number of autograder re-runs so not too frequent Make GitHub action that integrates STF so when new commits are made to a solution repo, the tests are automatically run (same workflow as Gradescope, but need to redo the details of the assignment metadata/tests output).
- Tag tests with specific sections of an assignment, and display on website/filter by tag
- Somehow allow students to rerun same suite of student tests twice in a row
- Support for other types of tests like Jest and playwright
- Finish TODOs written in codebase
- Resolve dependabot vulnerability alerts
- Implement test case similarity checking somehow to prevent very similar tests