From 5776e969170e4acab442078c641c0c446b8068d6 Mon Sep 17 00:00:00 2001 From: gfleury Date: Sat, 1 Sep 2018 17:31:39 +0200 Subject: [PATCH 1/3] Handling IOExceptions while following deployment log. --- .../plugins/tsuru/pipeline/TsuruAction.java | 45 +++++++++++++++++-- 1 file changed, 42 insertions(+), 3 deletions(-) diff --git a/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java b/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java index 5f93ef1..f2f9e78 100644 --- a/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java +++ b/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java @@ -11,6 +11,7 @@ import io.tsuru.client.ApiException; import io.tsuru.client.api.TsuruApi; import io.tsuru.client.model.Application; +import io.tsuru.client.model.Deployments; import org.jenkinsci.plugins.tsuru.utils.TarGzip; import org.jenkinsci.plugins.workflow.cps.EnvActionImpl; import org.jenkinsci.plugins.workflow.steps.AbstractStepDescriptorImpl; @@ -234,9 +235,47 @@ protected Execution run() throws Exception { getListener().getLogger().println("[app-deploy] Starting Tsuru application deployment ========>"); int timeout = step.apiInstance.getApiClient().getReadTimeout(); step.apiInstance.getApiClient().setReadTimeout(600000); // Same BuildTimeout than TSURU - String output = step.apiInstance.appDeploy(step.Args.get("appName"), deploymentFile, step.Args.get("imageTag"), step.Args.get("message"), step.Args.get("commit")); - step.apiInstance.getApiClient().setReadTimeout(timeout); - getListener().getLogger().println(output); + String output = ""; + try { + output = step.apiInstance.appDeploy(step.Args.get("appName"), deploymentFile, step.Args.get("imageTag"), step.Args.get("message"), step.Args.get("commit")); + getListener().getLogger().println(output); + } catch (io.tsuru.client.ApiException e) { + if (e.getCause() instanceof java.io.IOException) { + int counter = 0; + String id = ""; + getListener().getLogger().println("[app-deploy] Logs will be truncated, please check the logs directly on Tsuru!"); + do { + List deploys = step.apiInstance.appDeployList(step.Args.get("appName"), 1); + if (deploys.size() > 0) { + Deployments deployment = deploys.get(0); + if (id.length() == 0) { + id = deployment.getId(); + } else if (!id.contains(deployment.getId())) { + getListener().getLogger().println("[app-deploy] Another deployment started in the meanwhile! Aborting this one!"); + break; + } + if (!deployment.getDuration().startsWith("-") && (deployment.getImage().length() != 0 || deployment.getError().length() != 0)) { + output = step.apiInstance.appLog(step.Args.get("appName"), 20); + if (deployment.getImage().length() != 0) { + output += "\nOK\n"; + } + break; + } + } else { + // No deployments at all + getListener().getLogger().println("[app-deploy] No deployment was found!"); + break; + } + Thread.sleep(5000 + (counter + 500)); + counter++; + } while (counter < 20); + } else { + // TODO: Better handling on unauthorized and conflict (another deployment in course) + throw e; + } + } finally { + step.apiInstance.getApiClient().setReadTimeout(timeout); + } if (!output.endsWith("OK\n")) { throw new ApiException("[app-deploy] Tsuru deployment FAILED ˆˆˆˆˆˆˆˆˆ"); } From 30c14417381e587f2ea5113dccb6c97408408120 Mon Sep 17 00:00:00 2001 From: gfleury Date: Sat, 1 Sep 2018 17:34:25 +0200 Subject: [PATCH 2/3] Handling IOExceptions while following deployment log. --- .../java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java b/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java index f2f9e78..9b62f20 100644 --- a/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java +++ b/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java @@ -238,7 +238,6 @@ protected Execution run() throws Exception { String output = ""; try { output = step.apiInstance.appDeploy(step.Args.get("appName"), deploymentFile, step.Args.get("imageTag"), step.Args.get("message"), step.Args.get("commit")); - getListener().getLogger().println(output); } catch (io.tsuru.client.ApiException e) { if (e.getCause() instanceof java.io.IOException) { int counter = 0; @@ -274,6 +273,7 @@ protected Execution run() throws Exception { throw e; } } finally { + getListener().getLogger().println(output); step.apiInstance.getApiClient().setReadTimeout(timeout); } if (!output.endsWith("OK\n")) { From 5da2dfcf7623b666328ee452cee5a25ce208370b Mon Sep 17 00:00:00 2001 From: gfleury Date: Sat, 1 Sep 2018 17:36:48 +0200 Subject: [PATCH 3/3] Handling IOExceptions while following deployment log. --- .../java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java b/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java index 9b62f20..3342685 100644 --- a/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java +++ b/src/main/java/org/jenkinsci/plugins/tsuru/pipeline/TsuruAction.java @@ -265,7 +265,7 @@ protected Execution run() throws Exception { getListener().getLogger().println("[app-deploy] No deployment was found!"); break; } - Thread.sleep(5000 + (counter + 500)); + Thread.sleep(5000 + (counter * 500)); counter++; } while (counter < 20); } else {