Огромные человекоподобные роботы
Workflow
Общие понятия (на примере git.alt):
- Целевое хранилище
- название ветки в /gears (sisyphus)
- Пакет
- git-репозиторий на git.alt
- Схема репозитория
способ организации на git.alt (http://www.altlinux.org/%D0%A0%D1%83%D0%BA%D0%BE%D0%B2%D0%BE%D0%B4%D1%81%D1%82%D0%B2%D0%BE_%D0%BF%D0%BE_gear)
- Имя пакета
название src.rpm ( => имени репозитория в /gears)
Принципы:
- Робот не засоряет репозиторий на git.alt
- Константное число веток
Число тегов=O(количество сборок)
- Робот не подписывает пакеты подписью майнтейнера
Действия:
автоматическое
требуется исследование
может закончится неуспешно (текст после описывает обработку неуспеха, по умолчанию -- останов + оповещение)
второстепенное
Общий workflow:
- Добавление пакета
- Создание нового репозитория
- настройка autobuild
- создание минимального хранилища "версии 0"
- стартовое обновление исходников
- Импорт существующего репозитория
автоматическая конвертация
- Типовые watchfile для sf, gh, gc, g.a... ({i} * типовые репозитории?)
- Создание нового репозитория
Синхронизация
- с целевым хранилищем
с devel-веткой
Проверка апстрима
выяснение апстримной версий
- несколько исходников
- VCS
- выяснение текущей версии
- несколько исходников
- сравнение версий (возможно, нестрогое)
Обновление исходников
- подготовка сборочной версии старых исходников (например, создание временной ветки)
получение исходников из апстрим
обновление старых исходников новыми
- модификация служебных файлов (*.spec, .gear/* ...)
- маркировка (например, commmit + tag)
Сборка обновлённого пакета
тестовая сборка сборочной версии
«Домашняя» (см. Организация «домашней» сборки)
посредством git.alt
- получение журнала сборки
проверка качества сборки
- публикация результатов тестовой сборки для тестирования
если сборки была на git.alt
- Тестирование
получение бинарных пакетов для тестирования
- установка пакетов
- тестирование
- маркировка оттестированных пакетов
- Отсылка в g.a и на сборку
- подготовка рабочей версии обновлённых исходников (например, merge из временной ветки)
- отсылка рабочей версии в репозиторий
- запуск сборочницы
Структура комплекта сценариев
Организация «домашней» сборки
- Запуск по cron .... TODO
- Доступ к бинарному репозиторию
- Подготовка apt.conf
- ...
Следствия
- Разделение майнтейнера на активного пользователя (тестера) и сборщика. Разумеется, лучше в одном лице, но...
- Внешнее автоматическое тестирование