Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Django Upgrade] [Reference PR] The rest of the fixes #10048

Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
85 commits
Select commit Hold shift + click to select a range
7c3b9ad
remove post-migrate signals from migration stream (#9964)
Johnetordoff Jun 24, 2022
4a8bd61
move createcachetable to post migrate signal (#9944)
Johnetordoff Jun 27, 2022
bf7eb21
[ENG-3836] Investigate waffle flags (#9950)
Johnetordoff Jul 1, 2022
15f15e9
[ENG-3865] Create Licenses using post-migrate signal (#9961)
Johnetordoff Jul 12, 2022
5746a84
[ENG-3863] Move schema ensuring and schema blocks update to post-migr…
cslzchen Jul 13, 2022
c2c5e4e
[ENG-3868] Move blocked email domains to post-migrate signal (#9958)
Johnetordoff Jul 13, 2022
f22e531
[ENG-3866] Move citation style population out of migration stream (#9…
Johnetordoff Jul 15, 2022
250b832
[ENG-3867] Create Storage Regions on post migration signal (#9965)
Johnetordoff Jul 19, 2022
8052ea4
[ENG-3836] Follow-up: Add PyYAML to Requirements (#9993)
cslzchen Jul 27, 2022
65b344b
[ENG-3862] Move post-migrate signal out of migration stream for defau…
Johnetordoff Jul 28, 2022
205e560
Remove unused password change view/route (#9985)
Johnetordoff Aug 11, 2022
1675f6f
Update import paths and fix deprecated modules for Django 3 (#9983)
Johnetordoff Aug 11, 2022
391af60
Update postgres backend and remove failover router for Django 3 (#10011)
Johnetordoff Aug 11, 2022
c9c7f44
Move file metadata population to unit test fixtures (#9994)
Johnetordoff Aug 11, 2022
721ef90
Remove password_reset from installed apps
cslzchen Aug 11, 2022
75ffbb0
Merge remote-tracking branch 'upstream/develop' into feature/django_u…
cslzchen Aug 16, 2022
285d9a6
[Django Upgrade] Fix one sub-query slicing issue (#10012)
Johnetordoff Aug 17, 2022
06f6fe9
[Django Upgrade] Upgrade django-elasticsearch-metrics (#10021)
Johnetordoff Aug 17, 2022
724f59a
[Django Upgrade] Replace M2M direct assignment (#10010)
Johnetordoff Aug 17, 2022
afa62a7
[Django Upgrade] Upgrade markdown and mdx_del_ins (#9984)
Johnetordoff Aug 17, 2022
d15c88f
[Django Upgrade] Move schema activeness/visibility update to pytest f…
cslzchen Aug 18, 2022
3f162f1
Remove osf migrations
cslzchen Aug 17, 2022
f971149
Remove addon migrations
cslzchen Aug 17, 2022
f41eb8a
Init migrations - osf
cslzchen Aug 17, 2022
dab1bbc
Init migrations - addons
cslzchen Aug 17, 2022
994fcfd
Fix migration for NotableEmailDomain
cslzchen Aug 17, 2022
a54bbbe
Fix circular import with built-in admin migrations
cslzchen Aug 17, 2022
699fc1c
Add a RunSQL migration to update indexes
cslzchen Aug 22, 2022
0dc9220
Merge pull request #10028 from cslzchen/feature/clean_squash
mfraezz Aug 23, 2022
cfb012e
Merge remote-tracking branch 'upstream/develop' into feature/django_u…
cslzchen Sep 1, 2022
cb25d71
Upgrade django to 3.2.15 (and related dependencies)
cslzchen Aug 31, 2022
720b6ec
Make fields defined on typedmodels subclasses nullable
cslzchen Aug 31, 2022
6b7ce7f
Add required on_delete=CASCADE (default) to FKs missing it
cslzchen Aug 31, 2022
0192907
Fix django CORS whitelist settings due to orgin definition update
cslzchen Sep 1, 2022
51f4f48
Add/Enable missing templates and middlewares in api settings
cslzchen Sep 1, 2022
41d4b50
Comment out admin permissions that clash with built-in "view" ones
cslzchen Sep 1, 2022
65f39c8
Add migrations for django upgrade base fixes
cslzchen Sep 1, 2022
0ad3f7c
Fix system check warnings for django admin
cslzchen Sep 1, 2022
a2dc7ba
Merge branch 'longze/django3-upgrade-base' into feature/django_upgrade
cslzchen Sep 1, 2022
2a0aa6e
Fix django cache table creation
cslzchen Sep 2, 2022
66edda0
Enable django.contrib.sessions.middleware.SessionMiddleware
cslzchen Sep 7, 2022
37bd4e4
Use default truthy and falsy values from upgraded DRF 3.13.1
cslzchen Sep 7, 2022
bcd2c6e
Use JsonField from django.db.models and django.forms
cslzchen Sep 7, 2022
88c057e
Merge branch 'longze/django3-json-field-update' into feature/django_u…
cslzchen Sep 7, 2022
0ce6496
Fix session cookie encoding/decoding by using ensure_str()
cslzchen Sep 7, 2022
fc0d032
Merge branch 'fix-django-session-issues' into feature/django_upgrade
cslzchen Sep 8, 2022
2fbc057
Use prefetch instead of Django include
Aug 29, 2022
eb93348
Merge branch 'replace-django-include-with-prefetch' into feature/djan…
cslzchen Sep 9, 2022
07ee7e6
Fix CORS for ORIGINS_WHITELIST
cslzchen Sep 9, 2022
9e9c487
Merge branch 'django-3-update-cors' into feature/django_upgrade
cslzchen Sep 9, 2022
4e19413
Rename auto generated migration for django3 upgrade fixes
cslzchen Sep 12, 2022
d10824f
Remove QuickFile check from get_serializer_class for FileDetail view
cslzchen Sep 12, 2022
4e56c87
Merge remote-tracking branch 'upstream/develop' into feature/django_u…
cslzchen Sep 12, 2022
68acb17
clear cached property for storage region.
Sep 13, 2022
57e81a6
turn off notify emails for tests in Django 3 upgrade
Sep 13, 2022
0bc3d5c
upgrade Django factory models for Django 3
Sep 13, 2022
7d3c644
remove update_version_metadata with tests
Sep 13, 2022
51a6b1b
remove django-include and other unused egap backfill tests
Sep 13, 2022
e21b460
Make DFR serializer fixes
Sep 13, 2022
1a70f61
make registration metadata use real schema
Sep 13, 2022
f30f1ce
Fix changed test due to DRF upgrade issues
Sep 13, 2022
fca9e81
fix duplication of 'view_node' for admin app
Sep 13, 2022
dffad34
fix test issues by reloading refferents
Sep 13, 2022
db10898
add DEFAULT_AUTO_FIELD to end warnings for Django 3 upgrade
Sep 13, 2022
0c1cc03
fix DRF issue
Sep 13, 2022
494e396
Fix an issue where get_node() is not avaialbe from context view
cslzchen Sep 12, 2022
6548110
Add registration_schema to DraftRegistrationDetailSerializer
cslzchen Sep 12, 2022
0bb5fc5
Add id to DraftRegistrationDetailSerializer
cslzchen Sep 13, 2022
d69128c
Merge branch 'fix-draft-registration-serializers' into feature/django…
cslzchen Sep 13, 2022
7f6219b
Merge branch 'feature/django_upgrade' of https://github.com/CenterFor…
Sep 13, 2022
3f97cd6
sort out query issue for `visible_contributor_to` for Django 3 upgrade
Sep 13, 2022
ec4da2f
update schema code
Sep 14, 2022
6f64b38
skip test_validate_social_profile_website_many_different due to it br…
Sep 14, 2022
6dcb706
fix more draft registrations mro problems
Sep 14, 2022
b1845e4
refactor url to re_path for django 3 update to avoid annoying depreci…
Sep 14, 2022
95c9c83
Fix middleware order and replace deprecated staticfiles with static
Sep 14, 2022
ba02936
remove nullboolean fields to prevent depreciation warning
Sep 14, 2022
fd42db4
fix admin app depreciating staticfiles for Django 3 upgrade
Sep 14, 2022
dd377cc
Fix and rework from_db_value & to_python for EncryptedJSONField
cslzchen Sep 14, 2022
5f7fd3b
Merge branch 'feature/django_upgrade' of https://github.com/CenterFor…
Sep 15, 2022
b57c74e
fix admin login failure for django upgrade
Sep 15, 2022
93081d4
Fix admin login failure for django upgrade
Sep 15, 2022
b58c17f
upgrade to end dependabot warnings
Johnetordoff Sep 19, 2022
5a24b8f
Merge branch 'feature/django_upgrade' of https://github.com/CenterFor…
Sep 19, 2022
3f6a665
more dependabot updates
Sep 19, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion addons/osfstorage/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -411,7 +411,7 @@ def save(self, skip_search=False, *args, **kwargs):

class OsfStorageFolder(OsfStorageFileNode, Folder):

is_root = models.NullBooleanField()
is_root = models.BooleanField(null=True, blank=True)

objects = OsfStorageFolderManager()

Expand Down
2 changes: 1 addition & 1 deletion api/preprints/serializers.py
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ class PreprintSerializer(TaxonomizableSerializerMixin, MetricsSerializerMixin, J
},
)

has_coi = ser.NullBooleanField(required=False)
has_coi = ser.BooleanField(required=False, allow_null=True)
conflict_of_interest_statement = ser.CharField(required=False, allow_blank=True, allow_null=True)
has_data_links = ser.ChoiceField(Preprint.HAS_LINKS_CHOICES, required=False)
why_no_data = ser.CharField(required=False, allow_blank=True, allow_null=True)
Expand Down
24 changes: 12 additions & 12 deletions osf/migrations/0001_initial.py
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@ class Migration(migrations.Migration):
('description', models.TextField(blank=True, default='')),
('category', models.CharField(blank=True, choices=[('analysis', 'Analysis'), ('communication', 'Communication'), ('data', 'Data'), ('hypothesis', 'Hypothesis'), ('instrumentation', 'Instrumentation'), ('methods and measures', 'Methods and Measures'), ('procedure', 'Procedure'), ('project', 'Project'), ('software', 'Software'), ('other', 'Other'), ('', 'Uncategorized')], default='', max_length=255)),
('registration_responses', osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONField(blank=True, default=dict, encoder=osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONEncoder)),
('registration_responses_migrated', models.NullBooleanField(db_index=True, default=True)),
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Wondering if we should make a new migration rather than modifying the init migration?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, I think that's necessary for prod/staging.

('registration_responses_migrated', models.BooleanField(null=True, db_index=True, default=True)),
('type', models.CharField(choices=[('osf.node', 'node'), ('osf.draftnode', 'draft node'), ('osf.registration', 'registration'), ('osf.quickfilesnode', 'quick files node')], db_index=True, max_length=255)),
('child_node_subscriptions', osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONField(blank=True, default=dict, encoder=osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONEncoder)),
('deleted_date', osf.utils.fields.NonNaiveDateTimeField(blank=True, null=True)),
Expand All @@ -128,7 +128,7 @@ class Migration(migrations.Migration):
('is_fork', models.BooleanField(db_index=True, default=False)),
('is_public', models.BooleanField(db_index=True, default=False)),
('is_deleted', models.BooleanField(db_index=True, default=False)),
('access_requests_enabled', models.NullBooleanField(db_index=True, default=True)),
('access_requests_enabled', models.BooleanField(null=True, db_index=True, default=True)),
('custom_citation', models.TextField(blank=True, null=True)),
('comment_level', models.CharField(default='public', max_length=10)),
('article_doi', models.CharField(blank=True, max_length=128, null=True, validators=[osf.models.validators.validate_doi])),
Expand All @@ -139,10 +139,10 @@ class Migration(migrations.Migration):
('wiki_private_uuids', osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONField(blank=True, default=dict, encoder=osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONEncoder)),
('keenio_read_key', models.CharField(blank=True, max_length=1000, null=True)),
('registered_date', osf.utils.fields.NonNaiveDateTimeField(blank=True, db_index=True, null=True)),
('external_registration', models.NullBooleanField(default=False)),
('external_registration', models.BooleanField(null=True, default=False)),
('registered_meta', osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONField(blank=True, default=dict, encoder=osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONEncoder, null=True)),
('files_count', models.PositiveIntegerField(blank=True, null=True)),
('branched_from_node', models.NullBooleanField()),
('branched_from_node', models.BooleanField(null=True)),
('moderation_state', models.CharField(choices=[('undefined', 'Undefined'), ('initial', 'Initial'), ('reverted', 'Reverted'), ('pending', 'Pending'), ('rejected', 'Rejected'), ('accepted', 'Accepted'), ('embargo', 'Embargo'), ('pending_embargo_termination', 'PendingEmbargoTermination'), ('pending_withdraw_request', 'PendingWithdrawRequest'), ('pending_withdraw', 'PendingWithdraw'), ('withdrawn', 'Withdrawn')], default='initial', max_length=30, null=True)),
('ia_url', models.URLField(blank=True, help_text='Where the archive.org data for the registration is stored', null=True)),
('additional_metadata', osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONField(blank=True, encoder=osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONEncoder, null=True)),
Expand All @@ -161,8 +161,8 @@ class Migration(migrations.Migration):
('modified', django_extensions.db.fields.ModificationDateTimeField(auto_now=True, verbose_name='modified')),
('_id', models.CharField(db_index=True, default=osf.models.base.generate_object_id, max_length=24)),
('reviews_workflow', models.CharField(blank=True, choices=[(None, 'None'), ('pre-moderation', 'Pre-Moderation'), ('post-moderation', 'Post-Moderation')], max_length=15, null=True)),
('reviews_comments_private', models.NullBooleanField()),
('reviews_comments_anonymous', models.NullBooleanField()),
('reviews_comments_private', models.BooleanField(null=True)),
('reviews_comments_anonymous', models.BooleanField(null=True)),
('type', models.CharField(choices=[('osf.collectionprovider', 'collection provider'), ('osf.registrationprovider', 'registration provider'), ('osf.preprintprovider', 'preprint provider')], db_index=True, max_length=255)),
('name', models.CharField(max_length=128)),
('advisory_board', models.TextField(blank=True, default='')),
Expand All @@ -189,9 +189,9 @@ class Migration(migrations.Migration):
('share_title', models.TextField(blank=True, default='')),
('doi_prefix', models.CharField(blank=True, max_length=32, null=True)),
('additional_metadata_fields', osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONField(blank=True, encoder=osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONEncoder, null=True)),
('bulk_upload_auto_approval', models.NullBooleanField(default=False)),
('allow_updates', models.NullBooleanField(default=False)),
('allow_bulk_uploads', models.NullBooleanField(default=False)),
('bulk_upload_auto_approval', models.BooleanField(null=True, default=False)),
('allow_updates', models.BooleanField(null=True, default=False)),
('allow_bulk_uploads', models.BooleanField(null=True, default=False)),
('additional_providers', django.contrib.postgres.fields.ArrayField(base_field=models.CharField(max_length=200), blank=True, default=list, null=True, size=None)),
('preprint_word', models.CharField(choices=[('preprint', 'Preprint'), ('paper', 'Paper'), ('thesis', 'Thesis'), ('work', 'Work'), ('none', 'None')], default='preprint', max_length=10, null=True)),
('subjects_acceptable', osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONField(blank=True, default=list, encoder=osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONEncoder, null=True)),
Expand Down Expand Up @@ -354,7 +354,7 @@ class Migration(migrations.Migration):
('deleted_on', osf.utils.fields.NonNaiveDateTimeField(blank=True, null=True)),
('deleted', osf.utils.fields.NonNaiveDateTimeField(blank=True, null=True)),
('purged', osf.utils.fields.NonNaiveDateTimeField(blank=True, null=True)),
('is_root', models.NullBooleanField()),
('is_root', models.BooleanField(blank=True, null=True)),
('checkout', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
('copied_from', models.ForeignKey(blank=True, default=None, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='copy_of', to='osf.BaseFileNode')),
('deleted_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='files_deleted_by', to=settings.AUTH_USER_MODEL)),
Expand Down Expand Up @@ -612,7 +612,7 @@ class Migration(migrations.Migration):
('description', models.TextField(blank=True, default='')),
('category', models.CharField(blank=True, choices=[('analysis', 'Analysis'), ('communication', 'Communication'), ('data', 'Data'), ('hypothesis', 'Hypothesis'), ('instrumentation', 'Instrumentation'), ('methods and measures', 'Methods and Measures'), ('procedure', 'Procedure'), ('project', 'Project'), ('software', 'Software'), ('other', 'Other'), ('', 'Uncategorized')], default='', max_length=255)),
('registration_responses', osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONField(blank=True, default=dict, encoder=osf.utils.datetime_aware_jsonfield.DateTimeAwareJSONEncoder)),
('registration_responses_migrated', models.NullBooleanField(db_index=True, default=True)),
('registration_responses_migrated', models.BooleanField(null=True, db_index=True, default=True)),
('title', models.TextField(blank=True, default='', validators=[osf.models.validators.validate_title])),
('datetime_initiated', osf.utils.fields.NonNaiveDateTimeField(auto_now_add=True)),
('datetime_updated', osf.utils.fields.NonNaiveDateTimeField(auto_now=True)),
Expand Down Expand Up @@ -1238,7 +1238,7 @@ class Migration(migrations.Migration):
('deleted', osf.utils.fields.NonNaiveDateTimeField(blank=True, null=True)),
('migrated', osf.utils.fields.NonNaiveDateTimeField(blank=True, null=True)),
('conflict_of_interest_statement', models.TextField(blank=True, null=True)),
('has_coi', models.NullBooleanField()),
('has_coi', models.BooleanField(null=True)),
('has_prereg_links', models.TextField(blank=True, choices=[('available', 'Available'), ('no', 'No'), ('not_applicable', 'Not applicable')], null=True)),
('why_no_prereg', models.TextField(blank=True, null=True)),
('prereg_links', django.contrib.postgres.fields.ArrayField(base_field=models.URLField(blank=True, null=True), blank=True, null=True, size=None)),
Expand Down
6 changes: 3 additions & 3 deletions osf/models/mixins.py
Original file line number Diff line number Diff line change
Expand Up @@ -966,8 +966,8 @@ class Meta:
abstract = True

reviews_workflow = models.CharField(null=True, blank=True, max_length=15, choices=Workflows.choices())
reviews_comments_private = models.NullBooleanField()
reviews_comments_anonymous = models.NullBooleanField()
reviews_comments_private = models.BooleanField(null=True, blank=True)
reviews_comments_anonymous = models.BooleanField(null=True, blank=True)

DEFAULT_SUBSCRIPTIONS = ['new_pending_submissions']

Expand Down Expand Up @@ -2165,7 +2165,7 @@ class RegistrationResponseMixin(models.Model):
Mixin to be shared between DraftRegistrations and Registrations.
"""
registration_responses = DateTimeAwareJSONField(default=dict, blank=True)
registration_responses_migrated = models.NullBooleanField(default=True, db_index=True)
registration_responses_migrated = models.BooleanField(null=True, default=True, db_index=True)

def get_registration_metadata(self, schema):
raise NotImplementedError()
Expand Down
2 changes: 1 addition & 1 deletion osf/models/node.py
Original file line number Diff line number Diff line change
Expand Up @@ -329,7 +329,7 @@ class AbstractNode(DirtyFieldsMixin, TypedModel, AddonModelMixin, IdentifierMixi
is_fork = models.BooleanField(default=False, db_index=True)
is_public = models.BooleanField(default=False, db_index=True)
is_deleted = models.BooleanField(default=False, db_index=True)
access_requests_enabled = models.NullBooleanField(default=True, db_index=True)
access_requests_enabled = models.BooleanField(null=True, default=True, db_index=True)

custom_citation = models.TextField(blank=True, null=True)

Expand Down
2 changes: 1 addition & 1 deletion osf/models/preprint.py
Original file line number Diff line number Diff line change
Expand Up @@ -206,7 +206,7 @@ class Preprint(DirtyFieldsMixin, GuidMixin, IdentifierMixin, ReviewableMixin, Ba
blank=True,
null=True,
)
has_coi = models.NullBooleanField(
has_coi = models.BooleanField(
blank=True,
null=True
)
Expand Down
6 changes: 3 additions & 3 deletions osf/models/provider.py
Original file line number Diff line number Diff line change
Expand Up @@ -287,9 +287,9 @@ class RegistrationProvider(AbstractProvider):
# [{'field_name': 'foo'}, {'field_name': 'bar'}]
additional_metadata_fields = DateTimeAwareJSONField(blank=True, null=True)
default_schema = models.ForeignKey('osf.registrationschema', related_name='default_schema', null=True, blank=True, on_delete=models.SET_NULL)
bulk_upload_auto_approval = models.NullBooleanField(default=False)
allow_updates = models.NullBooleanField(default=False)
allow_bulk_uploads = models.NullBooleanField(default=False)
bulk_upload_auto_approval = models.BooleanField(null=True, default=False)
allow_updates = models.BooleanField(null=True, default=False)
allow_bulk_uploads = models.BooleanField(null=True, default=False)

def __init__(self, *args, **kwargs):
self._meta.get_field('share_publish_type').default = 'Registration'
Expand Down
4 changes: 2 additions & 2 deletions osf/models/registrations.py
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ class Registration(AbstractNode):

# This is a NullBooleanField because of inheritance issues with using a BooleanField
# TODO: Update to BooleanField(default=False, null=True) when Django is updated to >=2.1
external_registration = models.NullBooleanField(default=False)
external_registration = models.BooleanField(null=True, default=False)
registered_user = models.ForeignKey(OSFUser,
related_name='related_to',
on_delete=models.SET_NULL,
Expand Down Expand Up @@ -136,7 +136,7 @@ class Registration(AbstractNode):
null=True, blank=True,
on_delete=models.SET_NULL)
files_count = models.PositiveIntegerField(blank=True, null=True)
branched_from_node = models.NullBooleanField(blank=True, null=True)
branched_from_node = models.BooleanField(null=True, blank=True)

moderation_state = models.CharField(
max_length=30,
Expand Down