-
Notifications
You must be signed in to change notification settings - Fork 3
For Developers
To contribute to this project, please reach out to pcreighton429@gmail.com.
To ensure that our Python code stays clean, we are using Flake8 to enforce our style guide, which is mostly based off pep8. The only modification we have made to Flake8 is increasing the character line limit to 120.
Settings in the .vscode
directory will be automatically applied, which selects Flake8 as the linter and sets a vertical ruler of 120 for Python files.
The command run by the Flake8 Python Linter workflow (additionally excluding the .venv
directory) is:
flake8 . --count --show-source --statistics --max-line-length=120 --extend-exclude=.venv/
-
updatescripts.py
is used to sync locally stored data with the APIs: uncomment the code block corresponding to the desired data to sync, then run the file. These will take a while to execute.- Updates to the UBCGrades and UBC Course Explorer APIs depend on their respective owners, running these scripts might not change anything
- We recommend only running the RateMyProf section
-
testscripts.py
is used to test the output of various scraper methods: uncomment the code block corresonding to the desired method(s) to test, modify the parameters as required, then run the file.
- The database only stores
Course
objects that have been previously searched. These objects contain all the information displayed on the details page, except for the lists used: for the prerequisite tree, section professors, and course professors sections. - To view and manage the
Course
objects currently stored, will need to create a super user account: Introducing the Django Admin- You can sort pages by name and average, as well as view as the information stored for each object
- If
Course
fields are modified (added, renamed, deleted), the database will need to be updated: runpython manage.py makemigrations
, thenpython manage.py migrate
- If the field representations are changed without modifying the fields themselves (eg. changed
professors_info
field from dictionary to list), runpython manage.py updatecourseobjects
to refresh all the fields of allCourse
objects currently stored in the database - If migrations need to be made to the Course model,
coursetracker/migrations/load_courses.py
will need to be manually updated to depend on the latest migration
- If the field representations are changed without modifying the fields themselves (eg. changed
If the submodule directories are empty, try initializing the submodules
git submodule update --init --recursive
To fetch the latest changes from the submodules' repositories, use
git submodule update --recursive --remote
If there has been a new commit to those repositories, update this repository by committing the change