3528
Комментарий:
|
5307
|
Удаления помечены так. | Добавления помечены так. |
Строка 3: | Строка 3: |
=== Workflow === | |
Строка 9: | Строка 8: |
Действия: * ./ автоматическое |
Допуск (к некоторому действию):: маркировка пакета для того, чтобы робот, выполняющий данное действие, выполнил его Принципы: 1. Робот не засоряет репозиторий на git.alt * Константное число веток * `Число тегов=O(количество сборок)` 1. Робот не подписывает пакеты подписью майнтейнера === Описание Workflow === |
Строка 14: | Строка 19: |
Общий workflow: 1. Добавление пакета * Создание нового репозитория * настройка autobuild * создание минимального хранилища "версии 0" * стартовое обновление исходников * Импорт существующего репозитория * {2} автоматическая конвертация * Типовые watchfile для sf, gh, gc, g.a... ({i} * типовые репозитории?) 1. ./ Синхронизация |
==== Старт ==== 1. подготовка репозитория * {2} создание нового 1. связывание нового репозитория с git.alt 1. настройка autobuild 1. создание минимального хранилища "версии 0" 1. стартовая синхронизация и обновление исходников 1. оформление пакета * импорт существующего 1. настройка autobuild 1. проверка синхронизации 1. допуск к автосборке и публикация Типовые `watchfile` для sf, gh, gc, g.a... ==== Синхронизация ==== 1. Синхронизация |
Строка 25: | Строка 35: |
1. {2} с devel-веткой <!> ( 1. ./ Проверка апстрима |
1. {2} с devel-веткой 1. Проверка апстрима |
Строка 32: | Строка 42: |
1. сравнение версий (возможно, нестрогое) 1. ./ Обновление исходников 1. подготовка сборочной версии старых исходников (например, создание временной ветки) 1. получение исходников из апстрим <!> 1. обновление старых исходников новыми <!> 1. модификация служебных файлов (*.spec, .gear/* ...) 1. маркировка (например, commmit + tag) 1. ./ Сборка обновлённого пакета 1. Тестовая сборка <!> * «Домашняя» (см. [[#homebrew|Инфраструктура «домашней» сборки]]) * последовательность сборки * нстройка apt.conf * критерии успешности 1. Втягивание маркированных исходнков 1. Тестирование * {i} маркировка тестированных 1. Отсылка в g.a и на сборку |
1. сравнение версий (возможно, нестрогое) и допуск к обновлению ==== Обновление ==== 1. подготовка сборочной версии старых исходников (например, создание временной ветки) 1. получение исходников из апстрим <!> 1. обновление старых исходников новыми <!> 1. модификация служебных файлов (*.spec, .gear/* ...) 1. допуск к сборке (например, commmit + tag) ==== Сборка ==== 1. тестовая сборка сборочной версии <!> 1. получение журнала сборки 1. проверка качества сборки <!> 1. публикация результатов тестовой сборки для тестирования См. ниже [[#homebrew|Организация «домашней» сборки]] ==== Тестирование ==== 1. получение бинарных пакетов для тестирования 1. установка пакетов 1. тестирование <!> 1. маркировка оттестированных пакетов ==== Размещение в хранилище ==== 1. подготовка целевой версии обновлённых исходников (например, merge из временной ветки) 1. публикация целевой версии 1. запуск сборочницы целевого репозитория === Структура комплекта сценариев === '''TODO''' |
Строка 51: | Строка 70: |
=== Инфраструктура «домашней» сборки === * Запуск по cron .... TODO |
=== Организация «домашней» сборки и тестирования === |
Строка 55: | Строка 73: |
* ... === Следствия === |
* Сеанс автосборки 1. синхронизация всех пакетов 1. выявление и импорт ''новых'' подготовленных к автосборке пакетов 1. обновление допущенных к обновлению пакетов 1. сборка допущенных допущенных к сборке пакетов 1. публикация успешно собравшихся пакетов * {2} Запуск сеанса cron '''TODO''': диаграмма состояний == Следствия == |
Огромные человекоподобные роботы
Общие понятия (на примере 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-веткой
- Проверка апстрима
выяснение апстримной версий
- несколько исходников
- VCS
- выяснение текущей версии
- несколько исходников
- сравнение версий (возможно, нестрогое) и допуск к обновлению
Обновление
- подготовка сборочной версии старых исходников (например, создание временной ветки)
получение исходников из апстрим
обновление старых исходников новыми
- модификация служебных файлов (*.spec, .gear/* ...)
- допуск к сборке (например, commmit + tag)
Сборка
тестовая сборка сборочной версии
- получение журнала сборки
проверка качества сборки
- публикация результатов тестовой сборки для тестирования
См. ниже Организация «домашней» сборки
Тестирование
- получение бинарных пакетов для тестирования
- установка пакетов
тестирование
- маркировка оттестированных пакетов
Размещение в хранилище
- подготовка целевой версии обновлённых исходников (например, merge из временной ветки)
- публикация целевой версии
- запуск сборочницы целевого репозитория
Структура комплекта сценариев
TODO
Организация «домашней» сборки и тестирования
- Доступ к бинарному репозиторию
- Подготовка apt.conf
- Сеанс автосборки
- синхронизация всех пакетов
выявление и импорт новых подготовленных к автосборке пакетов
- обновление допущенных к обновлению пакетов
- сборка допущенных допущенных к сборке пакетов
- публикация успешно собравшихся пакетов
Запуск сеанса cron
TODO: диаграмма состояний
Следствия
- Разделение майнтейнера на активного пользователя (тестера) и сборщика. Разумеется, лучше в одном лице, но...
- Внешнее автоматическое тестирование