NMU: различия между версиями

Материал из ALT Linux Wiki
Нет описания правки
м (+заголовок Примечания)
 
(не показаны 54 промежуточные версии 10 участников)
Строка 1: Строка 1:
{{DraftPolicy}}
{{Policy
'''NMU''' (Non-Maintainer Upload) — обновление пакета не сопровождающим его.
|responsible=Антон Фарыгин (rider)
|since=01.05.2009
}}
__NOTOC__
Версия 1.1.


'''Следует различать NMU и запрос на добавление в группу майнтэйнеров!'''
'''NMU''' (Non-Maintainer Upload) — обновление пакета не сопровождающим его.


После введения сборки из git-репозиториев условия NMU существенно упроситились: если ваше изменение простое, то вы просто формируете задание на сборку и даёте на него ссылку мантейнерам, которые могут посмотреть и дать подтверждение.  Получив подтверждение, вы отправляете это же задание на повторную сборку. В случае крупных изменений действуют обычные правила NMU.
== Рамки Policy ==


Помните, что NMU — это акт помощи, мейнтейнер может быть благодарен за неё. При этом ответственность за судьбу пакета несёт мейнтайнер и поэтому он вправе в дальнейших сборках пакета делать то, что сочтёт нужным.
Данное Policy регламентирует взаимоотношения между мейнтейнерами. Для правил выполнения массовых NMU роботами см. [[MassNMU|полиси по массовым NMU]].


Стоит приложить разумные усилия к тому, чтобы облегчить мейнтейнеру принятие решения — приложением к письму или багрепорту патча, ссылкой на конкретный коммит или репозиторий в git.alt, наконец, доброжелательным отношением.
В данном Policy регулируются два вопроса:
* Условия выдачи NMU
* Технологические требования к NMU


== Условия, требующие подготовки NMU ==
== Условия выдачи NMU ==


NMU выполняется в случае выполнения одного из нижеследующих условий:
NMU выполняется в случае выполнения одного из нижеследующих условий:
# Наличие серьёзных ошибок в пакете (major и выше), висящих на нем в системе отслеживания ошибок {{altbug|}}.
# Отсутствие реакции мейнтейнера на запросы от любого из участников ALT Linux Team, выполненные через систему отслеживания ошибок {{altbug|}}, в течение двух недель.
# Наличие проблем с безопасностью в пакете.
# Несобираемость пакета в изменённой сборочной среде (например при обновлении gcc, glibc и т. д.).


== Общие соображения ==
# Без предварительного оповещения мейнтейнера NMU может выполняться при подготовке security-исправлений, требующих приватной подготовки согласно Security Policy (до того момента, как Security Policy принята, такими считаются только исправления, для которых организуется Coordinated Release Date (CRD)). В этом случае мейнтейнер должен быть извещён не позднее, чем пакет будет отправлен в репозиторий.
Перед тем, как делать NMU, следует постараться найти контакт с текущим мейнтейнером — обязательно при помощи отчёта об ошибке в [https://bugzilla.altlinux.org bugzilla], электронной почты, IM, телефона или прямого обращения по мере возможности и уместности.
# Отсутствие реакции мейнтейнера на ошибки с серьёзностью [[BugSeverityPolicy|Critical]] в {{altbug}} в течение двух недель.
# Отсутствие реакции мейнтейнера на ошибки с серьёзностью [[BugSeverityPolicy|Blocker]] в {{altbug}} в течение 12 часов
 
=== Общие соображения ===
Перед тем, как делать NMU, следует постараться найти контакт с текущим мейнтейнером при помощи отчёта об ошибке в {{altbug|}}. Всё общение с мейнтейнером должно быть зафиксировано в bugzilla для упрощения дальнейшей работы администратора ACL, арбитра или безконфликтной комиссии.
 
В случае отсутствия реакции мейнтейнера на ошибку в течении установленного в данном Policy времени следует добавить комментарий к ошибке с запросом на NMU и подготовить обновление.
 
Одновременно с заливкой NMU рекомендуется указать мейнтейнеру на git с исправлением (если мейнтейнер использует gear) либо приложить к ошибке в {{altbug}} патч.
 
=== Управление доступом ===
Мейнтейнер предоставляет или изымает возможность NMU на ведомые им пакеты при помощи [[Git.alt/Справочник#acl|git.alt acl]] и [[Git.alt/Справочник#task_approve|git.alt task approve]].
 
В случае отсутствия реакции мейнтейнера на запросы по предоставлению доступа, право на NMU предоставляет один из [[ACLAdmin|администраторов ACL]].


Если в течение срока от суток до двух недель, в зависимости от срочности проблемы (серьёзная с безопасностью или разваливающая существенную часть репозитория, мешающая не единицам пакетов и/или пользователей), положительный ответ не поступил или проблема не исправлена — следует написать в <tt>devel@</tt> запрос и готовить обновление, если оно ещё не собрано для своих нужд.
== Технологические требования к NMU ==


Лучше всего использовать git для подготовки изменений, исправляющих проблему. Следует обязательно прислать майнтейнеру ссылку на git-репозиторий с исправлениями.
* Изменения должны быть минимальными и настолько неинтрузивными, насколько это возможно (не следует «зачищать» спек, передвигать модули или файлы, и вообще, чинить то, что не сломано — этим следует заниматься мейнтейнерам).
* К NMU предъявляются обычные требования попадания пакета в репозиторий (в частности, наследование по коммитам при использовании gear).
* Если в spec-файле отсутствует поле <tt>Packager</tt>, то его необходимо добавить и указать в нём мейнтейнера пакета.<ref>Однако, ср. [[ACL#@everybody|текущее поведение acl для заливок через @everybody]]: "Принадлежность пакета при таких заливках не меняется." Т.е. в таком случае на самом деле в нынешней ситуации принадлежность не должна поменяться и при отсутствии поля <tt>Packager</tt>.</ref>
* Changelog пакета должен начинаться с «NMU:». В changelog так же должен быть указан номер ошибки в формате, допускающем [[Changelogs_guide#.D0.90.D0.B2.D1.82.D0.BE.D0.B7.D0.B0.D0.BA.D1.80.D1.8B.D1.82.D0.B8.D0.B5_.D0.B1.D0.B0.D0.B3.D0.BE.D0.B2|автоматическое закрытие ошибок]]. Мейнтейнеру следует сохранить или импортировать эту запись при дальнейшем сопровождении пакета.


== Подготовка ==
Не забывайте и Гиппократа: «превыше всего, не навреди». Пусть лучше на пакете будет висеть открытый багрепорт по серьёзной проблеме, чем она будет «разрешена» нерабочим патчем или даже исправлена, но при этом будет сломано ещё что-нибудь.


При исправлении следует учесть, что изменения должны быть минимальными и настолько неинтрузивными, насколько это возможно. Не следует «зачищать» спек, передвигать модули или файлы и вообще чинить то, что не сломано — этим следует заниматься мейнтейнеру или [[PackagerTeams|команде сопровождающих]].
=== Версионирование ===
Если исправление можно сделать в рамках той же upstream-версии пакета, что находится в репозитории, то в значение тэга Release пакета необходимо добавить дополнительное число, отделённое точкой и по нумерации начинающееся с единицы, чтобы не пересечься с обычной нумерацией версий и релизов у основного мейнтейнера.


Не забывайте и Гиппократа: «превыше всего, не навреди». Лучше на пакете будет висеть открытый багрепорт по серьёзной проблеме, чем она будет «разрешена» нерабочим патчем или даже исправлена, но сломано ещё что-нибудь.
Например, пакет, собранный ранее мейнтейнером с релизом <tt>alt3</tt> и автоматически пересобранный ранее QA Team Robot с релизом <tt>alt3.1</tt>, при NMU должен получить релиз <tt>alt3.1.1</tt>.


== Указание Packager ==
Если для исправления необходимо обновление версии в репозитории, то NMU выполняется с изменением версии программы и установкой релиза пакета в <tt>alt1</tt>.


При отсутствии поля Packager в пакете его необходимо добавить, указав в нём реального мейнтейнера, чтобы пакет случайно не перешёл к вам (со всеми своими багами).
Также, во избежание появления в релизе расчесок вида <tt>alt3.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1</tt>
допускаются суффиксы вида <tt>alt<M>{,.n}</tt>, где <M> релиз выставленный мантейнером, а n -- цифра инкрементируемая при NMU.


== Версионирование ==
Также, как исключение, сборки в рамках @qa team могут иметь суффикс <tt>alt<M>{,.qaN}</tt>,
где <M> релиз выставленный мантейнером, а N -- цифра, инкрементируемая при NMU.


Зачастую исправление можно сделать в рамках той же базовой версии пакета; при этом стоит добавить дополнительное число, отделённое точкой и по нумерации начинающееся с единицы к содержимому тега <tt>Release</tt>, чтобы не пересечься с нормальной нумерацией версий у основного мейнтейнера.
== Дополнительная информация ==


Например, пакет, собранный мейнтейнером с релизом <tt>alt3</tt>, автоматически пересобранный QA Team Robot с релизом <tt>alt3.1</tt> — при NMU должен получить релиз <tt>alt3.1.1</tt>.
''Эта секция не является нормативной''


Соответствующая строка в changelog пакета должна содержать слово «NMU», а также ссылки на номера багрепортов. Мейнтейнеру следует сохранить или импортировать эту запись при дальнейшем сопровождении пакета.
NMU и запрос на добавление в список мейнтейнеров — это разные вещи. Если вам хочется принять участие в поддержке пакета — обратитесь к мейнтейнеру и попросите его добавить вас в ACL пакета или группу. Если мейнтейнер не отзывается — имеет смысл [[ACLPolicy|забрать пакет себе]].


== Управление доступом ==
После введения в строй сборки из git-репозиториев стала доступной следующая простая форма реализации NMU:
вы формируете обычное задание на сборку и даёте на него ссылку мейнтейнерам, которые могут её посмотреть и дать подтверждение.
Получив подтверждение, вы просто отправляете это же задание на повторную сборку.


Мейнтейнер в данное время может предоставлять или изымать возможность публикации ведомого им пакета другими участниками команды, передавать им пакет или объявлять его бесхозным при помощи [[Git.alt/Справочник#Управление ACL пакетов|управления ACL пакетов через git.alt]].
Помните, что NMU — это акт помощи, мейнтейнер может быть благодарен за неё. При этом ответственность за судьбу пакета несёт мейнтейнер, и поэтому он вправе в дальнейших сборках пакета делать то, что сочтёт нужным.


В случае отсутствия реакции мантейнера на запросы по предоставлению доступа, согласно условиям предоставления NMU, право на NMU предоставляет один из администраторов репозитария.
Стоит приложить разумные усилия к тому, чтобы облегчить мейнтейнеру принятие решения — приложением к письму или багрепорту патча, ссылкой на конкретный коммит или репозиторий в git.alt, наконец, доброжелательным отношением.


== Ссылки ==
== Ссылки ==
* [http://www.debian.org/doc/developers-reference/ch-pkgs.en.html#s-nmu Debian NMU Policy]
* [[BugSeverityPolicy|Уровни серьёзности ошибок]]
* [[ACL|Общая информация об ACL]]
* [[Git.alt/Справочник#.D0.A3.D0.BF.D1.80.D0.B0.D0.B2.D0.BB.D0.B5.D0.BD.D0.B8.D0.B5_ACL_.D0.BF.D0.B0.D0.BA.D0.B5.D1.82.D0.BE.D0.B2|Справочник по управлению ACL в git.alt]]
 
== Примечания ==
<references />


[[Категория:Sisyphus]]
[[Категория:Sisyphus]]

Текущая версия от 19:27, 14 ноября 2015

Stamp90cw.png
Действующая политика Sisyphus

Политика действует с 01.05.2009.

Ответственный за проведение политики в жизнь — Антон Фарыгин (rider).


Версия 1.1.

NMU (Non-Maintainer Upload) — обновление пакета не сопровождающим его.

Рамки Policy

Данное Policy регламентирует взаимоотношения между мейнтейнерами. Для правил выполнения массовых NMU роботами см. полиси по массовым NMU.

В данном Policy регулируются два вопроса:

  • Условия выдачи NMU
  • Технологические требования к NMU

Условия выдачи NMU

NMU выполняется в случае выполнения одного из нижеследующих условий:

  1. Без предварительного оповещения мейнтейнера NMU может выполняться при подготовке security-исправлений, требующих приватной подготовки согласно Security Policy (до того момента, как Security Policy принята, такими считаются только исправления, для которых организуется Coordinated Release Date (CRD)). В этом случае мейнтейнер должен быть извещён не позднее, чем пакет будет отправлен в репозиторий.
  2. Отсутствие реакции мейнтейнера на ошибки с серьёзностью Critical в bugzilla.altlinux.org в течение двух недель.
  3. Отсутствие реакции мейнтейнера на ошибки с серьёзностью Blocker в bugzilla.altlinux.org в течение 12 часов

Общие соображения

Перед тем, как делать NMU, следует постараться найти контакт с текущим мейнтейнером при помощи отчёта об ошибке в bugzilla.altlinux.org. Всё общение с мейнтейнером должно быть зафиксировано в bugzilla для упрощения дальнейшей работы администратора ACL, арбитра или безконфликтной комиссии.

В случае отсутствия реакции мейнтейнера на ошибку в течении установленного в данном Policy времени следует добавить комментарий к ошибке с запросом на NMU и подготовить обновление.

Одновременно с заливкой NMU рекомендуется указать мейнтейнеру на git с исправлением (если мейнтейнер использует gear) либо приложить к ошибке в bugzilla.altlinux.org патч.

Управление доступом

Мейнтейнер предоставляет или изымает возможность NMU на ведомые им пакеты при помощи git.alt acl и git.alt task approve.

В случае отсутствия реакции мейнтейнера на запросы по предоставлению доступа, право на NMU предоставляет один из администраторов ACL.

Технологические требования к NMU

  • Изменения должны быть минимальными и настолько неинтрузивными, насколько это возможно (не следует «зачищать» спек, передвигать модули или файлы, и вообще, чинить то, что не сломано — этим следует заниматься мейнтейнерам).
  • К NMU предъявляются обычные требования попадания пакета в репозиторий (в частности, наследование по коммитам при использовании gear).
  • Если в spec-файле отсутствует поле Packager, то его необходимо добавить и указать в нём мейнтейнера пакета.[1]
  • Changelog пакета должен начинаться с «NMU:». В changelog так же должен быть указан номер ошибки в формате, допускающем автоматическое закрытие ошибок. Мейнтейнеру следует сохранить или импортировать эту запись при дальнейшем сопровождении пакета.

Не забывайте и Гиппократа: «превыше всего, не навреди». Пусть лучше на пакете будет висеть открытый багрепорт по серьёзной проблеме, чем она будет «разрешена» нерабочим патчем или даже исправлена, но при этом будет сломано ещё что-нибудь.

Версионирование

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

Например, пакет, собранный ранее мейнтейнером с релизом alt3 и автоматически пересобранный ранее QA Team Robot с релизом alt3.1, при NMU должен получить релиз alt3.1.1.

Если для исправления необходимо обновление версии в репозитории, то NMU выполняется с изменением версии программы и установкой релиза пакета в alt1.

Также, во избежание появления в релизе расчесок вида alt3.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1 допускаются суффиксы вида alt<M>{,.n}, где <M> релиз выставленный мантейнером, а n -- цифра инкрементируемая при NMU.

Также, как исключение, сборки в рамках @qa team могут иметь суффикс alt<M>{,.qaN}, где <M> релиз выставленный мантейнером, а N -- цифра, инкрементируемая при NMU.

Дополнительная информация

Эта секция не является нормативной

NMU и запрос на добавление в список мейнтейнеров — это разные вещи. Если вам хочется принять участие в поддержке пакета — обратитесь к мейнтейнеру и попросите его добавить вас в ACL пакета или группу. Если мейнтейнер не отзывается — имеет смысл забрать пакет себе.

После введения в строй сборки из git-репозиториев стала доступной следующая простая форма реализации NMU: вы формируете обычное задание на сборку и даёте на него ссылку мейнтейнерам, которые могут её посмотреть и дать подтверждение. Получив подтверждение, вы просто отправляете это же задание на повторную сборку.

Помните, что NMU — это акт помощи, мейнтейнер может быть благодарен за неё. При этом ответственность за судьбу пакета несёт мейнтейнер, и поэтому он вправе в дальнейших сборках пакета делать то, что сочтёт нужным.

Стоит приложить разумные усилия к тому, чтобы облегчить мейнтейнеру принятие решения — приложением к письму или багрепорту патча, ссылкой на конкретный коммит или репозиторий в git.alt, наконец, доброжелательным отношением.

Ссылки

Примечания

  1. Однако, ср. текущее поведение acl для заливок через @everybody: "Принадлежность пакета при таких заливках не меняется." Т.е. в таком случае на самом деле в нынешней ситуации принадлежность не должна поменяться и при отсутствии поля Packager.