#shell #jenkins #sed #jenkins-pipeline
#оболочка #дженкинс #sed #jenkins-конвейер
Вопрос:
Я пытаюсь вставить новую строку в файл YAML с помощью команды sed через Jenkins. Он работает локально при попытке через командную строку ( cmder
)
Файл YAML
access_url: http://abc
db-url: oracle_path
Команда файла Jenkins для добавления новой строки
sh ''' sed -i "/access_url: http://abc$/a user_id: '6100539'" ${file} '''
Сбой сборки Jenkin сразу после запуска без каких-либо ошибок после ввода строки выше.
Ожидаемый результат после выполнения:
access_url: http://abc
user_id: '6100539'
db-url: oracle_path
Но когда я попробовал команду below локально с помощью cmder, это дало ожидаемый результат выше
sed -i "/access_url: http://abc$/a user_id: '6100539'" file
Ошибка в Jenkins:
GitHub has been notified of this commit’s build result
org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:
WorkflowScript: 459: unexpected char: '' @ line 459, column 119.
http://abc$/a user_id
^
1 error
at org.codehaus.groovy.control.ErrorCollector.failIfErrors(ErrorCollector.java:310)
at org.codehaus.groovy.control.ErrorCollector.addFatalError(ErrorCollector.java:150)
at org.codehaus.groovy.control.ErrorCollector.addError(ErrorCollector.java:120)
at org.codehaus.groovy.control.ErrorCollector.addError(ErrorCollector.java:132)
at org.codehaus.groovy.control.SourceUnit.addError(SourceUnit.java:350)
at org.codehaus.groovy.antlr.AntlrParserPlugin.transformCSTIntoAST(AntlrParserPlugin.java:139)
at org.codehaus.groovy.antlr.AntlrParserPlugin.parseCST(AntlrParserPlugin.java:110)
at org.codehaus.groovy.control.SourceUnit.parse(SourceUnit.java:234)
at org.codehaus.groovy.control.CompilationUnit$1.call(CompilationUnit.java:168)
at org.codehaus.groovy.control.CompilationUnit.applyToSourceUnits(CompilationUnit.java:943)
at org.codehaus.groovy.control.CompilationUnit.doPhaseOperation(CompilationUnit.java:605)
at org.codehaus.groovy.control.CompilationUnit.processPhaseOperations(CompilationUnit.java:581)
at org.codehaus.groovy.control.CompilationUnit.compile(CompilationUnit.java:558)
at groovy.lang.GroovyClassLoader.doParseClass(GroovyClassLoader.java:298)
at groovy.lang.GroovyClassLoader.parseClass(GroovyClassLoader.java:268)
at groovy.lang.GroovyShell.parseClass(GroovyShell.java:688)
at groovy.lang.GroovyShell.parse(GroovyShell.java:700)
at org.jenkinsci.plugins.workflow.cps.CpsGroovyShell.doParse(CpsGroovyShell.java:142)
at org.jenkinsci.plugins.workflow.cps.CpsGroovyShell.reparse(CpsGroovyShell.java:127)
at org.jenkinsci.plugins.workflow.cps.CpsFlowExecution.parseScript(CpsFlowExecution.java:561)
at org.jenkinsci.plugins.workflow.cps.CpsFlowExecution.start(CpsFlowExecution.java:522)
at org.jenkinsci.plugins.workflow.job.WorkflowRun.run(WorkflowRun.java:320)
at hudson.model.ResourceController.execute(ResourceController.java:97)
at hudson.model.Executor.run(Executor.java:429)
Finished: FAILURE
Комментарии:
1. Пожалуйста, отправьте сообщение об ошибке для лучшей поддержки.
2. @Vijay Извините, я пропустил ошибку консоли в Jenkins, теперь добавленную к вопросу. Похоже
, который использовался для избежания начальных пробелов, вызывающих проблемы.
3. Добавление дополнительной
работы выполнено