Замеры покрытия для платформы 1С: Предприятие 8
https://42clouds.com/ru-ru/techdocs/raschyot-pokrytiya-koda-1C-testami.html
Сценарий использования:
- Устанавливаем EDT (для работы программы нужны как минимум его библиотеки
com._1c.g5.v8.dt.debug.core_*.jar
,com._1c.g5.v8.dt.debug.model_*.jar
). Если держать EDT на данной машине затруднительно, из можно скопировать в любую папку, установить параметр окружения EDT_LOCATION в данную папку и удалить EDT. - Скачиваем последнюю версию со страницы https://github.com/proDOOMman/Coverage41C/releases
- Включаем http-отладку
-
клиент-серверный сценарий:
путём добавления к флагу -debug флага -http в строке запуска службы агента сервера
-
файловый сценарий:
путём ручного зарпуска дебаг сервера dbgs.exe (например так:
dbgs.exe --addr=127.0.0.1 --port=1550
), к которому будет подключаться Coverage41C и клиент файловой базы (запущенный с флагами/debug -http -attach /debuggerURL «адрес отладчика»
или через меню "Настройка->Параметры->Сервер отладки" в самом клиенте), см. https://its.1c.ru/db/v837doc#bookmark:adm:TI000000495Примечание: если включить протокол отладки http через конфигуратор Сервис -> Параметры -> Отладка, то Coverage41C не сможет подключиться к серверу отладки, т.к. одновременно к информационной базе может быть подключен только один интерфей отладки.
- Проверяем что сервер отладки dbgs.exe (https://its.1c.ru/db/edtdoc/content/197/hdoc/_top/dbgs) запустился и работает. Для этого в браузере открываем его, адрес по умолчанию http://127.0.0.1:1550/. В случае успеха выдолжны увидеть сообщение "... it works!".
- Выгружаем исходники конфигурации, расширения или внешней обработки в файлы (если у вас проекта EDT, то этот шаг пропускаем - он и так хранится в файлах)
- Запускаем анализ покрытия командой
Coverage41C start -i <ИмяИнформационнойБазыВКластере> -P <ПутьКПроекту> -s <ПутьКИсходникам> -o <ИмяВыходногоФайлаПокрытия> -e <ИмяРасширения>
. Для файловой базы нужно указать адрес отладчика и предопределённое имя информационной базыCoverage41C start -i DefAlias -u http://127.0.0.1:<Порт> -P <ПутьКПроектуEDT>
илиCoverage41C start -i DefAlias -u http://127.0.0.1:<Порт> -s <ПутьКИсходникам>
- (Опционально, полезно для конвейера) Проверяем статус программы командой
Coverage41C check -i <ИмяИнформационнойБазыВКластере>
илиCoverage41C check -i DefAlias -u http://127.0.0.1:1550
для файловой. - Выполняем тесты
- Останавливаем программу нажатием Ctrl+C в окне терминала или командой
Coverage41C stop -i <ИмяИнформационнойБазыВКластере> -u http://127.0.0.1:<Порт>
. Также возможна запись файла покрытия без остановки замеров командойdump
. - Полученный файл в формате genericCoverage.xml загружаем в SonarQube (файл формата LCov можно просмотреть в VSCode, ReportTool, genhtml и многих других программах).
Если команде start передавался путь к исходникам, то convert не нужен.
Примеры запуска на файловой базе для проекта EDT:
Coverage41C start -i DefAlias -u http://127.0.0.1:1550 -P C:\path\to\sources\ -o genericCoverage.xml
При завершении работы создаётся файл покрытия вида:
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<coverage version="1">
<file path="CommonCommands/СменитьПароль/Ext/CommandModule.bsl">
<lineToCover covered="true" lineNumber="13"/>
<lineToCover covered="false" lineNumber="9"/>
</file>
<file path="Catalogs/ОбработчикиСобытийRMQ/Forms/ФормаСписка/Ext/Form/Module.bsl">
<lineToCover covered="false" lineNumber="11"/>
<lineToCover covered="true" lineNumber="5"/>
<lineToCover covered="true" lineNumber="4"/>
Справка из командной строки:
>Coverage41C --help
Usage: Coverage41C [-hV] [COMMAND]
Make measures from 1C:Enterprise and save them to genericCoverage.xml file
-h, --help Show this help message and exit.
-V, --version Print version information and exit.
Commands:
start Start measure and save coverage data to file
stop Stop main application and save coverage to file
check Check is main application ready
clean Clear coverage data in main application
dump Save coverage data to file
convert Convert results from internal uuid-based format
Так же доступна справка по каждой из команд:
>Coverage41C start -h
Usage: Coverage41C start [-hV] [-p] [--verbose] [-e=<extensionName>]
[-i=<infobaseAlias>] [-o=<outputFile>] [--opid=<opid>]
[-P=<projectDirName>] [-p:env=<passwordEnv>]
[-r=<removeSupport>] [-s=<srcDirName>]
[-t=<pingTimeout>] [-u=<debugServerUrl>] [-u:
file=<debugServerUrlFileName>]
[-x=<externalDataProcessorUrl>] [-a
[=<autoconnectTargets>...]]... [-n
[=<debugAreaNames>...]]...
Start measure and save coverage data to file
-i, --infobase=<infobaseAlias>
InfoBase name. File infobase uses 'DefAlias' name.
Default - DefAlias
-u, --debugger=<debugServerUrl>
Debugger url. Default - http://127.0.0.1:1550/
-u:file, --debugger:file=<debugServerUrlFileName>
Debugger url file name
-e, --extensionName=<extensionName>
Extension name
-x, --externalDataProcessor=<externalDataProcessorUrl>
External data processor (or external report) url
-s, --srcDir=<srcDirName>
Directory with sources exported to xml
-P, --projectDir=<projectDirName>
Directory with project
-r, --removeSupport=<removeSupport>
Remove support values: NOT_EDITABLE,
EDITABLE_SUPPORT_ENABLED, NOT_SUPPORTED, NONE.
Default - NONE
-o, --out=<outputFile> Output file name
-p, --password Dbgs password
-p:env, --password:env=<passwordEnv>
Password environment variable name
-n, --areanames[=<debugAreaNames>...]
Debug area names (not for general use!)
-a, --autoconnectTargets[=<autoconnectTargets>...]
Autoconnect debug targets (not for general use!):
Unknown, Client, ManagedClient, WEBClient,
COMConnector, Server, ServerEmulation, WEBService,
HTTPService, OData, JOB, JobFileMode,
MobileClient, MobileServer, MobileJobFileMode,
MobileManagedClient
-t, --timeout=<pingTimeout>
Ping timeout. Default - 1000
--verbose If you need more logs. Default - false
--opid=<opid> Owner process PID
-h, --help Show this help message and exit.
-V, --version Print version information and exit.