-
Notifications
You must be signed in to change notification settings - Fork 770
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
Support Pull Requests #739
Conversation
🎉 excited for this one, thanks for the contribution! I'm overall 👍🏾 on the data sources, but would like to think more about the new pull request resource. This project has considered adding a resource to manage Pull Requests in the past but shied away from it in favour of the I've added this to the milestone after next and hope to hear more opinions around the implementation when revisiting. 🙇🏾 for the patience while this one works its way through the release process. |
Thanks @jcudit, please LMK if I can be of any assistance. |
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.
Thanks again for making these available for everyone! Excited to see how these resources get used in the wild.
* Support Pull Requests * fixup! typo in description Co-authored-by: Jeremy Udit <[email protected]>
Use case
Frankly, I only came here to get a list of open pull requests from Terraform (the
github_repository_pull_requests
data source), but I wouldn't be able to test it properly without the ability to create PRs from Terraform, so here we go. My immediate use case for this feature is test/QA/preview (every company has their own name) environments automatically created from open Pull Requests and kept alive while these remain open. It goes something like this:The
source
module can then contain the definition of a Terraform project in form of aspacelift_stack
or atfe_workspace
, pointing to the head branch of the PR. I'm sure there are plenty other use cases, but this is what I personally need it for.Notes
Below are some of the notes I've been taking when researching and working on this diff. Hopefully they can shed some light on my decisions and help with the review.
Forks are supported
I assumed that the resource should support pull requests between forks. Not sure how frequent that use case would be in practice, but the extra cost was negligible. In the API, the "owner" field can be optionally supplied to explicitly indicating the owner of the repo to which we're trying to upstream our changes. I also called a field called "repository" in most other resources "base_repository" to make a clear distinction between (potentially) 2 repositories involved in creating a PR.
Deleting Pull Requests
It's not entirely clear how to treat PR deletion according to Terraform's CRUD semantics. The approach I've taken here is to close the PR unless it's already closed or merged in GitHub. Merging it (a "positive" action) feels intuitively wrong in what effectively is a destructor (a "negative" action).
Drafts
Creating drafts is not supported. While the v3 API call itself allows you mark the PR as draft when creating it, it does not allow you to change this setting afterwards. Hence, Terraform cannot manage the lifecycle of this field, and I decided to make it computed instead.