Skip to main content

Tool for flattening include statements in GitHub actions workflow.yml files.

Project description

actions-includes

License GitHub issues PyPI PyPI - Python Version PyPI - Downloads

Allows including an action inside another action (by preprocessing the Yaml file).

Instead of using uses or run in your action step, use the keyword includes.

Once you are using the includes argument, the workflows can be expanded using the tool like follows;

# python -m actions_include <input-workflow-with-includes> <output-workflow-flattened>
python -m actions_includes ./.github/workflows-src/workflow-a.yml ./.github/workflows/workflow-a.yml

includes: step

steps:
- name: Other step
  run: |
    command

- includes: {action-name}
  with:
    {inputs}

- name: Other step
  run: |
    command

The {action-name} follows the same syntax as the standard GitHub action uses and the action referenced should look exactly like a GitHub "composite action" except runs.using should be includes.

For example;

  • {owner}/{repo}@{ref} - Public action in github.com/{owner}/{repo}
  • {owner}/{repo}/{path}@{ref} - Public action under {path} in github.com/{owner}/{repo}.
  • ./{path} - Local action under local {path}, IE ./.github/actions/my-action.

As it only makes sense to reference composite actions, the docker:// form isn't supported.

As you frequently want to include local actions, actions-includes extends the {action-name} syntax to also support;

  • /{name} - Local action under ./.github/actions/{name}.

This is how composite actions should have worked.

includes-script: step

File: script.py

print('Hello world')

File: workflow.yml

steps:
- name: Other step
  run: |
    command

- name: Hello
  includes-script: script.py

- name: Other step
  run: |
    command

python -m actions_includes.py workflow.in.yml workflow.out.yml

File: oworkflow.out.yml

steps:
- name: Other step
  run: |
    command

- name: Hello
  shell: python
  run: |
    print('Hello world')

- name: Other step
  run: |
    command

The shell parameter is deduced from the file extension, but it is possible to use a custom shell by setting the shell parameter manually.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

actions-includes-0.0.post117.tar.gz (36.4 kB view details)

Uploaded Source

Built Distributions

actions_includes-0.0.post117-py3.9.egg (54.9 kB view details)

Uploaded Source

actions_includes-0.0.post117-py3.8.egg (54.9 kB view details)

Uploaded Source

actions_includes-0.0.post117-py3-none-any.whl (29.6 kB view details)

Uploaded Python 3

File details

Details for the file actions-includes-0.0.post117.tar.gz.

File metadata

  • Download URL: actions-includes-0.0.post117.tar.gz
  • Upload date:
  • Size: 36.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.8.8

File hashes

Hashes for actions-includes-0.0.post117.tar.gz
Algorithm Hash digest
SHA256 cf0960dfbc511025faeac9338a1d74d0155abd3858aa6b7482e3bb9fc0af16d3
MD5 dbd68dd7d33ebe697e16b977ae330fdf
BLAKE2b-256 9fec3ebcc305530a2368ef0d6b13213cfb20b2835eaf13e5acba7f163aa7d5a8

See more details on using hashes here.

File details

Details for the file actions_includes-0.0.post117-py3.9.egg.

File metadata

  • Download URL: actions_includes-0.0.post117-py3.9.egg
  • Upload date:
  • Size: 54.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2

File hashes

Hashes for actions_includes-0.0.post117-py3.9.egg
Algorithm Hash digest
SHA256 519785d3852577ea5d8dd051529e36518970076402b4ba5b2fe17b0378701b6d
MD5 6ba457dd65469cc9ab5554080eafe32b
BLAKE2b-256 aa3ca4babdb4cb49437633e8e732b0215a3a709ca5cc18690bc9914289c0d507

See more details on using hashes here.

File details

Details for the file actions_includes-0.0.post117-py3.8.egg.

File metadata

  • Download URL: actions_includes-0.0.post117-py3.8.egg
  • Upload date:
  • Size: 54.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.8.8

File hashes

Hashes for actions_includes-0.0.post117-py3.8.egg
Algorithm Hash digest
SHA256 8e06fc397f0c17fca14d8f9e127f07ff17ab5cb7c82eb81846cf9b061803ee3a
MD5 1f3fd6110683bc71b20ca5d673aa00a9
BLAKE2b-256 97adb7c16aeae18fd5af761737b49a99af6302b0f58f061a52285a6cd73dcc5e

See more details on using hashes here.

File details

Details for the file actions_includes-0.0.post117-py3-none-any.whl.

File metadata

  • Download URL: actions_includes-0.0.post117-py3-none-any.whl
  • Upload date:
  • Size: 29.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.8.8

File hashes

Hashes for actions_includes-0.0.post117-py3-none-any.whl
Algorithm Hash digest
SHA256 c10e3202181e1813e743da89bac78c0114808cc03f95f69e177e82cdf4ed3d67
MD5 fa57e6a393994057def6de48a4435108
BLAKE2b-256 5ce93e632b915259e4afb3562be451c8cc13c7be616a472dc73bb141e4b53177

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page