Skip to content

Conversation

@andrepapoti
Copy link

@andrepapoti andrepapoti commented Apr 1, 2024

Description

Add the relation between an user and a patch through the Patch's interested_users attribute.
This relations happens through the model PatchInterest that contains a timestamp for when the interest was declared.
Inside a Patch's State there's now an attribute indicating how long an interest can last before it expires.
To remove expired interests async tasks were added using Celery
Serializers and Forms were update to reflect the changes aswell

Related

@andrepapoti andrepapoti marked this pull request as draft April 5, 2024 04:10
@stephenfin
Copy link
Member

I have seen this 👀 but I'm going to leave comments on the issue and discuss things there before looking at this.

@andrepapoti andrepapoti marked this pull request as ready for review April 8, 2024 16:13
@andrepapoti andrepapoti marked this pull request as draft April 15, 2024 19:38
@andrepapoti andrepapoti force-pushed the i507 branch 3 times, most recently from 4e1c212 to 2eb1ae1 Compare April 17, 2024 15:42
@andrepapoti andrepapoti marked this pull request as ready for review April 17, 2024 15:42
@hero24
Copy link

hero24 commented Oct 23, 2024

I am not certain this solves #507. I can see from the code that there have been changes to model and patch structures to store users interested in the patch, but I don't see anywhere changes to actual user interface. I also run this code using docker-compose on my machine and I don't see any way to show interest in the patch? Am I missing something?

@andrepapoti
Copy link
Author

@hero24 were you unable to declare interest on a patch when running it on a container?

I missed to add a button for it on the UI, I'll add an extra commit with it

@hero24
Copy link

hero24 commented Nov 1, 2024

@andrepapoti I will retest this later and let you know if it works through API for me, When I was testing this, I focused on web interface. I think most people use patchwork through web interface (it would actually be an interesting metric to conduct, but that beyond of the scope), but yes I could not find an add interest button through web, or any other way to declare interest through web interface.

@hero24
Copy link

hero24 commented Nov 1, 2024

As I said earlier I gave this a run and tried looking at it through API. The code crashes, like the other PR, when I access through web /api/patches/XXX/ patchwork crashes. Seems like its user permissions, but it can't crash on api call to patch details, and this works without this PR on standard patchwork code. Attaching screenshot.
Screenshot 2024-11-01 at 21 29 05

Copy link
Contributor

@victor-accarini victor-accarini left a comment

Choose a reason for hiding this comment

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

Seems to be working didn't check the cronjob though

@victor-accarini
Copy link
Contributor

@stephenfin I took a closer look into this feature and from the issue it seems we should only be able to declare interest in a series and not on specific patches, is this correct? Also how the interest should be handled in the case of another series superseding the current one, the review should be moved to the new series or should just be deleted?

Copy link
Member

@stephenfin stephenfin left a comment

Choose a reason for hiding this comment

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

This is looking pretty good. There are, however, three main changes I'd like to see:

  • Rename the models and fields, per comments.
  • Ensure attention set entries can be "soft deleted", so that maintainers can tell that one existed in the past
  • Consider dropping the concept stale review requests from Patchwork itself and instead document how one can do this via the API.

]


class PatchReviewIntention(models.Model):
Copy link
Member

Choose a reason for hiding this comment

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

I quite like the "attention set" term since it allows us to capture both a review intention and a review request. Can we use it?

Suggested change
class PatchReviewIntention(models.Model):
class PatchAttentionSet(models.Model):

class PatchReviewIntention(models.Model):
patch = models.ForeignKey(Patch, on_delete=models.CASCADE)
user = models.ForeignKey(User, on_delete=models.CASCADE)
last_time_marked_for_review = models.DateTimeField(default=tz_utils.now)
Copy link
Member

Choose a reason for hiding this comment

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

Can we rename this field to simply last_updated. I also wonder if we could/should track removals from this set? If we do, I think we likely only need to track the most recent request.

Suggested change
last_time_marked_for_review = models.DateTimeField(default=tz_utils.now)
last_updated = models.DateTimeField(auto_now=True)
removed = models.BooleanField(default=False)
removed_reason = models.CharField(max_length=50)

last_time_marked_for_review = models.DateTimeField(default=tz_utils.now)

class Meta:
unique_together = [('patch', 'user')]
Copy link
Member

Choose a reason for hiding this comment

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

Assuming the above.

Suggested change
unique_together = [('patch', 'user')]
unique_together = [('patch', 'user', 'removed')]

Copy link
Member

Choose a reason for hiding this comment

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

Because the GitHub UI won't let me leave comments on the commit message: please wrap commit messages at <= 72 characters.

class Migration(migrations.Migration):
dependencies = [
('patchwork', '0047_add_database_indexes'),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
Copy link
Member

Choose a reason for hiding this comment

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

I'm guessing this was auto-generated? I didn't see it pop up in the most recent series. Could you regenerate this?

for review_data in data:
user_id = review_data['user']
if request.user.id == reviewing_user:
if request.user.id == user_id:
Copy link
Member

Choose a reason for hiding this comment

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

Can you squash this change back into the earlier commit that added this view.

'hash',
'submitter',
'delegate',
'planning_to_review',
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change
'planning_to_review',
'attention_set',

'submitter',
'delegate',
'planning_to_review',
'has_planned_review',
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change
'has_planned_review',

Comment on lines 268 to 269
intereted_user = patchreviewintention_set.pop()['user']
instance.planning_to_review.add(intereted_user.id)
Copy link
Member

Choose a reason for hiding this comment

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

s/intereted/interested/

return super(PatchDetailSerializer, self).update(
instance, validated_data
)
return
Copy link
Member

Choose a reason for hiding this comment

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

Is this correct? Could you add a comment explaining why we're returning without calling super()?

Patches that needs the attention of a specific user can now be linked to
them by the attention set field.

Attention flags by default are soft deleted.

Signed-off-by: andrepapoti <[email protected]>
Signed-off-by: Victor Accarini <[email protected]>
Users can now add/remove themselves from a patch attention list if they
want to sinalize that they will look into it.

To add themselves to the attention list they must execute a patch with a
list with their IDs in the `attention_set` property. To remove
themselves they must send a list with their negative IDs or an empty
list.

Maintainers can also remove anyone from the attention list by sending a
list with negative IDs.

Signed-off-by: andrepapoti <[email protected]>
Signed-off-by: Victor Accarini <[email protected]>
@victor-accarini
Copy link
Contributor

victor-accarini commented Mar 21, 2025

@stephenfin I executed some of the request changes but also refactored a little @andrepapoti solution.

  • There were some inconsistencies in how the application behaved in the API and the web, I updated both to have similar behavior.
  • Now we can add/remove users in the attention set from the admin interface
  • Fixed a permission bug allowing non-maintainers to update patches if they had 'attention_set' defined in the payload
  • Moved the permission check for the update function (since is a specific use-case we don't need to make it more complex that needed right now)
  • Had to adapt a solution for updating the attention_set + soft_delete

Edit:

  • I also removed the 'soft-delete' attribute from the unique contraints since I'm always updating the existing ones.

@victor-accarini
Copy link
Contributor

@stephenfin any news about this issue?

andrepapoti and others added 2 commits May 8, 2025 19:49
* List view: show number of users interested in a specific patch
* Detail view: show a list of users who are interested in the patch
    * Allow users to add/remove interest in a patch
    * Allow managers to remove interested user from a patch

Signed-off-by: Victor Accarini <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Allow non-delegates to claim interest in a series

4 participants