-
Notifications
You must be signed in to change notification settings - Fork 332
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
Changes from 1 commit
7c3b9ad
4a8bd61
bf7eb21
15f15e9
5746a84
c2c5e4e
f22e531
250b832
8052ea4
65b344b
205e560
1675f6f
391af60
c9c7f44
721ef90
75ffbb0
285d9a6
06f6fe9
724f59a
afa62a7
d15c88f
3f162f1
f971149
f41eb8a
dab1bbc
994fcfd
a54bbbe
699fc1c
0dc9220
cfb012e
cb25d71
720b6ec
6b7ce7f
0192907
51f4f48
41d4b50
65f39c8
0ad3f7c
a2dc7ba
2a0aa6e
66edda0
37bd4e4
bcd2c6e
88c057e
0ce6496
fc0d032
2fbc057
eb93348
07ee7e6
9e9c487
4e19413
d10824f
4e56c87
68acb17
57e81a6
0bc3d5c
7d3c644
51a6b1b
e21b460
1a70f61
f30f1ce
fca9e81
dffad34
db10898
0c1cc03
494e396
6548110
0bb5fc5
d69128c
7f6219b
3f97cd6
ec4da2f
6f64b38
6dcb706
b1845e4
95c9c83
ba02936
fd42db4
dd377cc
5f7fd3b
b57c74e
93081d4
b58c17f
5a24b8f
3f6a665
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -979,7 +979,7 @@ def test_comments_move_when_file_moved_from_project_to_component(self, project, | |
self.file.move_under(destination['node'].get_addon(self.provider).get_root()) | ||
payload = self._create_payload('move', user, source, destination, self.file._id) | ||
update_file_guid_referent(self=None, target=destination['node'], event_type='addon_file_moved', payload=payload) | ||
self.guid.reload() | ||
self.guid.referent.reload() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This fix makes sense since Django My concern is, given that we use Behavior of 1.11: doc, code In addition, our customization of the 1.11
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. More Update: We were using f.is_relation and f.many_to_one and not (hasattr(f.remote_field, 'model') and f.remote_field.model) which, can be found in private APIs from the source code of django.db.models.options. And An issue with refreshing related fields is that it can cause infinite loop, as confirmed in local shell. |
||
|
||
file_node = BaseFileNode.resolve_class(self.provider, BaseFileNode.FILE).get_or_create(destination['node'], self._format_path(destination['path'], file_id=self.file._id)) | ||
assert self.guid._id == file_node.get_guid()._id | ||
|
@@ -1002,7 +1002,7 @@ def test_comments_move_when_file_moved_from_component_to_project(self, project, | |
self.file.move_under(destination['node'].get_addon(self.provider).get_root()) | ||
payload = self._create_payload('move', user, source, destination, self.file._id) | ||
update_file_guid_referent(self=None, target=destination['node'], event_type='addon_file_moved', payload=payload) | ||
self.guid.reload() | ||
self.guid.referent.reload() | ||
|
||
file_node = BaseFileNode.resolve_class(self.provider, BaseFileNode.FILE).get_or_create(destination['node'], self._format_path(destination['path'], file_id=self.file._id)) | ||
assert self.guid._id == file_node.get_guid()._id | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -111,8 +111,9 @@ def handle_archive_fail(reason, src, dst, user, result): | |
pass | ||
else: # reason == ARCHIVER_UNCAUGHT_ERROR | ||
send_archiver_uncaught_error_mails(src, user, result, url) | ||
dst.root.sanction.forcibly_reject() | ||
dst.root.sanction.save() | ||
if dst.root.sanction: | ||
dst.root.sanction.forcibly_reject() | ||
dst.root.sanction.save() | ||
Comment on lines
-114
to
+116
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Looking at the Here are the failures that probably led to this fix.
However, I think the correct fix should be on the RegistrationFactory instead of the actual code. Otherwise, the two lines inside the dst.root.sanction.forcibly_reject()
dst.root.sanction.save() |
||
dst.root.delete_registration_tree(save=True) | ||
|
||
def archive_provider_for(node, user): | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -49,6 +49,7 @@ def update_file_guid_referent(self, target, event_type, payload, user=None): | |
old_file = BaseFileNode.load(obj.referent._id) | ||
obj.referent = create_new_file(obj, source, destination, destination_node) | ||
obj.save() | ||
obj.referent.reload() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. hmm, why do we need to reload the referent object when we are not using it at all afterwards? Update: as expected, I verified that we don't need this |
||
if old_file and not TrashedFileNode.load(old_file._id): | ||
old_file.delete() | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Comment: we use
reload()
andrefresh_from_db()
interchangeably, though they are the same, see here.