1
0
mirror of https://github.com/Bayselonarrend/OpenIntegrations.git synced 2024-12-16 11:38:11 +02:00
OpenIntegrations/.github/workflows/os/oint_testmaker.os

312 lines
12 KiB
Plaintext
Raw Normal View History

#Использовать "../../../OInt/tools/"
Перем СоответствияПараметровЗначениям;
Перем СоответствияПараметровПредобработкам;
2024-04-20 11:50:02 +02:00
Перем СписокРабот;
Перем ТекущийДокумент;
Перем ПутьКФайлам;
Процедура ПриСозданииОбъекта()
МассивВлияющих = Новый Массив;
2024-05-08 17:28:26 +02:00
МассивВлияющих.Добавить("Testing-Twitter");
2024-04-20 11:50:02 +02:00
СписокРабот = "";
ТаблицаТестов = OPI_ПолучениеДанныхТестов.ПолучитьТаблицуТестов();
СписокБиблиотек = OPI_ПолучениеДанныхТестов.ПолучитьСоответствиеРазделовТестирования();
ПутьКФайлам = "./.github/workflows/";
ТекущийДокумент = Новый ТекстовыйДокумент();
СообщитьНачалоФайлаПроцесса();
СформироватьЗапуск(ТаблицаТестов, СписокБиблиотек);
СообщитьОкончаниеФайлаПроцесса(МассивВлияющих);
ТекущийДокумент.Записать(ПутьКФайлам + "oint_test_full.yml");
Для Каждого ТекущаяБиблиотека Из СписокБиблиотек Цикл
ТекущийДокумент = Новый ТекстовыйДокумент();
Библиотека = ТекущаяБиблиотека.Ключ;
2024-05-08 13:30:21 +02:00
СписокРабот = "";
СообщитьНачалоФайлаПроцесса("Тестирование " + Библиотека);
СписокОдной = Новый Соответствие();
2024-05-08 13:23:28 +02:00
Зависимости = СписокБиблиотек[Библиотека];
СписокОдной.Вставить(Библиотека, Зависимости);
СформироватьЗапуск(ТаблицаТестов, СписокОдной);
2024-05-08 17:39:34 +02:00
ТекущийДокумент.ДобавитьСтроку("
|
| - name: Записать измененные данные
| if: ${{ cancelled() }} == false
| uses: actions/cache/save@v3
| with:
| key: test-data_new
| path: ./data.json
|");
2024-05-08 17:28:26 +02:00
СообщитьОкончаниеФайлаПроцесса("Testing-" + Библиотека);
ТекущийДокумент.Записать(ПутьКФайлам + "oint_test_" + Библиотека + ".yml");
КонецЦикла;
КонецПроцедуры
Процедура СформироватьЗапуск(Знач ТаблицаТестов, Знач СписокБиблиотек)
Раннер = "/home/runner/.local/share/ovm/current/lib/1testrunner/src/main.os";
ФайлТестов = "./OInt/tests/Modules/internal/OPI_Тесты.os";
Для Каждого Библиотека Из СписокБиблиотек Цикл
Раздел = Библиотека.Ключ;
Зависимости = Библиотека.Значение;
2024-04-20 11:50:02 +02:00
НазваниеРаботы = "Testing-" + Раздел;
СписокРабот = СписокРабот + НазваниеРаботы + ", ";
ТекстРаботы = "
|
2024-04-20 11:50:02 +02:00
| " + НазваниеРаботы + ":
2024-04-19 19:27:33 +02:00
| runs-on: ubuntu-latest
| needs: " + Зависимости + "
| steps:
|
2024-04-19 19:27:33 +02:00
| - uses: actions/checkout@v2
| - uses: otymko/setup-onescript@v1.4
| with:
| version: 1.9.0
|
2024-04-19 19:27:33 +02:00
| - name: Получить тестовые данные из кэша
| uses: actions/cache/restore@v3
| with:
2024-04-19 19:49:31 +02:00
| key: " + КлючКэша(Раздел) + "
2024-04-19 19:27:33 +02:00
| path: ./data.json
|
2024-04-19 19:27:33 +02:00
| - name: Установить asserts и 1testrunner
| run: |
| opm install asserts
| opm install 1testrunner
|
2024-04-19 19:27:33 +02:00
| - name: Установить OInt
| run: |
| cd ./OInt
| opm build
| opm install *.ospx
|
2024-04-19 19:27:33 +02:00
|";
2024-05-08 12:35:02 +02:00
Отбор = Новый Структура("Раздел", Раздел);
ТестыТекущегоРаздела = ТаблицаТестов.НайтиСтроки(Отбор);
Для Каждого Тест Из ТестыТекущегоРаздела Цикл
Метод = Тест.Метод;
Синоним = Тест.Синоним;
ТекстРаботы = ТекстРаботы + "
|
2024-04-19 19:31:41 +02:00
| - name: " + Синоним + "
2024-04-19 19:33:38 +02:00
| if: ${{ cancelled() }} == false
| run: oscript " + Раннер + " -run " + ФайлТестов + " """ + Метод + """";
КонецЦикла;
2024-04-19 19:49:31 +02:00
ДополнитьТекстРаботы(Раздел, ТекстРаботы);
ТекущийДокумент.ДобавитьСтроку(ТекстРаботы);
КонецЦикла;
КонецПроцедуры
Процедура СообщитьНачалоФайлаПроцесса(Знач ИмяРаботы = "Полное тестирование")
ТекущийДокумент.ДобавитьСтроку(
"
|name: OINT | " + ИмяРаботы + "
|
|# Controls when the workflow will run
|on:
| workflow_dispatch:
|
|jobs:
|
| Decode:
2024-04-19 16:18:44 +02:00
| runs-on: ubuntu-latest
| if: ${{ always() }}
| steps:
2024-04-19 16:23:05 +02:00
|
2024-04-19 16:18:44 +02:00
| - uses: actions/checkout@v4
|
| - name: Расшифровать тестовые данные
| run: gpg --quiet --batch --yes --decrypt --passphrase=""$ENC_JSON"" --output ./data.json ./data.json.gpg
| env:
| ENC_JSON: ${{ secrets.ENC_JSON }}
| - name: Записать тестовые данные в кэш
| uses: actions/cache/save@v3
| with:
| key: test-data
| path: ./data.json
|
| Build:
2024-04-19 16:18:44 +02:00
| runs-on: ubuntu-latest
| steps:
| - uses: actions/checkout@v4
| - uses: otymko/setup-onescript@v1.4
| with:
| version: 1.9.0
|
2024-04-19 16:18:44 +02:00
| - name: Установить asserts и 1testrunner
| run: |
| opm install asserts
| opm install 1testrunner
|
2024-04-19 16:18:44 +02:00
| - name: Установить OInt
| run: |
| cd ./OInt
| opm build
| opm install *.ospx
|
2024-04-19 16:18:44 +02:00
| - name: Записать артефакт
| uses: actions/upload-artifact@v4
| with:
| name: oint
| path: ./OInt/*.ospx
2024-04-19 16:23:05 +02:00
|");
КонецПроцедуры
Процедура СообщитьОкончаниеФайлаПроцесса(Знач СписокВлияний = "")
Если ЗначениеЗаполнено(СписокВлияний) Тогда
Если ТипЗнч(СписокВлияний) = Тип("Массив") Тогда
СписокВлияний = СтрСоединить(СписокВлияний, ",");
КонецЕсли;
ТекущийДокумент.ДобавитьСтроку("
| Encode:
| runs-on: ubuntu-latest
| needs: [" + СписокВлияний + "]
| if: ${{ always() }}
| permissions:
| contents: write
|
| steps:
|
| - uses: actions/checkout@v2
|
| - name: Обновить данные в репозитории
| run: git pull https://github.com/Bayselonarrend/OpenIntegrations
|
| - name: Получить тестовые данные из кэша
| uses: actions/cache/restore@v3
| with:
| key: test-data_new
| path: ./data.json
|
| - name: Зашифровать данные обратно
| continue-on-error: false
|
| run: |
| rm -f ./data.json.gpg
| gpg --batch --symmetric --cipher-algo AES256 --passphrase=""$ENC_JSON"" data.json
| rm -f ./data.json
| env:
| ENC_JSON: ${{ secrets.ENC_JSON }}
|
| - name: Записать данные
| uses: stefanzweifel/git-auto-commit-action@v5
| with:
| commit_user_name: Vitaly the Alpaca (bot)
| commit_user_email: vitaly.the.alpaca@gmail.com
| commit_author: Vitaly the Alpaca <vitaly.the.alpaca@gmail.com>
| commit_message: Обновление зашифрованных данных по результатам тестов (workflow)
|");
КонецЕсли;
ТекущийДокумент.ДобавитьСтроку("
2024-04-19 19:27:33 +02:00
|
| Clear-Cache:
| runs-on: ubuntu-latest
2024-04-20 11:50:02 +02:00
| needs: [" + СписокРабот + "Encode]
2024-04-19 19:27:33 +02:00
| if: ${{ always() }}
| steps:
| - name: Очистка основного кэша
| run: |
| curl -L \
| -X DELETE \
| -H ""Accept: application/vnd.github+json"" \
| -H ""Authorization: Bearer ${{ secrets.TOKEN }}"" \
| -H ""X-GitHub-Api-Version: 2022-11-28"" \
| ""https://api.github.com/repos/Bayselonarrend/OpenIntegrations/actions/caches?key=test-data""
|
| - name: Очистка кэша Google
| run: |
| curl -L \
| -X DELETE \
| -H ""Accept: application/vnd.github+json"" \
| -H ""Authorization: Bearer ${{ secrets.TOKEN }}"" \
| -H ""X-GitHub-Api-Version: 2022-11-28"" \
| ""https://api.github.com/repos/Bayselonarrend/OpenIntegrations/actions/caches?key=test-data_google""
|
| - name: Очистка кэша Twitter
| run: |
| curl -L \
| -X DELETE \
| -H ""Accept: application/vnd.github+json"" \
| -H ""Authorization: Bearer ${{ secrets.TOKEN }}"" \
| -H ""X-GitHub-Api-Version: 2022-11-28"" \
| ""https://api.github.com/repos/Bayselonarrend/OpenIntegrations/actions/caches?key=test-data_new""");
2024-04-19 19:49:31 +02:00
КонецПроцедуры
Процедура ДополнитьТекстРаботы(Знач Раздел, ТекстРаботы)
Если Раздел = "Twitter" Тогда
ТекстРаботы = ТекстРаботы + "
|
2024-04-19 19:55:16 +02:00
| - name: Записать измененные данные
| if: ${{ cancelled() }} == false
| uses: actions/cache/save@v3
| with:
| key: test-data_new
| path: ./data.json
2024-04-19 19:49:31 +02:00
|";
ИначеЕсли Раздел = "GoogleWorkspace" Тогда
ТекстРаботы = ТекстРаботы + "
|
2024-04-19 19:55:16 +02:00
| - name: Записать измененные данные
| if: ${{ cancelled() }} == false
| uses: actions/cache/save@v3
| with:
| key: test-data_google
| path: ./data.json
2024-04-19 19:49:31 +02:00
|";
Иначе
Возврат;
КонецЕсли;
КонецПроцедуры
Функция КлючКэша(Знач Раздел)
СоответствиеОсобыхРазделов = Новый Соответствие();
СоответствиеОсобыхРазделов.Вставить("GoogleDrive" , "test-data_google");
СоответствиеОсобыхРазделов.Вставить("GoogleCalendar", "test-data_google");
2024-05-04 23:27:11 +02:00
СоответствиеОсобыхРазделов.Вставить("GoogleSheets" , "test-data_google");
2024-04-19 19:49:31 +02:00
Ключ = СоответствиеОсобыхРазделов.Получить(Раздел);
Если Не ЗначениеЗаполнено(Ключ) Тогда
Ключ = "test-data";
КонецЕсли;
Возврат Ключ;
КонецФункции