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

Add option to skip verifying the dependabot user internally #332

Closed
jeffwidman opened this issue Apr 6, 2023 · 5 comments
Closed

Add option to skip verifying the dependabot user internally #332

jeffwidman opened this issue Apr 6, 2023 · 5 comments
Labels
enhancement New feature or request

Comments

@jeffwidman
Copy link
Member

jeffwidman commented Apr 6, 2023

@yeikel pointed out that we don't need to do the internal check within the action if we recommend on the Readme that users check the user before executing the action:

I think this is the reason the check exists within the code... the concern is that users may not realize they need to set that, and so may fire off spurious requests... so it's defensive coding to protect the API from ignorant/careless users.

That said, I agree the volume of calls here is probably pretty low, so it may be fine to remove this... 🤷‍♂️

Removing it would simplify the code / config complexity since the DEPENDABOT_LOGIN const and associated logic of letting users customize the user simply disappears...

@jeffwidman jeffwidman added the enhancement New feature or request label Apr 6, 2023
@jeffwidman
Copy link
Member Author

I'm going to run this by the team internally to see what folks think...

@yeikel
Copy link
Contributor

yeikel commented Apr 7, 2023

I think that the only downside of implementing this is that we will need to release a new breaking version and inform the users about it.

Other than that, I assume that most users will copy/paste the examples

@jeffwidman
Copy link
Member Author

From @brrygrdn via slack:

As I recall, the intent of that method was to avoid anyone tacking on additional commits or force-pushing an edited commit that would trigger a user's automation. The reason we do the 'belt-and-braces' in the workflow is more about avoiding jobs running on every PR ending in errors rather than just skipping.

I think the intent that content should be verified as best possible is still worthwhile because people are using this as a gateway to automerging, etc, so as an official action I think we should avoid trusting the content by default.

Adding an option to disable content verification seems ok though as in that case the user knows what they are doing and has taken the safety catch off.

On the surface that makes sense to me, I hadn't even considered the case of someone tacking on additional commits to an existing Dependabot PR.

However, the funky part is that the logic is not checking the author of the last commit, it's checking the PR author:

// Don't bother hitting the API if the PR author isn't Dependabot
if (pr.user.login !== DEPENDABOT_LOGIN) {
core.debug(`PR author '${pr.user.login}' is not Dependabot.`)
return false

And on the flip side, only checking the PR author makes sense for the cases where someone has automation for an additional commit on every :dependabot: PR, such as using https://github.com/jonabc/licensed-ci.

So that kinda prevents us fully switching to checking the latest commit author rather than PR author.

That said, I'm still fine with leaving the existing check for defensive purposes, but does mean we could probably loosen the API over in #331 from specifying a custom user to simple on/off of enforcing the in-code check.

@brrygrdn feel free to add mroe comments if I'm misunderstanding or overlooking something.

@cysp
Copy link

cysp commented Apr 13, 2023

For a data point, I've occasionally manually combined the changes from multiple Dependabot PRs in cases where it doesn't make sense for the individual package updates to be applied separately (e.g. @sentry/* where all package versions need to be kept aligned to result in a working system, but Dependabot today raises separate PRs for each directly-referenced dependency).
When I've done that, I've also gone and manually combined the metadata stanzas in the resulting commit message to indicate the now-combined update being applied. To me, that seems like a completely valid use case where I would want any tooling that reads this metadata to read the updated metadata even though my user had committed (and potentially authored) the commit. 🙂

jeffwidman pushed a commit that referenced this issue Apr 17, 2023
Add a `skip-verification` (boolean) option:
 
 - If `true`, the action will not validate the user or the commit verification status
 - Defaults to `false`

Allows for scenarios where users want to add or amend commits on the Dependabot PR, and those commits will not come from the :dependabot: user.

There's a fair bit of discussion on this use case and also why this isn't the default behavior, see:
* #336
* #332
@jeffwidman jeffwidman changed the title No need to verify the dependabot user internally Add option to skip verifying the dependabot user internally Apr 17, 2023
@jeffwidman
Copy link
Member Author

Fixed by #336

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

3 participants