Огромные человекоподобные роботы
Общие понятия (на примере 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
требуется исследование
может закончиться неуспешно (текст после описывает обработку неуспеха, по умолчанию -- останов + оповещение)
второстепенное
Старт
- подготовка репозитория
создание нового
- связывание нового репозитория с git.alt
- настройка autobuild
- создание минимального хранилища "версии 0"
- стартовая синхронизация и обновление исходников
- оформление пакета
- импорт существующего
- настройка autobuild
- проверка синхронизации
- допуск к автосборке и публикация
Типовые watchfile для sf, gh, gc, g.a...
Синхронизация
- Синхронизация
- с целевым хранилищем
с devel-веткой
- Проверка апстрима
- генерация uscan-файла на основании шаблона (нужно для sf, gc и т. п.: они часто меняют формат доступа)
выяснение апстримной версий
- несколько исходников
- VCS
- выяснение текущей версии
- несколько исходников
- сравнение версий (возможно, нестрогое) и допуск к обновлению
Обновление
- подготовка сборочной версии старых исходников (например, создание временной ветки)
получение исходников из апстрим
обновление старых исходников новыми
- модификация служебных файлов (*.spec, .gear/* ...)
- допуск к сборке (например, commmit + tag)
Сборка
тестовая сборка сборочной версии
- получение журнала сборки
проверка качества сборки
- публикация результатов тестовой сборки для тестирования
См. ниже Организация «домашней» сборки
Тестирование
- получение бинарных пакетов для тестирования
- установка пакетов
тестирование
- маркировка оттестированных пакетов
Размещение в хранилище
- подготовка целевой версии обновлённых исходников (например, merge из временной ветки)
- публикация целевой версии
- запуск сборочницы целевого репозитория
Структура комплекта сценариев
TODO
Организация «домашней» сборки и тестирования
- Доступ к бинарному репозиторию
- Подготовка apt.conf
- Сеанс автосборки
- синхронизация всех пакетов
выявление и импорт новых подготовленных к автосборке пакетов
- обновление допущенных к обновлению пакетов
- сборка допущенных допущенных к сборке пакетов
- публикация успешно собравшихся пакетов
Запуск сеанса cron
TODO: диаграмма состояний
Следствия
- Разделение майнтейнера на активного пользователя (тестера) и сборщика. Разумеется, лучше в одном лице, но...
- Внешнее автоматическое тестирование