-
Notifications
You must be signed in to change notification settings - Fork 69
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
Honor SCM checkout retry count #110
Changes from all commits
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 |
---|---|---|
|
@@ -25,14 +25,17 @@ | |
package org.jenkinsci.plugins.workflow.steps.scm; | ||
|
||
import com.google.common.collect.ImmutableSet; | ||
import hudson.AbortException; | ||
import hudson.FilePath; | ||
import hudson.Functions; | ||
import hudson.Launcher; | ||
import hudson.model.Run; | ||
import hudson.model.TaskListener; | ||
import hudson.model.listeners.SCMListener; | ||
import hudson.scm.SCM; | ||
import hudson.scm.SCMRevisionState; | ||
import java.io.File; | ||
import java.io.InterruptedIOException; | ||
import java.nio.file.FileSystems; | ||
import java.nio.file.Files; | ||
import java.nio.file.attribute.PosixFilePermissions; | ||
|
@@ -42,6 +45,7 @@ | |
import java.util.logging.Level; | ||
import java.util.logging.Logger; | ||
import edu.umd.cs.findbugs.annotations.NonNull; | ||
import jenkins.model.Jenkins; | ||
import org.jenkinsci.plugins.workflow.steps.Step; | ||
import org.jenkinsci.plugins.workflow.steps.StepContext; | ||
import org.jenkinsci.plugins.workflow.steps.StepDescriptor; | ||
|
@@ -62,11 +66,11 @@ | |
public boolean isPoll() { | ||
return poll; | ||
} | ||
|
||
@DataBoundSetter public void setPoll(boolean poll) { | ||
this.poll = poll; | ||
} | ||
|
||
public boolean isChangelog() { | ||
return changelog; | ||
} | ||
|
@@ -126,7 +130,30 @@ | |
} | ||
} | ||
} | ||
scm.checkout(run, launcher, workspace, listener, changelogFile, baseline); | ||
|
||
for (int retryCount = Jenkins.get().getScmCheckoutRetryCount(); retryCount >= 0; retryCount--) { | ||
try { | ||
scm.checkout(run, launcher, workspace, listener, changelogFile, baseline); | ||
break; | ||
} catch (InterruptedIOException e) { | ||
throw e; | ||
} catch (Exception e) { | ||
// We follow the same exception output behavior as jenkinsci/workflow-cps-plugin#147, | ||
// but throw up the original exception if this is the last attempt | ||
if (e instanceof AbortException && e.getMessage() != null) { | ||
listener.error(e.getMessage()); | ||
} else { | ||
Functions.printStackTrace(e, listener.error("Checkout failed")); | ||
} | ||
if (retryCount == 0) { | ||
listener.error("Maximum checkout retry attempts reached, aborting");// all attempts failed | ||
throw e; | ||
} | ||
} | ||
listener.getLogger().println("Retrying after 10 seconds"); | ||
Thread.sleep(10000); | ||
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. This does not look right to me, should probably do something like what the sleep step does instead of blocking the thread here. Though I am not sure atm how a 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. Well, a background thread will sleep. Not terrible, under the assumption this code path is rarely used. 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. Shall I keep this change? Or, do I need to rewrite the whole StepExecutionImpl? 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. Probably good enough as is. This step used sh 'git clone https://github.com/myorg/myrepo' a slow checkout cannot survive a controller restart. As of jenkinsci/workflow-basic-steps-plugin#203 this matters less anyway since you can use the new retry system with the |
||
} | ||
|
||
if (changelogFile != null && changelogFile.length() == 0 | ||
&& changelogOriginalModifiedDate != null && changelogFile.lastModified() == changelogOriginalModifiedDate) { | ||
// JENKINS-57918/JENKINS-59560/FakeChangeLogSCM: Some SCMs don't write anything to the changelog file in some | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
package org.jenkinsci.plugins.workflow.steps.scm; | ||
|
||
import hudson.FilePath; | ||
import hudson.Launcher; | ||
import hudson.model.Run; | ||
import hudson.model.TaskListener; | ||
import hudson.scm.SCMRevisionState; | ||
|
||
import java.io.File; | ||
import java.io.IOException; | ||
|
||
public class UnstableSCM extends org.jvnet.hudson.test.FakeChangeLogSCM { | ||
private int failedCount; | ||
|
||
public UnstableSCM(int failedCount) { | ||
this.failedCount = failedCount; | ||
} | ||
|
||
@Override | ||
public void checkout(Run<?, ?> build, Launcher launcher, FilePath remoteDir, TaskListener listener, File changeLogFile, SCMRevisionState baseline) throws IOException, InterruptedException { | ||
try { | ||
if (failedCount > 0) { | ||
throw new IOException("IO Exception happens"); | ||
} | ||
super.checkout(build, launcher, remoteDir, listener, changeLogFile, baseline); | ||
} finally { | ||
failedCount--; | ||
} | ||
} | ||
} |
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.
This block should include:
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.
(per #110 (comment))