-
Notifications
You must be signed in to change notification settings - Fork 6.8k
Added repeats for github status updates #14530
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -186,18 +186,27 @@ def update_github_commit_status(state, message) { | |
context = get_github_context() | ||
echo "context=${context}" | ||
|
||
step([ | ||
$class: 'GitHubCommitStatusSetter', | ||
reposSource: [$class: "ManuallyEnteredRepositorySource", url: repoUrl], | ||
contextSource: [$class: "ManuallyEnteredCommitContextSource", context: context], | ||
commitShaSource: [$class: "ManuallyEnteredShaSource", sha: commitSha], | ||
statusBackrefSource: [$class: "ManuallyEnteredBackrefSource", backref: "${env.RUN_DISPLAY_URL}"], | ||
errorHandlers: [[$class: 'ShallowAnyErrorHandler']], | ||
statusResultSource: [ | ||
$class: 'ConditionalStatusResultSource', | ||
results: [[$class: "AnyBuildResult", message: message, state: state]] | ||
] | ||
]) | ||
// a few attempts need to be made: /~https://github.com/apache/incubator-mxnet/issues/11654 | ||
for (int attempt = 1; attempt < 4; attempt++) { | ||
echo "Sending GitHub status attempt ${attempt}..." | ||
|
||
step([ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't understand few points here
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @vishaalkapoor I mentioned the answers in the description, but here they are again explicitly:
There is no known to me way to determine if step was a success. In case of a real failure the step just does nothing - the list of repositories it needs to update is empty.
I needed to look in Wikipedia what Idempotence actually is and found out that yes, the operation is idempotent.
The repository object can not be fetched from a cache for some reason by GitHubCommitStatusSetter. This happens once in a while and became a significant problem because we have split the pipelines.
We are aiming to test that on all the PR's. For the test job it didn't fail at all. If this simple strategy will not be enough we might look into other.
Potentially another plugin might be used when it will be mature enough. Currently it doesn't work since it can not be configured properly. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Apologies for missing the first point which was addressed in the comments, but you didn't address backoff or idempotence :) If the back-off strategy isn't right, you may see the issue reappear with some low frequency. I'm good with committing because it will temporarily fix the issue at least (LGTM) A suggestion if it's not in the comments already :) Can you repro with a minimal scenario and figure out some probabilities (to justify 3 back-offs and a 1 second delay)? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There is a certain problem with that. The test job doesn't catch the failures, but I can see a metric in CloudWatch that this is happening 1-2 times per hour. Once this PR get merged it should have an immediate effect on the metric. If not - the strategy would need to be reconsidered. |
||
$class: 'GitHubCommitStatusSetter', | ||
reposSource: [$class: "ManuallyEnteredRepositorySource", url: repoUrl], | ||
contextSource: [$class: "ManuallyEnteredCommitContextSource", context: context], | ||
commitShaSource: [$class: "ManuallyEnteredShaSource", sha: commitSha], | ||
statusBackrefSource: [$class: "ManuallyEnteredBackrefSource", backref: "${env.RUN_DISPLAY_URL}"], | ||
errorHandlers: [[$class: 'ShallowAnyErrorHandler']], | ||
statusResultSource: [ | ||
$class: 'ConditionalStatusResultSource', | ||
results: [[$class: "AnyBuildResult", message: message, state: state]] | ||
] | ||
]) | ||
|
||
if (attempt < 3) { | ||
sleep 1 | ||
} | ||
} | ||
|
||
echo "Publishing commit status done." | ||
|
||
|
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.
nit, use <= 3. it's easier to mentally parse at a glance. same with <= 2. (philosophical aside: 4 isn't the significant piece of info, 3 is. when you have < len(a) it makes sense to avoid the - 1 because that clutters the code, but here we're interested in 3 not 4, and 2 not 3 :)).
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.
Ok, changed as you suggested