Skip to main content

Управление пользовательскими действиями

Узнайте, как создавать собственные действия и управлять ими, а также настраивать действия, используемые сообществом GitHub.

Выбор расположения для действия

Если вы разрабатываете действие для других пользователей, рекомендуется сохранить действие в собственном репозитории вместо объединения его с другим кодом приложения. Это позволяет осуществлять управление версиями, отслеживание и выпуск для действия точно так же, как и для любого другого программного обеспечения.

Хранение действия в собственном репозитории упрощает обнаружение действия в сообществе GitHub, ограничивает область базы кода для разработчиков, устраняющих проблемы и расширяющих действие, а также отделяет управление версиями от версий другого кода приложения.

Если вы создаете действие, которое не планируете делать доступным для других пользователей, вы можете хранить файлы этого действия в любом расположении своего репозитория. Если вы планируете объединить действие, рабочий процесс и код приложения в одном репозитории, рекомендуется хранить действия в каталоге .github. Например, .github/actions/action-a и .github/actions/action-b.

Обеспечение совместимости с другими платформами

Многие пользователи получают доступ к GitHub в домене, отличном от GitHub.com, например GHE.com или личного домена для GitHub Enterprise Server.

Чтобы убедиться, что действие совместимо с другими платформами, не используйте жестко закодированные ссылки на URL-адреса API, например https://api.github.com. Вместо этого можно:

  • Используйте переменные среды (см . AUTOTITLE):

    • Для REST API используйте переменную среды GITHUB_API_URL.
    • Для GraphQL используйте переменную среды GITHUB_GRAPHQL_URL.
  • Используйте набор средств, например @actions/github, который может автоматически задать правильные URL-адреса.

Использование управления выпусками для действий

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

В рамках этого подхода к управлению выпусками пользователи не должны ссылаться на ветвь по умолчанию действия, так как, скорее всего, содержит последний код и, следовательно, может быть неустойчивым. Вместо этого можно порекомендовать, чтобы пользователи указывали основной номер версии при использовании действия, и перенаправлять их к более конкретной версии только при возникновении проблем.

Чтобы использовать определенную версию действия, пользователи могут настроить рабочий процесс GitHub Actions для тега, SHA фиксации или ветви, названной по выпуску.

Использование тегов для управления выпусками

Мы рекомендуем использовать теги для управления выпусками действий. С помощью этого подхода пользователи могут легко различать основной и дополнительный номера версии:

  1. Разработка и проверка выпуска в ветви выпуска (например, release/v1).
  2. Создайте выпуск с тегом выпуска с помощью семантического управления версиями (например, v1.0.1). Дополнительные сведения см. в разделе Управление выпусками в репозитории.
  3. Переместите тег основной версии (например, v1), чтобы указать ссылку на Git ref текущего выпуска. Дополнительные сведения см. в основах Git.
  4. Введите новый тег основной версии (например, v2) для изменений, которые будут нарушать существующие рабочие процессы, такие как изменение входных данных действия.

Синтаксис для ссылок

В этом примере показано, как пользователь может ссылаться на основной тег версии:

steps:
    - uses: actions/javascript-action@v1

В этом примере показано, как пользователь может ссылаться на тег определенного выпуска исправления:

steps:
    - uses: actions/javascript-action@v1.0.1

Использование ветвей для управления выпусками

Если вы предпочитаете использовать имена ветвей для управления выпусками, в этом примере показано, как ссылаться на именованную ветвь:

steps:
    - uses: actions/javascript-action@v1-beta

Использование SHA фиксации для управления выпусками

Каждая фиксация Git получает вычисляемое значение SHA, которое является уникальным и неизменяемым. Пользователи вашего действия могут предпочесть использование значения SHA фиксации, так как такой подход может оказаться более надежным, чем указание тега, который может быть удален или перемещен. Однако это означает, что пользователи не получат дальнейшие обновления для такого действия. Необходимо использовать полное значение SHA фиксации, а не сокращенное.

steps:
    - uses: actions/javascript-action@a824008085750b8e136effc585c3cd6082bd575f

Создание файла сведений для действия

Мы рекомендуем создать файл сведений, чтобы помочь людям понять, как следует использовать ваше действие. В файл README.md можно включить следующее:

  • подробное описание того, что делает действие;
  • обязательные входные и выходные аргументы;
  • необязательные входные и выходные аргументы;
  • секреты, используемые действием;
  • переменные среды, используемые действием;
  • пример использования действия в рабочем процессе.