1
0
mirror of https://github.com/firstBitMarksistskaya/jenkins-lib.git synced 2025-01-22 12:12:53 +02:00

Edt transformation fix (#2)

Обработка ошибки EDT: утилита ring не повышает в командной строке errorlevel, поэтому при ошибке в ринге шаг не считается проваленным. Изменил метод cmd для возможности проверить текст отработки ring и дальнейшего выявления из текста ошибки
This commit is contained in:
Ivan Smirnov 2024-03-01 16:36:11 +03:00 committed by GitHub
parent 262cd7ac24
commit 6ac28af8a0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 30 additions and 19 deletions

View File

@ -12,9 +12,9 @@ interface IStepExecutor {
boolean isUnix()
int sh(String script, boolean returnStatus, String encoding)
def sh(String script, boolean returnStatus, boolean returnStdout, String encoding)
int bat(String script, boolean returnStatus, String encoding)
def bat(String script, boolean returnStatus, boolean returnStdout, String encoding)
String libraryResource(String path)
@ -30,9 +30,11 @@ interface IStepExecutor {
void echo(message)
int cmd(String script, boolean returnStatus)
def cmd(String script, boolean returnStatus, boolean returnStdout)
int cmd(String script)
def cmd(String script, boolean returnStatus)
def cmd(String script)
void tool(String toolName)

View File

@ -23,13 +23,13 @@ class StepExecutor implements IStepExecutor {
}
@Override
int sh(String script, boolean returnStatus, String encoding) {
steps.sh script: script, returnStatus: returnStatus, encoding: encoding
def sh(String script, boolean returnStatus, boolean returnStdout, String encoding) {
steps.sh script: script, returnStatus: returnStatus, returnStdout: returnStdout, encoding: encoding
}
@Override
int bat(String script, boolean returnStatus, String encoding) {
steps.bat script: script, returnStatus: returnStatus, encoding: encoding
def bat(String script, boolean returnStatus, boolean returnStdout, String encoding) {
steps.bat script: script, returnStatus: returnStatus, returnStdout: returnStdout, encoding: encoding
}
@Override
@ -58,8 +58,8 @@ class StepExecutor implements IStepExecutor {
}
@Override
int cmd(String script, boolean returnStatus = false) {
return steps.cmd(script, returnStatus)
def cmd(String script, boolean returnStatus = false, boolean returnStdout = false) {
return steps.cmd(script, returnStatus, returnStdout)
}
@Override

View File

@ -7,22 +7,28 @@ class Cmd implements Serializable {
private String script;
private boolean returnStatus
private boolean returnStdout
private String encoding = 'UTF-8'
Cmd(String script, boolean returnStatus = false) {
Cmd(String script, boolean returnStatus = false, boolean returnStdout = false) {
this.script = script
this.returnStatus = returnStatus
this.returnStdout = returnStdout
};
int run() {
def run() {
IStepExecutor steps = ContextRegistry.getContext().getStepExecutor()
int returnValue
def returnValue
if (returnStatus & returnStdout) {
return "returnStatus and returnStdout are not supported at the same time"
}
if (steps.isUnix()) {
returnValue = steps.sh("$script", returnStatus, encoding)
returnValue = steps.sh("$script", returnStatus, returnStdout, encoding)
} else {
returnValue = steps.bat("chcp 65001 > nul \n$script", returnStatus, encoding)
returnValue = steps.bat("chcp 65001 > nul \n$script", returnStatus, returnStdout, encoding)
}
return returnValue

View File

@ -34,7 +34,7 @@ class DesignerToEdtFormatTransformation implements Serializable {
def env = steps.env();
def workspaceDir = FileUtils.getFilePath("$env.WORKSPACE/$WORKSPACE")
String workspaceDir = FileUtils.getFilePath("$env.WORKSPACE/$WORKSPACE").getRemote()
def srcDir = config.srcDir
def configurationRoot = FileUtils.getFilePath("$env.WORKSPACE/$srcDir")
def edtVersionForRing = EDT.ringModule(config)
@ -47,7 +47,10 @@ class DesignerToEdtFormatTransformation implements Serializable {
def ringOpts = [Constants.DEFAULT_RING_OPTS]
steps.withEnv(ringOpts) {
steps.cmd(ringCommand)
String ringMessage = steps.cmd(ringCommand, false, true)
if (ringMessage.contains("error")) {
steps.error(ringMessage)
}
}
steps.zip(WORKSPACE, WORKSPACE_ZIP)

View File

@ -1,9 +1,9 @@
import ru.pulsar.jenkins.library.steps.Cmd
import ru.pulsar.jenkins.library.ioc.ContextRegistry
int call(String script, boolean returnStatus = false) {
int call(String script, boolean returnStatus = false, boolean returnStdout = false ) {
ContextRegistry.registerDefaultContext(this)
Cmd cmd = new Cmd(script, returnStatus)
Cmd cmd = new Cmd(script, returnStatus, returnStdout)
return cmd.run()
}