wait-for-github ci
can report failures when GitHub's UI shows success
#181
Labels
good-first-issue
Good issue for new contributors to the project: not too simple, and would have decent impact
For an internal usecase (a rollout), we ran
wait-for-github
on grafana/pyroscope@6e6a073.wait-for-github
failed and blocked the rollout. Running it right now shows the same:GitHub's UI shows this as a success.
I do see that if you ask for all check runs the Dependabot one fails.
Let's take a look at what is happening. We can call the API to list the check runs, which is what
wait-for-github
does (as well as looking at the statuses which is OK here: there aren't any and we correctly handle that). Running:gives:
But thinking about what Dependabot is, it's not something you run from Actions directly - GitHub runs it for you. I don't know why they expose it as a check run but it doesn't seem like we should be considering that the commit has failed due to it. The output also doesn't appear in the list of check runs attached to the commit in the UI.
Basically we want to replicate the ✔/❌ that GitHub shows you on a commit.
I had a deeper look around on the interwebs and I found a
StatusCheckRollup
field on the GraphQL API. What we're doing inwait-for-github
at the minute is trying to replicate this using the REST API and we haven't been able to get it quite right yet. (I just started a discussion asking if this can be made easier.)Right now it seems to me like using that method from the GraphQL API is going to be our best path forward to get reliable results.
For that we'd use https://github.com/shurcooL/graphql (making sure to give it the same caching retryable transport we already give to the REST client), constructing a query something like this:
which gives:
There are other fields on that object too which might be interesting - you can select the relevant statuses and checks so we could say which ones are causing us to fail (see the docs, and also the GraphQL Explorer is very useful for playing).
For whoever works on this, I suggest checking the results of this query in a variety of situations such as:
And if it all looks good / can be solved then this would be a good API to use!
The text was updated successfully, but these errors were encountered: