Skip to content
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

Поддержка edt-ripper для подготовки файла с замечаниями для SonarQube в формате bsl-ls, поддержка SQ>=10.3 при использовании stebi #121

Merged
Merged
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
fcb233e
add edt-ripper
ovcharenko-di Jul 24, 2024
0d00417
upd schema
ovcharenko-di Jul 24, 2024
bf3fb2d
fix errors
ovcharenko-di Jul 24, 2024
edfc25e
add NonCPS
ovcharenko-di Jul 24, 2024
5d01386
add toString
ovcharenko-di Jul 24, 2024
20a6645
fixes and tests
ovcharenko-di Jul 24, 2024
44d988d
fixes
ovcharenko-di Jul 24, 2024
d70a598
fix edt-ripper cmd, stashes and sonar-scanner parameters
ovcharenko-di Jul 24, 2024
2f32edb
fix workspace path
ovcharenko-di Jul 24, 2024
2063096
comment edt-ripper publish
ovcharenko-di Jul 25, 2024
a63847d
fix workspace path
ovcharenko-di Jul 25, 2024
aa4a9d6
add unstash for sonar-scanner
ovcharenko-di Jul 25, 2024
4b6b3eb
fix workspace path (experiment)
ovcharenko-di Jul 25, 2024
cf890d0
fix projectName, add split for srcDir for edt-ripper
ovcharenko-di Jul 27, 2024
17b6066
fix projectName
ovcharenko-di Jul 27, 2024
3e5209a
Update README.md
ovcharenko-di Jul 27, 2024
accc8e8
fixes
ovcharenko-di Jul 28, 2024
dd5f568
fix paths
ovcharenko-di Jul 28, 2024
f528bd3
fix README.md
ovcharenko-di Jul 28, 2024
45d5e8a
fix README.md
ovcharenko-di Jul 28, 2024
088b281
Merge branch 'develop' into feature/edt-ripper
nixel2007 Aug 24, 2024
0647dcb
Merge remote-tracking branch 'origin/develop' into pr/ovcharenko-di/121
nixel2007 Aug 30, 2024
e0f349a
fix defaults and doc
ovcharenko-di Aug 30, 2024
6561fe1
Смена дефолтной версии форматтера стеби на 10.3+
nixel2007 Aug 30, 2024
0f33f96
Merge branch 'feature/edt-ripper' of https://github.com/ovcharenko-di…
ovcharenko-di Aug 30, 2024
571b37b
new json schema generator
ovcharenko-di Aug 30, 2024
49fe3ea
fix edt srcDir
ovcharenko-di Aug 30, 2024
28e298b
Update src/ru/pulsar/jenkins/library/configuration/ResultsTransformOp…
ovcharenko-di Aug 31, 2024
453abf4
fixes
ovcharenko-di Aug 31, 2024
b063905
Merge branch 'feature/edt-ripper' of https://github.com/ovcharenko-di…
ovcharenko-di Aug 31, 2024
6ae35d0
Dry-run pipeline1C test
nixel2007 Aug 31, 2024
2680dd6
Cleanups
nixel2007 Aug 31, 2024
65799d1
Небольшое уточнение доки
nixel2007 Sep 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 5 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,10 @@

## Ограничения

1. Хранение исходников в корне репозитория или в каталоге первого уровня (например, в `src`) не рекомендуется.
1. Для шага подготовки требуется любой агент с меткой `agent`.
1. Для запуска шага анализа SonarQube требуется агент с меткой `sonar`.
1. Для запуска шагов, работающих с EDT (валидация, трансформация формата исходников) требуется агент с меткой `edt` (если используется несколько версий EDT необходимо к метке добавить версию, например `[email protected]:x86_64`) и агент с меткой `oscript`, на котором глобально установлена библиотека [stebi](https://github.com/Stepa86/stebi) версии 1.9.1 или новее.
1. Для запуска шагов, работающих с EDT (валидация, трансформация формата исходников) требуется агент с меткой `edt` (если используется несколько версий EDT необходимо к метке добавить версию, например `[email protected]:x86_64`) и агент с меткой `oscript`, на котором глобально установлена библиотека [stebi](https://github.com/Stepa86/stebi) версии 1.11.1 и выше или [edt-ripper](https://github.com/bia-technologies/edt_ripper).
1. Для запуска шагов, работающих с 1С (подготовка, синтаксический контроль и т.д.) требуется агент с меткой, совпадающей со значением в поле `v8version` файла конфигурации.
1. В качестве ИБ используется файловая база, создаваемая в каталоге `./build/ib`. При необходимости вы можете создать пользователей на фазе инициализации ИБ.

Expand All @@ -38,7 +39,8 @@
1. Запуск BDD сценариев с сохранением результатов в формате Allure.
1. Запуск юнит-тестов с помощью фреймворка YAXUnit с сохранением результатов в формате jUnit и Allure.
1. Запуск синтаксического контроля средствами конфигуратора и сохранение результатов в виде отчета jUnit.
1. Запуск валидации проекта средствами EDT и конвертация отчета в формате generic issues.
1. Запуск валидации проекта средствами EDT и конвертация отчета в форматах BSL LS или Generic Issue.

1. Запуск статического анализа для SonarQube.
1. Публикация результатов junit и Allure в интерфейс Jenkins.
1. Рассылка результатов сборки на почту и в Telegram.
Expand Down Expand Up @@ -148,15 +150,14 @@ pipeline1C()
* Если в репозитории существует файл `./tools/syntax-check-exception-file.txt`, то команде запуска синтаксического контроля конфигурации данный файл будет передаваться как файл с исключениями сообщений об ошибках (параметр `--exception-file`) (`syntaxCheck` -> `exceptionFile`).
* Конфигурационный файл по умолчанию уже содержит ряд "режимов проверки" для синтаксического контроля конфигурации (`syntaxCheck` -> `checkModes`).
* Трансформация результатов валидации EDT:
* По умолчанию из результатов анализа исключаются замечания, сработавшие на модулях с включенным запретом редактирования (желтый куб с замком) (параметры `resultsTransform` -> `removeSupport` и `resultsTransform` -> `supportLevel`).
* При использовании stebi по умолчанию из результатов анализа исключаются замечания, сработавшие на модулях с включенным запретом редактирования (желтый куб с замком) (параметры `resultsTransform` -> `removeSupport` и `resultsTransform` -> `supportLevel`).
* Анализ SonarQube:
* Предполагается наличие единственной настройки `SonarQube installation` (`sonarqube` -> `sonarQubeInstallation`).
* Используется `sonar-scanner` из переменной окружения `PATH` (`sonarqube` -> `useSonarScannerFromPath`).
* Если использование `sonar-scanner` из переменной окружения `PATH` выключено, предполагается наличие настроенного глобального инструмента `SonarQube Scanner` с идентификатором инструмента `sonar-scanner` (`sonarqube` -> `sonarScannerToolName`).
* Применяется расчет аргументов командной строки для работы [`branch plugin`](https://github.com/mc1arke/sonarqube-community-branch-plugin) или коммерческих версий SonarQube (`sonarqube` -> `branchAnalysisConfiguration`).
* Если разработка ведется с использованием подсистемы [БСП "Обновление версии ИБ"](https://its.1c.ru/db/bsp315doc#content:4:1:issogl1_обновление_версии_иб), то в значение параметра `sonar.projectVersion=$configurationVersion` утилиты `sonar-scanner` можно передавать версию из созданного общего модуля. Для этого необходимо заполнить параметр (`sonarqube` -> `infoBaseUpdateModuleName`). Если параметр не заполнен, версия передается из корня конфигурации.
* По умолчанию шаг анализа не дожидается окончания фонового задания на сервере SonarQube и не анализирует результат прохождения Порога качества (`sonarqube` -> `waitForQualityGate`).
* Если выполнялась валидация EDT, результаты валидации в формате `generic issues` передаются утилите `sonar-scanner` как значение параметра `sonar.externalIssuesReportPaths`.
ovcharenko-di marked this conversation as resolved.
Show resolved Hide resolved
* Рассылка уведомлений:
* Электронная почта:
* Для отправки используется плагин [`email-ext`](https://plugins.jenkins.io/email-ext). Шаблоны сообщений конфигурируются в настройках плагина.
Expand Down
2 changes: 2 additions & 0 deletions resources/globalConfiguration.json
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,8 @@
"publishToJUnitReport": true
},
"resultsTransform": {
"transformer": "stebi",
"genericIssueFormat": "Generic_Issue_10_3",
"removeSupport": true,
"supportLevel": 0
},
Expand Down
14 changes: 12 additions & 2 deletions resources/schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -344,13 +344,23 @@
"id" : "urn:jsonschema:ru:pulsar:jenkins:library:configuration:ResultsTransformOptions",
"description" : "Настройки трансформации результатов анализа",
"properties" : {
"transformer" : {
"type" : "string",
"description" : "Способ преобразования замечаний.\n Поддерживается stebi и edt-ripper.\n По умолчанию содержит значение \"stebi\".\n ",
"enum" : [ "stebi", "edt-ripper" ]
},
"removeSupport" : {
"type" : "boolean",
"description" : "Фильтровать замечания по уровню поддержки модуля. По умолчанию включено."
"description" : "Фильтровать замечания по уровню поддержки модуля. Только для stebi. По умолчанию включено."
},
"supportLevel" : {
"type" : "integer",
"description" : "Настройка фильтрации замечаний по уровню поддержки.\n 0 - удалить файлы на замке;\n 1 - удалить файлы на замке и на поддержке;\n 2 - удалить файлы на замке, на поддержке и снятые с поддержки.\n "
"description" : "Настройка фильтрации замечаний по уровню поддержки. Только для stebi.\n 0 - удалить файлы на замке;\n 1 - удалить файлы на замке и на поддержке;\n 2 - удалить файлы на замке, на поддержке и снятые с поддержки.\n "
},
"genericIssueFormat" : {
"type" : "string",
"description" : "Формат отчета generic issue. Только для stebi.\n Для SonarQube старее 10.3 необходимо использовать Generic_Issue.\n По умолчанию Generic_Issue_10_3\n ",
"enum" : [ "Generic_Issue", "Generic_Issue_10_3" ]
}
}
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,26 +3,41 @@ package ru.pulsar.jenkins.library.configuration
import com.cloudbees.groovy.cps.NonCPS
import com.fasterxml.jackson.annotation.JsonIgnoreProperties
import com.fasterxml.jackson.annotation.JsonPropertyDescription
import ru.pulsar.jenkins.library.configuration.sonarqube.GenericIssueFormat

@JsonIgnoreProperties(ignoreUnknown = true)
class ResultsTransformOptions implements Serializable {

@JsonPropertyDescription("Фильтровать замечания по уровню поддержки модуля. По умолчанию включено.")
@JsonPropertyDescription("""Способ преобразования замечаний.
Поддерживается stebi и edt-ripper.
По умолчанию содержит значение "stebi".
""")
ResultsTransformerType transformer = ResultsTransformerType.STEBI
ovcharenko-di marked this conversation as resolved.
Show resolved Hide resolved

@JsonPropertyDescription("Фильтровать замечания по уровню поддержки модуля. Только для stebi. По умолчанию включено.")
Boolean removeSupport = true

@JsonPropertyDescription("""Настройка фильтрации замечаний по уровню поддержки.
@JsonPropertyDescription("""Настройка фильтрации замечаний по уровню поддержки. Только для stebi.
0 - удалить файлы на замке;
1 - удалить файлы на замке и на поддержке;
2 - удалить файлы на замке, на поддержке и снятые с поддержки.
""")
Integer supportLevel

@JsonPropertyDescription("""Формат отчета generic issue. Только для stebi.
Для SonarQube старее 10.3 необходимо использовать Generic_Issue.
По умолчанию Generic_Issue_10_3
""")
GenericIssueFormat genericIssueFormat = GenericIssueFormat.GENERIC_ISSUE_10_3

@Override
@NonCPS
String toString() {
return "ResultsTransformOptions{" +
"transformer=" + transformer +
"removeSupport=" + removeSupport +
", supportLevel=" + supportLevel +
'}';
"supportLevel=" + supportLevel +
"genericIssueFormat=" + genericIssueFormat +
'}'
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
package ru.pulsar.jenkins.library.configuration

import com.fasterxml.jackson.annotation.JsonProperty

enum ResultsTransformerType {
@JsonProperty("stebi")
STEBI,

@JsonProperty("edt-ripper")
EDT_RIPPER

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package ru.pulsar.jenkins.library.configuration.sonarqube

import com.fasterxml.jackson.annotation.JsonProperty
import com.fasterxml.jackson.annotation.JsonValue

enum GenericIssueFormat {
@JsonProperty("Generic_Issue")
GENERIC_ISSUE("Generic_Issue"),

@JsonProperty("Generic_Issue_10_3")
GENERIC_ISSUE_10_3("Generic_Issue_10_3")

private String value

private GenericIssueFormat(String value) {
this.value = value
}


String getValue() {
return value
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,11 @@ import ru.pulsar.jenkins.library.utils.Logger

class DesignerToEdtFormatTransformation implements Serializable {

public static final String PROJECT_NAME = 'temp'
public static final String WORKSPACE = 'build/edt-workspace'
public static final String WORKSPACE_ZIP = 'build/edt-workspace.zip'
public static final String WORKSPACE_ZIP_STASH = 'edt-workspace-zip'

private final JobConfiguration config;
private final JobConfiguration config

DesignerToEdtFormatTransformation(JobConfiguration config) {
this.config = config
Expand All @@ -31,18 +30,19 @@ class DesignerToEdtFormatTransformation implements Serializable {
return
}

def env = steps.env();
def env = steps.env()

def workspaceDir = FileUtils.getFilePath("$env.WORKSPACE/$WORKSPACE")
def srcDir = config.srcDir
def configurationRoot = FileUtils.getFilePath("$env.WORKSPACE/$srcDir")
def projectName = configurationRoot.getName()
def edtVersionForRing = EDT.ringModule(config)

steps.deleteDir(workspaceDir)

Logger.println("Конвертация исходников из формата конфигуратора в формат EDT")

def ringCommand = "ring $edtVersionForRing workspace import --configuration-files \"$configurationRoot\" --project-name $PROJECT_NAME --workspace-location \"$workspaceDir\""
def ringCommand = "ring $edtVersionForRing workspace import --configuration-files \"$configurationRoot\" --project-name $projectName --workspace-location \"$workspaceDir\""

steps.ringCommand(ringCommand)

Expand Down
13 changes: 9 additions & 4 deletions src/ru/pulsar/jenkins/library/steps/EdtValidate.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ class EdtValidate implements Serializable {
public static final String RESULT_STASH = 'edt-validate'
public static final String RESULT_FILE = 'build/out/edt-validate.out'

private final JobConfiguration config;
private final JobConfiguration config
ovcharenko-di marked this conversation as resolved.
Show resolved Hide resolved

EdtValidate(JobConfiguration config) {
this.config = config
Expand All @@ -29,16 +29,21 @@ class EdtValidate implements Serializable {
return
}

def env = steps.env();
def env = steps.env()

String workspaceLocation = "$env.WORKSPACE/$DesignerToEdtFormatTransformation.WORKSPACE"
String projectList;
String projectList

if (config.sourceFormat == SourceFormat.DESIGNER) {
steps.unstash(DesignerToEdtFormatTransformation.WORKSPACE_ZIP_STASH)
steps.unzip(DesignerToEdtFormatTransformation.WORKSPACE, DesignerToEdtFormatTransformation.WORKSPACE_ZIP)

projectList = "--project-name-list $DesignerToEdtFormatTransformation.PROJECT_NAME"
def srcDir = config.srcDir
def configurationRoot = FileUtils.getFilePath("$env.WORKSPACE/$srcDir")

def projectName = configurationRoot.getName()

projectList = "--project-name-list $projectName"
} else {
def srcDir = config.srcDir
def projectDir = FileUtils.getFilePath("$env.WORKSPACE/$srcDir")
Expand Down
53 changes: 40 additions & 13 deletions src/ru/pulsar/jenkins/library/steps/ResultsTransformer.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -2,18 +2,18 @@ package ru.pulsar.jenkins.library.steps

import ru.pulsar.jenkins.library.IStepExecutor
import ru.pulsar.jenkins.library.configuration.JobConfiguration
import ru.pulsar.jenkins.library.configuration.ResultsTransformerType
import ru.pulsar.jenkins.library.configuration.SourceFormat
import ru.pulsar.jenkins.library.ioc.ContextRegistry
import ru.pulsar.jenkins.library.utils.FileUtils
import ru.pulsar.jenkins.library.utils.Logger

import java.nio.file.Paths

class ResultsTransformer implements Serializable {

public static final String RESULT_STASH = 'edt-generic-issue'
public static final String RESULT_FILE = 'build/out/edt-generic-issue.json'
public static final String RESULT_STASH = 'edt-issues'
public static final String RESULT_FILE = 'build/out/edt-issues.json'

private final JobConfiguration config;
private final JobConfiguration config

ResultsTransformer(JobConfiguration config) {
this.config = config
Expand All @@ -24,7 +24,7 @@ class ResultsTransformer implements Serializable {

Logger.printLocation()

def env = steps.env();
def env = steps.env()

if (!config.stageFlags.edtValidate) {
Logger.println("EDT validation is disabled. No transform is needed.")
Expand All @@ -33,20 +33,47 @@ class ResultsTransformer implements Serializable {

steps.unstash(EdtValidate.RESULT_STASH)

Logger.println("Конвертация результата EDT в Generic Issue")
ResultsTransformerType transformerType = config.resultsTransformOptions.transformer

def edtValidateFile = "$env.WORKSPACE/$EdtValidate.RESULT_FILE"
def genericIssueFile = "$env.WORKSPACE/$RESULT_FILE"
def srcDir = FileUtils.getFilePath("$env.WORKSPACE/$config.srcDir")

if (transformerType == ResultsTransformerType.STEBI) {

Logger.println("Конвертация результата EDT в Generic Issue с помощью stebi")

def genericIssueFile = "$env.WORKSPACE/$RESULT_FILE"
def genericIssuesFormat = config.resultsTransformOptions.genericIssueFormat.getValue()

String srcDir = config.sourceFormat == SourceFormat.DESIGNER ? config.srcDir : Paths.get(config.srcDir, "src")
nixel2007 marked this conversation as resolved.
Show resolved Hide resolved
steps.cmd("stebi convert -r $edtValidateFile $genericIssueFile $srcDir")
steps.cmd("stebi convert --Format $genericIssuesFormat -r $edtValidateFile $genericIssueFile $srcDir")

if (config.resultsTransformOptions.removeSupport) {
def supportLevel = config.resultsTransformOptions.supportLevel
steps.cmd("stebi transform --Format $genericIssuesFormat --remove_support $supportLevel --src $srcDir $genericIssueFile")
}

} else {

Logger.println("Конвертация результата EDT в Issues с помощью edt-ripper")

if (config.sourceFormat == SourceFormat.DESIGNER) {

steps.unstash(DesignerToEdtFormatTransformation.WORKSPACE_ZIP_STASH)
ovcharenko-di marked this conversation as resolved.
Show resolved Hide resolved
steps.unzip(DesignerToEdtFormatTransformation.WORKSPACE, DesignerToEdtFormatTransformation.WORKSPACE_ZIP)

}

srcDir = FileUtils.getFilePath("$env.WORKSPACE/$config.srcDir")

def projectName = srcDir.getName()
def srcDirExceptLast = srcDir.getParent()

steps.cmd("edt-ripper parse $edtValidateFile $srcDirExceptLast $projectName $env.WORKSPACE/$RESULT_FILE")

if (config.resultsTransformOptions.removeSupport) {
def supportLevel = config.resultsTransformOptions.supportLevel
steps.cmd("stebi transform --remove_support $supportLevel --src $srcDir $genericIssueFile")
}

steps.archiveArtifacts(RESULT_FILE)
steps.stash(RESULT_STASH, RESULT_FILE)

}
}
Loading