Git по-нашему: как и зачем мы сделали собственный инструмент многопоточной разработки

Руководитель проектов ALP Group Егор Сорокин делится личным опытом создания обработок Gitflow Tools на языке 1С.

Git по-нашему: как и зачем мы сделали собственный инструмент многопоточной разработки

Пляски с бубнами, или попытки использовать существующие инструменты

Ни для кого не секрет, что параллельная коллективная разработка намного эффективнее, нежели последовательная. Многие крупные ИТ-компании, желая достичь преимуществ одномоментной разработки, со скрипом переходили на DevOps-методологии, открывали целые департаменты для набора соответствующих специалистов и пытались — с переменным успехом — сделать закостенелый процесс более гибким и контролируемым.

В какой-то момент, достигнув определенных бизнес-масштабов, ALP Group тоже столкнулась с необходимостью хранить изменения обособленно и вести быструю разработку большим числом разработчиков. Для решения этой задачи нужно было погрузиться в устройство классической системы управления версиями Git и понять, как интегрировать ее с 1С, на продуктах которой завязано большинство наших проектов.

Хотя первая версия Git была выпущена еще в 2005 году, по ощущениям, до сих пор лишь небольшая доля команд разработчиков 1С использует Git на постоянной основе. Это довольно сложный набор утилит командной строки с параметрами. Чтобы подключить Git к 1С, необходимо выполнить установку дополнительного программного обеспечения, подключиться к репозиторию, завести аккаунт на одном из хостингов, всё корректно настроить и разобраться в специфике работы с консолью GitBash. Всё это требует большого профессионального уровня погружения разработчиков в специфику Git, а главное — свободного времени и горящих глаз для изучения чего-то нового. С горящими глазами у нас проблем не было, а вот со временем, на фоне других срочных задач, — были.

Тогда мы решили оценить второй вариант: работать с Git не напрямую, а через специальное решение вендора — “1С:Enterprise Development Tools”. “1C:EDT” — это расширяемая среда разработки прикладных решений, уже интегрированная с Git. По сути, “1C:EDT” — навороченный аналог знакомого всем конфигуратора. Не возьмусь оценить последнюю версию решения, но на тот момент, когда мы заинтересовались средой EDT, она подтормаживала, долго запускала проект, иногда теряла доработки и в довесок имела немало багов.

От бессилия хотелось отказаться от этой идеи и вернуться к разработке в привычном конфигураторе. Но в IT, кто не учится — тот теряет клиентов и деньги. В итоге мы решили действовать самостоятельно и создать собственный инструмент многопоточной разработки.

Обработки GitFlow Tools

Мы хотели сделать максимально простое и изящное решение без лишних (конкретно для наших проектов) фич. Так было создано две обработки на языке 1С, о которых я расскажу ниже.

1. Рабочее место разработчика (РМР).

Источник: ALP Group
Источник: ALP Group

Инструмент представляет из себя упрощенный Git-клиент в виде 1C-обработки. Под капотом решения — смесь из языков 1С, OneScript и прямых Git-команд. Как видно на скриншоте, у РМР всего две базовые кнопки — «Начать/продолжить работу» и «Поместить в удаленный репозиторий». Они реализуют два основных сценария работы:

а) Программист хочет начать работу над задачей. В этом случае он выбирает из списка уже существующую feature-ветку (либо указывает, что нужно создать новую) и нажимает кнопку «Начать/продолжить работу». В результате выполняется подготовка конфигурации к работе — создание новой ветки (либо переключение на уже существующую и синхронизация ее с удаленным репозиторием) и загрузка ветки в конфигуратор.

б) Программист хочет зафиксировать результат своей работы. В этом случае он нажимает кнопку «Поместить в удаленный репозиторий». Происходит выгрузка конфигурации в локальный Git-репозиторий, фиксация и отправка в удаленный репозиторий. Перед отправкой программисту будет показано окно с выполненными изменениями в KDiff (проверка на отсутствие случайных изменений).

Для выполнения всего вышеперечисленного программисту не нужно изучать команды Git, всё делается автоматически — нужные команды зашиты внутри РМР.

Остальные кнопки отвечают за вспомогательную функциональность.

2. Создание релизов.

Источник: ALP Group
Источник: ALP Group

Эта обработка загружает список обращений, еще не включенных в релиз, и выполняет сборку релиза из выбранных обращений. Решение позволяет изменить номер версии конфигураций прямо в окне сборки, не запуская конфигуратор. В случае если несколько обращений не получилось включить в релиз из-за конфликтов слияния, они откладываются в отдельный список, по которому можно впоследствии пройтись и включить обращения в релиз уже при помощи инструмента разрешения конфликтов (конфигуратор + CF или git-mergetool). Сборка из 5–10 мелких и средних задач без конфликтов слияния займет около 10 минут.

Так, с помощью двух простых обработок, мы реализовали многопоточную среду разработки, не потратив времени специалистов на изучение всех тонкостей Git-команд (эта участь выпала только на архитектора, который занимался обработками). При этом все преимущества системы Git теперь с нами: это и эффективное управление версиями кода, и отслеживание изменений, и возвращение к предыдущим версиям при необходимости, и возможность ветвления/слияния, и стабильность кодовой базы, и общее повышение производительности и качества разработки.

А как вы работаете с Git в 1С? Пожалуйста, поделитесь своим опытом в комментариях ⬇

66
Начать дискуссию
«Сервер сгорел, продажи встали, клиенты ушли»: как собственник Иван Петрович спас свой бизнес с помощью 1С в облаке
«Сервер сгорел, продажи встали, клиенты ушли»: как собственник Иван Петрович спас свой бизнес с помощью 1С в облаке

Иван Петрович руководит сетью магазинов электроники и бытовой техники. Компания стабильно росла, и бизнес начинал набирать обороты: магазины открывались в новых районах, ассортимент расширялся, а клиенты возвращались за покупками.

Но вместе с ростом приходили и проблемы: отчёты не сходились, остатки на складе часто не совпадали с реальностью, а серв…

1515
55
11
11
Иван Петрович) Настало время офигительных историй? (С)
⚙️ Как мы устраняем «бутылочные горлышки» в разработке с помощью Lean и Agile
⚙️ Как мы устраняем «бутылочные горлышки» в разработке с помощью Lean и Agile
22
Командная разработка на платформе AggreGate + Git

Приветствую, меня зовут Сергей, я основатель независимого сообщества Low-code разработчиков на платформе AggreGate (далее Платформа).


В этой статье изложу взгляды на организацию командной разработки коммерческих продуктов на Платформе с использованием Git.

Работали без MS Project и Jira до того, как это стало мейнстримом. Как мы управляем проектами в своей системе
Работали без MS Project и Jira до того, как это стало мейнстримом. Как мы управляем проектами в своей системе

В этой колонке я расскажу, как мы автоматизировали процессы на каждом этапе управления проектом и как это помогает нам укладываться в сроки, управлять ресурсами без овербукинга, ставить выполнимые цели и не терять информацию в проектах.

88
22
Доработки 1С: как прокачать программу и ничего не сломать

Продукты 1С весьма универсальны, но они умеют и учитывают не всё. Эта статья о том, как добавить новые функции в типовую конфигурацию и расширить её возможности, а не сломать.

Доработки 1С: как прокачать программу и ничего не сломать
11
Кейс по оптимизации запасов в 1С УПП для снижения простоев в производстве
Кейс по оптимизации запасов в 1С УПП для снижения простоев в производстве
1С «из коробки» — не панацея, или почему автоматизация может создать проблемы бизнесу

Если у вас магазин одежды или украшений, объемы растут, аналитики не хватает, а в операционке назревает беспорядок, этот кейс поможет вашему бизнесу избежать типичных ошибок начинающих компаний.

1С «из коробки» — не панацея, или почему автоматизация может создать проблемы бизнесу
33
Все еще зависает 1С? Узнали про опыт пользователей и делимся с вами инсайтами

Сегодня многие компании активно используют 1С для управления бизнесом, и с ростом объёмов данных и числа пользователей производительность системы становится критически важной. Мы провели исследование среди пользователей 1С и выявили ключевые проблемы, с которыми сталкиваются компании, а также возможные пути их решения.

11
[]