Расширение для пакета voral/version-increment автоматизирующее пакетов обновления модулей для Битрикс-маркетплейс на основе анализа git коммитов и семантического обновления версии. А так же изменяющее номер версии в файле version.php
При вычислении новой версии утилитой voral/version-increment перед коммитом выполняются следующие этапы по сборке обновления версии:
- Изменение версии модуля в соответствии с обновлением в файле install/version.php. А так же даты версии модуля на текущую. Если это файла нет в модуле - он будет создан.
- На основе анализа коммитов выполненных с предыдущей версии копируются новые и измененные файлы модуля в каталог пакета обновления. Кроме того, при необходимости, добавляется код удаления файлов, которые были удалены из модуля в скрипт обновления
updater.phpОбратите внимание, что функционал удаления упрощенный - перед окончательным оформлением пакета обновлений рекомендую проверить и скорректировать при необходимости
- Если в обновление были добавлены каталоги
install/admin,install/componentsи т.п в скриптupdater.phpдобавляется код по их копированию. При этом для каталога admin выполняется не копирование, а создание файлов которые подключают оригинальные. - Если произведена соответствующая настройка в скрипт
updater.phpдобавляется проверка версии PHP - Если произведена соответствующая настройка в скрипт
updater.phpдобавляется дополнительный кастомный PHP код - На основе коммитов git выполненных с предыдущей версии формируются файлы description.* пакета обновлений
- Если произведена соответствующая настройка генерируется файл контроля версий модулей от которых ваш модуль зависит
- Файлы
updater.php,description.*, а так же<путь_к_исходникам>/install/version.php(если он был создан) добавляются в репозиторий git
- PHP >= 8.1
- Git установлен и доступен в CLI
- Composer для управления зависимостями
Для начала необходимо установить пакет
composer require -dev voral/bitrix-module-toolЕсли у вас до этого не был установлен пакет voral/version-increment - он будет установлен и необходимо будет произвести настройку согласно документации. А так же подключить данный пакет в файле .vs-version-increment.php
use Vasoft\VersionIncrement\Config;
use Vasoft\VersionIncrement\Events\EventType;
use Voral\BitrixModuleTool\ModuleListener;
$config = new Config();
$eventBus = $config->getEventBus();
$listener = new ModuleListener(
$config,
'vendor.module',
includePhpFile: __DIR__ . '/updates/update_include.php',
);
$eventBus->addListener(EventType::BEFORE_VERSION_SET, $listener);
// прочие настройки
return $config;Т.к., как правило, есть необходимость доработать пакет обновлений перед загрузкой на маркетплейс (например перевести языковые description.*), рекомендую команду обновления версии выполнять с флагом отключающим коммит
php ./vendor/bin/vs-version-increment --no-commitУдобно записать этот скрипт в composer.json. Так же необходимо добавить скрипты создания пакетов модуля (обновления и полного) для загрузки на маркетплейс
{
"scripts": {
"vi:auto": "php ./vendor/bin/vs-version-increment --no-commit",
"pack:last": "sh scripts/pack-last.sh",
"pack:ver": "sh scripts/pack-version.sh",
"pack": [
"@pack:ver",
"@pack:last"
]
},
"scripts-descriptions": {
"vi:auto": "Increment module version and generate update package",
"pack:last": "Pack the full package of the module's latest version",
"pack:ver": "Pack the update package for a specified module version",
"pack": "Pack the full package of the latest version and the update package for a specified version"
}
}-
После выполнения изменений в модуле выполните расчет версии. Ппо окончанию этого скрипта в консоль будут выведены рекомендуемые команды для выполнения коммита и установки тега. Они будут содержать новую версию пакета.
composer vi:auto
-
При необходимости внесите изменения в CHANGELOG.md, в так же сгенерированные файлы описания обновления /updates/<версия_пакета>/description.*
-
Выполните сборку пакета обновлений для полученной версии (например для версии 1.3.0)
composer pack:last 1.3.0
-
Выполните проверку пакета обновлений как описано в статье
-
После всех проверок выполните сборку пакетов обновления и полного пакета модуля
composer pack:pack 1.3.0
-
Выполните коммит релиза и установите так как рекомендовано на шаге 1
-
Загрузить пакет на Битрикс маркетплейс
Настройка выполняется при помощи конструктора, который имеет следующие параметры:
$config - обязательный. Конфигурация version-increment
$moduleId - обязательный. Идентификатор вашего модуля
$sourcePath - необязательный. Каталог с исходниками модуля, относительно корня проекта. По умолчанию src
$destinationPath - необязательный. Каталог для пакетов обновлений, относительно корня проекта. По умолчанию updates
$phpVersion - необязательный. Версия PHP если необходим контроль в скрипте обновления
$modulesVersion - необязательный. Требующиеся модули и их версии
$excludeCommitTypes - необязательный. Типы коммитов, сообщения которых необходимо пропускать при формировании файлов description.*
$lang - необязательный. Символьные коды языков для создания описания обновлений (файлов description.*)
$includePhpFile - необязательный. Путь у php файлу, код которого необходимо включить в скрипт обновления update.php
Пример конфигурации
use Vasoft\VersionIncrement\Config;
use Vasoft\VersionIncrement\Events\EventType;
use Voral\BitrixModuleTool\ModuleListener;
$config = new Config();
$eventBus = $config->getEventBus();
$listener = new ModuleListener(
$config,
'vendor.module',
'last_version',
'marketplace',
'8.3.0',
[
'main' => '24.100.100',
'sale' => '24.0.100',
],
['build','docs','test'],
['ru','en','fr']
__DIR__ . '/updates/update_include.php',
);
$eventBus->addListener(EventType::BEFORE_VERSION_SET, $listener);
// прочие настройки
return $config;| Код | Описание |
|---|---|
| 5101 | Нет доступа к каталогу проекта |
| 5102 | Не корректный путь к проекту |
| 5103 | Не найден git тег версии |
| 5104 | Отсутствует или не верный формат файла version.php |
| 5105 | Не корректно задан путь к каталогу исходников или обновлений |
Чтобы избежать конфликты с прочими расширениями пакета voral/vs-version-incrementor можно изменять коды ошибок. Для этого необходимо задать дельту. В приведенном ниже примере коды ошибок будут увеличены на 100
use Vasoft\VersionIncrement\Config;
use Vasoft\VersionIncrement\Events\EventType;
use Voral\BitrixModuleTool\ModuleListener;
use Voral\BitrixModuleTool\Exception\ExtensionException;
ExtensionException::$errorCodeDelta = 100;
$config = new Config();
$eventBus = $config->getEventBus();
$listener = new ModuleListener($config, 'vendor.module');
$eventBus->addListener(EventType::BEFORE_VERSION_SET, $listener);
// прочие настройки
return $config;<?php
$arModuleVersion = [
'VERSION' => '1.0.0',
'VERSION_DATE' => '2023-01-01'
];MIT License. Подробности в файле LICENSE.