Where possible, use consistent formatting for file layout. In pycharm take advantage of the
Code
→Optimize imports
and Code
→Reformat code
menu items in order to have a consistent
code layout.
We use Google-style docstrings. You can see examples of these docstrings here: https://sphinxcontrib-napoleon.readthedocs.io/en/latest/example_google.html
In pycharm you can set this format by choosing in Preferences Tools
→Python Integrated Tools
and change the Docstring format.
Make sure whenever possible you add type annotations to the variables, e.g.
Args:
param1 (int): The first parameter.
Always use a . to end sentences of a docstring. This includes argument lists
and other lists (see the Google example linked above). Here is an example of one
of the docstrings in our code base that you can use as reference
(from utils.test_helpers.create_user_and_sounds
):
"""Creates User, Sound and Pack objects useful for testing.
A counter is used to make sound names unique as well as other fields like md5 (see `sound_counter` variable).
NOTE: creating sounds requires License objects to exist in DB. Do that by making sure your test case loads
'licenses' fixture, i.e. "fixtures = ['licenses']".
Args:
num_sounds (int): N sounds to generate.
num_packs (int): N packs in which the sounds above will be grouped.
user (User): user owner of the created sounds (if not provided, a new user will be created).
count_offset (int): start counting sounds at X.
tags (str): string of tags to be added to the sounds (all sounds will have the same tags).
processing_state (str): processing state of the created sounds.
moderation_state (str): moderation state of the created sounds.
type (str): type of the sounds to be created (e.g. 'wav').
Returns:
(Tuple(User, List[Pack], List[Sound]): 3-element tuple containing the user owning the sounds,
a list of the packs created and a list of the sounds created.
"""
Prefer to create a pull request for all changes. This allows us to keep a record of the changes that were made, and allow feedback if necessary
Merging and deployment process (for admins only) When PRs are merged, we add the [merged] label to the ticket that it solves. This allows us to make a list of changes for release notes or other documentation. Once the release has been made we finally close the tickets.
If there is a need for defining custom permissions we should define them in the corresponding model's Meta
class
as described in the Django docs. There
is no generic model to host all custom permissions, but we'll add them to the most closely related model. These
permissions should then be added to a Group
so that we can manage them properly in the Django admin. The Group
should
be added in the user_groups
fixture and then the fixture needs to be manually loaded to the database. Loading the fixture won't duplicate
groups which are already existing if the pk
is specified in the fixture.
NOTE: Currently this fixture needs to be loaded manually to the database. We have plans for writing a command that will
automatically load the important fixtures (in the past Django used to do that automatically with fixtures named initial_data
).
Currently, we only use the following custom permissions:
tickets.can_moderate
(inTicket
model, used to allow sound moderation)forum.can_moderate_forum
(inPost
model, used to allow forum moderation)sounds.can_describe_in_bulk
(inBulkUploadProgress
model, used to allow bulk upload for users who don't meet the other common requirements)
We should aim to minimise the amount of downtime due to database migrations. This means that instead of doing complex data migration in a migration file, we should consider doing a basic migration, copying data in a management command, and then using the data. This may require that we do multiple releases to get all data populated and the site using this data.
For tables that have lots of rows, adding a column with a default value takes a long time. Adding this column as nullable is much faster. We can create a second migration to make the column not null once it is populated.
-
Make sure that there are no outstanding deprecation warnings for the version of django that we are upgrading to.
docker-compose run --rm web python -Wd manage.py test
Check for warnings of the form RemovedInDjango110Warning
(TODO: Make tests fail if a warning occurs)
-
Check each item in the Django release notes to see if it affects code in Freesound. In the final pull request, list each item and if affects us, and a link to the commit if a change was made.
-
For the 'remember password' form we had copied django code and modified it to accept an email or a username, changes in django code could break this part. Check if there are changes that could imply a modification on this form.
-
Check if
django.contrib.auth.forms.PasswordResetForm
method's code has changed with respect to the previous version. If it has changed see how this should be ported to our custom version of the form inaccounts.forms.FsPasswordResetForm
.
If the upgrade requires a database migration for django models, indicate this in the pull request. Include an estimate of the time required to perform this migration by first running the migration on fs-test
After doing all the changes follow this list as a guideline to check if things are working fine:
- Upload new sound
- Moderate sound
- post comment on sound
- Download sound
- follow user
- search and filter sounds
- create new post on forum
- search post on forum
- send message to user
- check that cross-site embeds work
- ...
- Check that CORS headers are working, by using a javascript app
- Add to Github team
- Add to Slack channel
- Give access to Sentry/Graylog