-
Notifications
You must be signed in to change notification settings - Fork 94
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
Process deleting projects as background task #1060
base: main
Are you sure you want to change the base?
Conversation
1. Fix Default Filtering in ProjectFilterSet: - Modified the `ProjectFilterSet` to include `is_marked_for_deletion` in the default filtering when `is_archived` is not provided. - This ensures that projects marked for deletion are excluded from default views. 2. Migration for `is_marked_for_deletion`: - Added a migration (`0052_project_is_marked_for_deletion.py`) to introduce the `is_marked_for_deletion` field in the `Project` model. 3. Updated `Project` Model: - Added `is_marked_for_deletion` field to the `Project` model with a default value of `False`. 4. Modified `ProjectListView` to Exclude Marked Projects: - Modified the `get_queryset` method in `ProjectListView` to only fetch projects with `is_marked_for_deletion=False`. 5. Introduced `mark_for_deletion` Method: - Added a `mark_for_deletion` method in the `Project` model to set the `is_marked_for_deletion` flag and save the model. 6. Add `delete_in_background` Method in `Project` Model: - Introduced a new `delete_in_background` method that marks the project for deletion and enqueues a background deletion task. 7. Background Deletion Task: - Created a background deletion task using `django_rq` to handle project deletion asynchronously. - Checks if the project is still marked for deletion before proceeding. - If an error occurs during deletion, updates project status and logs an error. 8. Updated `ProjectActionView` Success Message: - Modified the success message in `ProjectActionView` for the "delete" action to provide a more informative message based on the count. Fixes: aboutcode-org#1002 Signed-off-by: Jayanth Kumar <jknani111@gmail.com>
6b5ca98
to
dc7b4b4
Compare
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.
Pretty good start. See my comments for improvements.
This is a good approach and well explained... it is likely missing not much to get this merged... @jayanth-kumar-morem do you mind looking into some of the comments? |
d6f4c43
to
5136eaf
Compare
- Remove comments - Use django rq - Use update instead of save Signed-off-by: Jayanth Kumar <jknani111@gmail.com>
5136eaf
to
bb312f7
Compare
|
||
active_count = Project.objects.filter(is_archived=False).count() | ||
active_count = Project.objects.filter( | ||
is_archived=False, is_marked_for_deletion=False |
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.
We should use active()
here as well, no?
|
||
def delete_in_background(self): | ||
# Mark the project for deletion and enqueue background deletion task | ||
self.mark_for_deletion() |
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.
I think we can put self.update(is_marked_for_deletion=True)
directly here, no need for the mark_for_deletion
method yet since it's a one-liner that is only used in one place.
self.update(is_marked_for_deletion=True) | ||
|
||
def delete_in_background(self): | ||
# Mark the project for deletion and enqueue background deletion task |
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.
A docstring would be better than a comment.
project.delete() | ||
except Exception as e: | ||
info(f"Deletion failed: {str(e)}", project.pk) | ||
project.update(is_marked_for_deletion=True) |
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.
I'm wondering is this line is of any use, the is_marked_for_deletion
must be already True to reach this line, no?
Merge remote-tracking branch 'upstream/main' into 1002
Fix Default Filtering in ProjectFilterSet:
ProjectFilterSet
to includeis_marked_for_deletion
in the default filtering whenis_archived
is not provided.Migration for
is_marked_for_deletion
:0052_project_is_marked_for_deletion.py
) to introduce theis_marked_for_deletion
field in theProject
model.Updated
Project
Model:is_marked_for_deletion
field to theProject
model with a default value ofFalse
.Modified
ProjectListView
to Exclude Marked Projects:get_queryset
method inProjectListView
to only fetch projects withis_marked_for_deletion=False
.Introduced
mark_for_deletion
Method:mark_for_deletion
method in theProject
model to set theis_marked_for_deletion
flag and save the model.Changed
delete
Method inProject
Model:delete
method todelete_action
in theProject
model to avoid conflicts.delete
method that marks the project for deletion and enqueues a background deletion task.Background Deletion Task:
django_rq
to handle project deletion asynchronously.Updated
ProjectActionView
Success Message:ProjectActionView
for the "delete" action to provide a more informative message based on the count.Fixes: #1002