Если вы тоже параллельно работаете сразу в нескольких несвязанных между собой системах, то знаете, какая это головная боль. Мы долго мучились, и в конце концов придумали схему, по которой можно объединить «необъединимое»: системы Confluence, СППР2 и Jira. Практическая инструкция по интеграции инструментов (а также ответ на вопрос «Зачем вам всё это понадобилось?») — под катом. Никакой воды — всё строго по делу.
Предпосылки реализации (зачем «плодить сущности»)
Привет, Хабр! Меня зовут Артем Вожаков, и я работаю архитектором информационных систем в IBS. Наша команда реализует сложные информационные системы, состоящие из множества отдельных программных решений на различных платформах, преимущественно 1С.
Вот классические проблемы, с которыми может столкнуться команда при работе над крупным «долгостроем»:
№ |
Проблема |
Влияние на проект |
Решение |
1 |
Отсутствие единого информационного поля, приводящее к ошибкам проектирования и разработки |
Затраты на переработку, сдвиг сроков |
Использование эффективных средств коллективной работы |
2 |
Рассинхронизация работ внутри команды |
Увеличение сроков, простои сотрудников |
Использование методики выравнивания потока работ, основанной на теории ограничений |
3 |
Множество версий документов, без возможности сравнения версий из-за использования неэффективных инструментов (Excel, Word) |
Конфликты версий, потеря данных, высокие затраты на администрирование |
Обеспечение автоматической актуализации содержания документов при изменении зависимых документов |
4 |
Разработка невостребованного функционала ввиду использования неактуальных заданий на разработку |
Дополнительные затраты на переработку и тестирование |
Прямые связи задач на разработку с актуальными версиями заданий на разработку |
5 |
Несоответствие разработанного функционала ожиданиям заказчика |
Необходимость переработки функционала, затраты, сдвиг сроков |
Организация прослеживаемости требований на всем жизненном цикле, непрерывный сбор обратной связи от заказчика на всех этапах работ |
6 |
Проблемы связывания функциональных блоков проекта в единую систему, несовместимость программных решений |
Переработка функционала при сборке готового решения, затраты, сдвиг сроков |
Прослеживание связей между блоками, интеграционных потоков, построение сводных отчетов и матриц трассировки требований |
7 |
Отсутствие процесса передачи экспертизы в компанию по итогам проекта |
Доработка СППР2 заново на каждом проекте |
Формирование центра экспертизы в компании по СППР2, формирование внутреннего продукта для управления проектом, обеспечения жизненного цикла требований и управления созданием конфигураций 1С в проектах компании |
Такого рода проблемы типичны для проектов по комплексной автоматизации крупного бизнеса, которыми занимается наша команда. Очевидно, что крайне важно с самого начала любого ИТ-проекта организовать работу таким образом, чтобы обеспечить максимальную прослеживаемость и прогнозируемость результатов. Чтобы проект завершился успешно (да даже просто — завершился), необходимо предвидеть типичные проблемы, исключать их возникновение или выявлять их как можно раньше и минимизировать последствия.
Но вот загвоздка: в своей работе мы параллельно используем сразу несколько специализированных инструментов проектного управления, проектирования и документирования:
Jira — для трекинга работ, учета трудозатрат и контроля лимитов на всех стадиях проекта.
Confluence — для документирования работ на всех стадиях проекта, обеспечения прослеживаемости требований и ведения базы знаний.
СППР2 (продукт Фирмы «1С») — для проектирования разрабатываемых (дорабатываемых) конфигураций 1С, организации процессов разработки, создания системы распределения прав доступа и построения системы регрессионного тестирования конфигураций и расширений.
Каждый из перечисленных инструментов частично дублирует функциональность двух других (особенно Confluence и СППР2), что часто приводит к желанию отказаться от одного из инструментов или даже двух из трех при реализации проектов. Так почему же нельзя обойтись одной системой? Каждый из инструментов обладает уникальными функциями, использование которых (под наши цели) является целесообразным. Так, например, СППР2 описывает только отдельные конфигурации 1С. Описание комплексных проектов, соответствие объектов метаданных, интеграции не покрываются функционалом СППР2. Для этих задач требуются доработки или же использование дополнительных инструментов.
Мы решили не лишать себя преимуществ разных систем, останавливаясь на каком-то одном продукте, а вместо этого придумать, как доработать СППР2 и создать наборы интеграций с Confluence и Jira — причем так, чтобы избежать дублирования информации в системах.
Плюсы подхода:
Для каждой прикладной задачи используется лучший инструмент для ее решения, данные между системами передаются автоматически.
На выходе из проекта заказчик получает базу СППР2, в которой в структурированном виде хранится вся информация о проекте: функционально-технические требования, реестры бизнес-процессов, проектные решения, задания на разработку (технические проекты), задачи разработки, объекты метаданных (с привязкой к задачам разработки), исходный код доработок.
На выходе из проекта IBS забирает для повторного использования свою копию базы СППР2, которая содержит всю информацию, включая выгрузки из Confluence и Jira, где хранятся исходные данные для проекта.
Необходимость ручного ввода данных в СППР2 сведена к минимуму, вносятся только дополнительные данные по решению команды: шаги процессов, описание функций системы, автотесты и т. д. При этом на 100% исключен двойной ввод информации в разные системы.
Основные объекты этапа проектирования
При разработке проектной документации в Confluence ряд сущностей требуют проведения работ по созданию реестров для построения системы связей и трассировки требований на всех этапах реализации проекта. Для ведения реестров хорошо подходит компонент Confluence Requirement Yogi. Данный компонент изначально использовался только для учета требований заказчика, но в дальнейшем мы распространили практику его использования до множества объектов и учета связей между ними.
Приведем перечень основных объектов, учитываемых в проекте:
Понятие/объект |
Объект метаданных для хранения в СППР2 |
Назначение объекта |
Конфигурация |
Проект |
СППР2 устроен таким образом, что для каждой отдельной конфигурации 1С (в том числе расширений) необходимо создавать отдельный проект. |
Бизнес-процесс |
Процесс |
Объект используется для создания реестра бизнес-процессов Заказчика, фиксации владельцев процессов и распределения требований и других объектов по процессам. |
Функциональная область |
Позволяет разделить функциональность системы на отдельные функциональные блоки, каждым из которых занимается отдельная группа специалистов. |
|
Функционально-технические требования |
Идея |
Используются для хранения всех видов требований, предъявляемых к создаваемой системе. |
Объекты логической модели (функция, документ, точка интеграции, отчет, интерфейс) |
Объекты логической модели* |
Объект логической модели не равен объекту метаданных, для хранения в СППР2 таких данных потребуется доработка. При написании проектных решений в Confluence система и автоматизированные процессы описываются в разрезе объектов логической модели, которые описываются в проектных решениях с детализацией до реквизитов. |
Роль |
Профиль доступа |
Используется для выделения бизнес-ролей пользователей, которые в дальнейшем используются для определения полномочий пользователей в системе и настройки прав доступа. |
Разработка (Epic) |
Технический проект |
До начала разработки/доработки системы все зафиксированные потребности к разработке должны быть разделены на отдельные разработки (совокупность работ, которые в дальнейшем декомпозируются на конкретные задачи). |
Задачи разработки |
Задача |
Используется для распределения задач разработки между разработчиками. |
Объекты метаданных |
Объекты метаданных |
Объект метаданных конфигурации решения. |
Распределение функциональности по системам
Как было сказано выше, используемые инструменты обладают рядом аналогичных функций, комбинации использования которых команда может выбирать самостоятельно. В таблице приведены варианты комбинаций, которые встречались на наших проектах. У каждого варианта есть свои плюсы и минусы.
Функциональность |
Возможные инструменты |
Подготовка и оформление документации по шаблонам заказчика |
Confluence, крайне редко СППР2 (в основном для описания доработок) |
Коллективная работа с документацией |
Confluence |
Согласование и утверждение документации |
«1С:Документооборот», Confluence (придется заводить заказчика в среду исполнителя) |
Учет трудозатрат по задачам |
Jira, крайне редко СППР2 |
Контроль лимитов проекта |
Jira |
Контроль статусов разработки/согласования документов |
«1С:Документооборот», Confluence |
План-фактный анализ показателей трудозатрат |
Jira |
Контроль исполнительской дисциплины |
Jira |
Анализ эффективности (результативности) членов команды проекта |
Jira |
Анализ качества разрабатываемых решений на основании статистики выявленных ошибок |
Jira |
Контроль прослеживаемости артефактов от исходных требований и бизнес-процессов |
СППР2, Confluence |
Контроль полноты покрытия исходных требований артефактами проекта |
СППР2, Confluence |
Интеграция инструментов
Общий принцип интеграции заключается в том, что объекты, которые создаются в мастер-системе, не создаются в других системах вручную, а выгружаются туда средствами интеграции. Однако для минимизации интеграционных потоков штучные элементы не выгружаются, а соответствия между объектами устанавливаются в настройках обменов.
В проектах IBS разработка, как правило, выполняется в среде заказчика, причем зачастую через VPN-подключение. Confluence и Jira используются внутри компании. Получается, что команде необходимо одновременно работать и в сети заказчика и в сети IBS. Исходя из целей обеспечения информационной безопасности одновременная регистрация в двух VPN запрещена. Таким образом, прямая интеграция систем среды разработки и IBS крайне затруднена. Исходя из этого мы планируем использовать интеграцию, основанную на передаче файлов, которые можно копировать в среду заказчика любым доступным способом, в том числе по электронной почте.
СППР2 → Confluence
Для подготовки различных документов в Confluence может потребоваться информация, хранящаяся в СППР2, такая как:
Бизнес-роли пользователей (Профили доступа).
Матрица доступа (состав ролей профилей доступа).
Функции системы для сценария тестирования и ПМИ (если ведется в СППР2).
Ключевые операции (для программы нагрузочного тестирования).
Прочая техническая информация.
Для выгрузки данных из СППР2 в Confluence используется простая выгрузка документов Excel из СППР2 и дальнейшая вставка этих данных в Confluence. Таким образом обратных интеграционных потоков создавать не требуется.
Confluence → Jira
Интеграция Confluence – Jira является бесшовной и детально описана на официальном сайте Atlassian.
Confluence → СППР2
Наиболее трудоемкой и связанной системой с Confluence является СППР2. Требуется разработка инструментов интеграции для объектов, представленных в таблице.
Поскольку СППР2 часто разворачивается на инфраструктуре заказчика, целесообразным является разработка файловых обменов, чтобы была возможность обменов в разорванных информационных контурах путем копирования файлов.
Даже если СППР2 на проекте не используется, интеграция может использоваться для передачи исходной технической информации Confluence заказчику.
Сущность |
Confluence |
СППР2 |
Аналитики прослеживаемости (связи) |
Комментарий |
Проектные решения по способу автоматизации бизнес-процесса |
Проектное решение |
Процесс |
Первый объект для интеграции, обмен организуется на стадии проекта, когда уже разработаны проектные решения. |
|
Задание на разработку (техническое задание) |
Задание на разработку |
Технический проект |
Процесс |
Обмен организуется на стадии проекта, когда уже разработаны ЗНР. Привязка к проекту выполняется через поле соответствия Информационная база, Раздел проекта не заполняется — при необходимости уточняется на стороне СППР2, как и прочие поля, не описанные в интеграции. |
Функционально-технические требования (ФТТ) |
ФТТ |
Идея |
ЗНР |
ФТТ содержат результаты анализа требований заказчика, описывают способ реализации и разрывы. В дальнейшем ФТТ используются как источник информации для разработки. В СППР2 используется объект Идеи, при этом в дополнительном реквизите Идеи разделяются на требования заказчика и ФТТ, для обеспечения прослеживаемости и к первой и второй сущности. |
Jira → СППР2
Сущность |
Jira |
СППР2 |
Комментарий |
Задача разработки |
Задача с типом UserStory |
Задача |
В СППР2 в техническом проекте должен храниться код Epic Jira — на основании кода задачи привязываются к техническому проекту. Задачи, для которых не созданы технические проекты (по разным причинам), в СППР2 не загружаются. Коды задач Jira должны быть использованы для автоматической привязки коммитов к задачам и техническим проектам. |
Ошибки |
Задача с типом Ошибка |
Ошибка |
Ограничения СППР для использования в комплексных проектах
При обозначенной выше схеме интеграции остается ряд концептуальных проблем, требующих решения при практической реализации. Я опишу, как к ним решили подступиться в IBS. Предлагайте альтернативные решения в комментариях ;)
1. Проектирование конфигураций с расширениями в СППР2.
Поскольку использование расширений становится основной практикой на проектах, необходимо встроить их в логическую модель описания создаваемых в рамках проектов решений. Проблема в том, что конфигурация с расширениями работает как одна, но по факту представляет собой несколько объектов — в СППР2 это не учитывается. Отсюда проистекает ряд вопросов:
Как будут связаны расширения и основные конфигурации?
Как будут загружаться объекты метаданных, которые были в изначальной конфигурации, но которые были изменены в расширении? Будет ли связь объектов метаданных основной конфигурации и расширения?
Как вести учет требований, техпроектов, которые затрагивают несколько конфигураций? Придется ли отвязывать эти сущности от проекта? Возможно ли это без серьезной доработки?
Возможно ли автоматизировать получение текущего состояния объектов метаданных конфигурации и всех расширений на регулярной основе? Какие доработки для этого потребуются? Объем?
Возможное решение:
Проект в СППР2 — это конфигурация в реальном мире. База с несколькими так называемыми проектами — это проект в реальном мире. Можно переименовать синоним у справочника «Проекты» в «Конфигурации, расширения, смежные системы», чтобы никого больше никогда не путать.
Это будут разные элементы, так же как они технически разные и в реальности. Можно сделать реквизит для связки по имени или по uuid.
Вести их для базы в целом. И вообще проектный учет сделать для базы в целом, для нескольких конфигураций.
Загрузка объектов метаданных по расписанию есть в «коробке».
2. Проектирование интеграций в СППР2.
Вопросы:
Как следует учитывать интеграции между системами в СППР2? Какие доработки потребуются для включения интеграций в логическую модель описания?
Нет инструментов для проектирования интеграций между конфигурациями; у интеграции минимум две стороны — каждая находится в отдельном проекте. Как видеть интеграции как цельный механизм?
Решение:
Каждая сторона интеграции как отдельная конфигурация. Считаем, что сама с собой база через интеграцию не общается.
3. Механизм загрузки метаданных из ИБ.
Механизм загрузки метаданных из ИБ не получает метаданные, хранимые в расширениях.
Есть предложения по решению: https://infostart.ru/public/1585975/; https://infostart.ru/1c/articles/1585833/.
4. Механизм связи между изменениями в хранилище и задачами разработки.
Есть потребность в автоматизации формирования базы СППР2 на основании изменений исходного кода конфигураций и расширений. Идея заключается в том, что каждый коммит хранилища привязывается к идентификатору задачи разработки (например, в поле Комментарий или другим способом). Необходимо создать инструмент, который бы автоматически привязывал объекты метаданных к задачам разработки и техническим проектам. Также нелишним будет хранить и исходный код доработок. На одном из проектов мои коллеги решили эту задачу с помощью интеграции с git. Ввиду этого есть ряд вопросов:
Какой видится оптимальный способ решения данной задачи для проектов, не использующих EDT?
Если использовать git, то возможно ли будет использовать данный механизм на проектах, где изначально не было git?
Возможно ли развернуть git на серверах заказчика на существующем проекте?
Решение:
На основании анализа коммитов хранилища можно бы было автоматически привязывать метаданные к задачам разработки и исходный код доработок — без этого ценность использования СППР2 сильно снижается.
Каждый коммит хранилища имеет комментарий, в котором указан код задачи Jira, по которой происходила доработка. Система могла бы сама проанализировать коммит, чтобы определить набор использованных метаданных. Задачи разработки привязаны к техпроектам в СППР2, на основании коммита можно бы было заполнить объекты метаданных техпроекта автоматически, плюс сохранить исходный код коммита в приложении к техпроекту. Это бы дало максимально полную информацию о доработках в СППР2. При этом для получения информации никакого ручного труда не требуется.
Перечень доработок прикладных решений
Итак, какие доработки в итоге требуются:
Интеграция Confluence – СППР2: две мини-конфигурации для выгрузки в XML и загрузки из XML; готовое API Confluence.
Интеграция Jira – СППР2: две мини-конфигурации для выгрузки в XML и загрузки из XML; готовое API Jira.
Доработка СППР2 для работы с объектами логической модели (документы, роли, функции и т. д.): проектирование структуры объектов, связи и отчеты.
Доработка СППР2 для работы с расширениями, мультипроектами, проектированием интеграций: добавление новых объектов, модификация механизмов загрузки метаданных, изменение метаданных, доработка интерфейсов.
Создание инструментов загрузки коммитов из хранилища, привязки метаданных к задачам разработки и техпроектам: существует несколько вариантов реализации — через интеграцию с git или путем парсинга файлов хранилища.
Доработка СППР2 в части учета изменения метаданных с историей задач разработки.
Заключение
Сейчас наша команда реализовала пилотный проект, где интеграция сделана в полуручном режиме. В ближайшее время мы планируем реализовать внутренний проект по доработке СППР2 и созданию компонентов интеграции, необходимых для полноценного использования инструментов с максимальной эффективностью. Мы видим живой интерес от заказчиков в получении структурированной базы знаний по результатам проекта, и СППР2 идеально подходит для этой цели — информационная база полностью отчуждаемая, содержит всю основную информацию о проекте, туда же можно дозагрузить всю техническую документацию проекта. Таким образом заказчик в результате проекта получает не только работающую систему и пачку документации, но еще и эффективный инструмент для сопровождения системы и ее развития собственными силами или же силами других подрядчиков.
Со временем, Confluence и Jira могут быть заменены на импортонезависимые решения, без изменения подхода к работе, — осталось только дождаться полноценных отечественных аналогов данных инструментов. Скорее всего, созданный продукт не будет выпущен на рынок в виде коробочного решения, но его использование будет включено в стандарт реализации проектов IBS и предлагаться заказчикам как один из значимых результатов проекта.