1
0
mirror of https://github.com/Bayselonarrend/OpenIntegrations.git synced 2025-11-25 22:12:29 +02:00
Files
OpenIntegrations/ci/split_tests/Bitrix24/os_test_en

153 lines
5.9 KiB
Plaintext
Raw Normal View History

2025-07-30 09:58:25 +03:00
def runCommand(String command) {
if (isUnix()) {
sh(script: command)
} else {
bat(script: command)
}
}
pipeline {
agent {
label 'windows'
}
stages {
2025-10-19 10:12:36 +03:00
stage('Read stages config') {
steps {
script {
def configText = readFile './service/tests_config.json'
env.STAGES_CONFIG = configText
}
}
}
2025-07-30 09:58:25 +03:00
stage('Remove OInt from OneScript Lib') {
steps {
script {
try {
// Удаление каталога C:\Program Files\OneScript\lib\oint, если существует
powershell encoding: 'UTF-8', script: '''
$dirPath = "C:\\Program Files\\OneScript\\lib\\oint"
if (Test-Path $dirPath) {
Write-Host "Каталог oint найден. Удаляем..."
Remove-Item -Path $dirPath -Recurse -Force
Write-Host "Каталог oint успешно удален."
} else {
Write-Host "Каталог oint не найден. Пропускаем удаление."
}
'''
// Проверяем, что каталог действительно удален
powershell encoding: 'UTF-8', script: '''
$dirPath = "C:\\Program Files\\OneScript\\lib\\oint"
if (Test-Path $dirPath) {
Write-Error "Ошибка: Каталог oint всё ещё существует после попытки удаления!"
exit 1
} else {
Write-Host "Проверка: Каталог oint отсутствует после удаления."
}
'''
} catch (Exception e) {
echo "Произошла ошибка при удалении каталога oint: ${e.getMessage()}"
currentBuild.result = 'FAILURE'
error("Удаление каталога oint завершено с ошибкой.")
}
}
}
}
stage('Build OInt from source and decrypt secret data'){
steps{
2025-09-18 13:55:48 +03:00
powershell encoding: 'UTF-8', script:'cd ./src/en/OInt; opm build; opm install oint-1.28.0.ospx; del oint-1.28.0.ospx'
2025-07-30 09:58:25 +03:00
withCredentials([string(credentialsId: 'gpgkey', variable: 'GPGKEY')]) {
bat encoding: 'UTF-8', script:'gpg --quiet --batch --yes --decrypt --passphrase="%GPGKEY%" --output ./data.json ./data.json.gpg'
}
}
}
2025-09-02 09:03:47 +03:00
stage('Create ReportPortal launch'){
steps{
bat encoding: 'UTF-8', script:'chcp 65001 & oscript ./ci/os/rp_start.os'
}
}
2025-07-30 09:58:25 +03:00
stage('Testing-Bitrix24') {
2025-10-19 10:12:36 +03:00
when {
expression { return shouldRunStage('Bitrix24') }
}
2025-10-19 11:44:58 +03:00
steps {
script {
def tests = [
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_TokenManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_ServerTime'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_PostsManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_TaskManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_CommentsManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_WorkingWithDrive'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_Kanban'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_Timekeeping'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_ChatManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_NotificationsManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_TasksFieldsManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_DepartmentsManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B2_UsersManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_LeadsManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_DealsManagement'],
['./src/en/OInt/tests/Modules/internal/OPI_Tests.os', 'B24_CalendarsManagement'],
]
for (test in tests) {
catchError(buildResult: 'FAILURE', stageResult: 'FAILURE') {
runLibraryTest(test[0], test[1])
}
}
}
2025-07-30 09:58:25 +03:00
}
}
}
post{
always{
script {
2025-09-02 15:31:57 +03:00
catchError() {
2025-09-03 09:01:54 +03:00
runCommand('oscript ./ci/os/rp_stop.os "en"')
2025-09-02 15:31:57 +03:00
}
2025-07-30 09:58:25 +03:00
withCredentials([string(credentialsId: 'gpgkey', variable: 'GPGKEY')]) {
bat encoding: 'UTF-8', script:'del "./data.json.gpg"'
bat encoding: 'UTF-8', script:'gpg --batch --symmetric --cipher-algo AES256 --passphrase="%GPGKEY%" ./data.json'
bat encoding: 'UTF-8', script:'del "./data.json"'
}
withCredentials([gitUsernamePassword(credentialsId: 'gitmain', gitToolName: 'Default')]) {
bat "git config user.email vitaly.the.alpaca@gmail.com"
bat 'git config user.name "Vitaly the Alpaca (bot)"'
bat "git config --global core.ignorecase true"
bat "git add ."
bat 'git commit -m "Test data update (Jenkins)"'
bat "git push origin HEAD:main"
2025-09-02 15:31:57 +03:00
}
2025-07-30 09:58:25 +03:00
}
}
}
2025-10-19 10:12:36 +03:00
}
def shouldRunStage(stageName) {
2025-10-19 12:10:19 +03:00
try {
if (!env.STAGES_CONFIG) {
echo "[WARN] STAGES_CONFIG not set. Assuming stage '${stageName}' is ENABLED."
return true
}
def config = readJSON text: env.STAGES_CONFIG
def value = config[stageName]
if (value == null) {
echo "[WARN] Stage '${stageName}' not found in config. Defaulting to DISABLED."
return false
}
return value == true
} catch (Exception e) {
echo "[ERROR] Failed to parse STAGES_CONFIG: ${e.message}"
echo "Raw config: ${env.STAGES_CONFIG}"
// Решите: включать stage по умолчанию или нет?
return false // или true — по вашему усмотрению
}
2025-10-19 11:44:58 +03:00
}
def runLibraryTest(String configPath, String libraryName) {
runCommand("1testrunner -run \"${configPath}\" \"${libraryName}\"")
2025-07-30 09:58:25 +03:00
}