9868e13772
* Feature: uses in composite * Negate logic * Reduce complexity * Update step_context.go * Update step_context.go * Update step_context.go * Fix syntax error in test * Bump * Disable usage of actions/setup-node@v2 * Bump * Fix step id collision * Fix output command workaround * Make secrets context inaccessible in composite * Fix order after adding a workaround (needs tests) Fixes https://github.com/nektos/act/pull/793#issuecomment-922329838 * Evaluate env before passing one step deeper If env would contain any inputs, steps ctx or secrets there was undefined behaviour * [no ci] prepare secret test * Initial test pass inputs as env * Fix syntax error * extend test also for direct invoke * Fix passing provided env as composite output * Fix syntax error * toUpper 'no such secret', act has a bug * fix indent * Fix env outputs in composite * Test env outputs of composite * Fix inputs not defined in docker actions * Fix interpolate args input of docker actions * Fix lint * AllowCompositeIf now defaults to true see https://github.com/actions/runner/releases/tag/v2.284.0 * Fix lint * Fix env of docker action.yml * Test calling a local docker action from composite With input context hirachy * local-action-dockerfile Test pass on action/runner It seems action/runner ignores overrides of args, if the target docker action has the args property set. * Fix exec permissions of docker-local-noargs * Revert getStepsContext change * fix: handle composite action on error and continue This change is a follow up of https://github.com/nektos/act/pull/840 and integrates with https://github.com/nektos/act/pull/793 There are two things included here: - The default value for a step.if in an action need to be 'success()' - We need to hand the error from a composite action back to the calling executor Co-authored-by: Björn Brauer <bjoern.brauer@new-work.se> * Patch inputs can be bool, float64 and string for workflow_call Also inputs is now always defined, but may be null * Simplify cherry-picked commit * Minor style adjustments * Remove chmod +x from tests now fails on windows like before * Fix GITHUB_ACTION_PATH some action env vars Fixes GITHUB_ACTION_REPOSITORY, GITHUB_ACTION_REF. * Add comment to CompositeRestrictions Co-authored-by: Markus Wolf <markus.wolf@new-work.se> Co-authored-by: Björn Brauer <bjoern.brauer@new-work.se> Co-authored-by: Ryan <me@hackerc.at> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
63 lines
No EOL
2.5 KiB
YAML
63 lines
No EOL
2.5 KiB
YAML
---
|
|
name: "Test Composite Action"
|
|
description: "Test action uses composite"
|
|
|
|
inputs:
|
|
test_input_optional:
|
|
description: Test
|
|
|
|
runs:
|
|
using: "composite"
|
|
steps:
|
|
# The output of actions/setup-node@v2 seems to fail the workflow
|
|
# - uses: actions/setup-node@v2
|
|
# with:
|
|
# node-version: '16'
|
|
# - run: |
|
|
# console.log(process.version);
|
|
# console.log("Hi from node");
|
|
# console.log("${{ inputs.test_input_optional }}");
|
|
# if("${{ inputs.test_input_optional }}" !== "Test") {
|
|
# console.log("Invalid input test_input_optional expected \"Test\" as value");
|
|
# process.exit(1);
|
|
# }
|
|
# if(!process.version.startsWith('v16')) {
|
|
# console.log("Expected node v16, but got " + process.version);
|
|
# process.exit(1);
|
|
# }
|
|
# shell: node {0}
|
|
- uses: ./uses-composite/composite_action
|
|
id: composite
|
|
with:
|
|
test_input_required: 'test_input_required_value'
|
|
test_input_optional: 'test_input_optional_value'
|
|
test_input_optional_with_default_overriden: 'test_input_optional_with_default_overriden'
|
|
test_input_required_with_default: 'test_input_optional_value'
|
|
test_input_required_with_default_overriden: 'test_input_required_with_default_overriden'
|
|
secret_input: ${{inputs.test_input_optional}}
|
|
env:
|
|
secret_input: ${{inputs.test_input_optional}}
|
|
- run: |
|
|
echo "steps.composite.outputs.test_output=${{ steps.composite.outputs.test_output }}"
|
|
[[ "${{steps.composite.outputs.test_output == 'test_output_value'}}" = "true" ]] || exit 1
|
|
shell: bash
|
|
- run: |
|
|
echo "steps.composite.outputs.secret_output=${{ steps.composite.outputs.secret_output }}"
|
|
[[ "${{steps.composite.outputs.secret_output == format('{0}/{0}', inputs.test_input_optional)}}" = "true" ]] || exit 1
|
|
shell: bash
|
|
# Now test again with default values
|
|
- uses: ./uses-composite/composite_action
|
|
id: composite2
|
|
with:
|
|
test_input_required: 'test_input_required_value'
|
|
test_input_optional_with_default_overriden: 'test_input_optional_with_default_overriden'
|
|
test_input_required_with_default_overriden: 'test_input_required_with_default_overriden'
|
|
|
|
- run: |
|
|
echo "steps.composite2.outputs.test_output=${{ steps.composite2.outputs.test_output }}"
|
|
[[ "${{steps.composite2.outputs.test_output == 'test_output_value'}}" = "true" ]] || exit 1
|
|
shell: bash
|
|
- run: |
|
|
echo "steps.composite.outputs.secret_output=$COMPOSITE_ACTION_ENV_OUTPUT"
|
|
[[ "${{env.COMPOSITE_ACTION_ENV_OUTPUT == 'my test value' }}" = "true" ]] || exit 1
|
|
shell: bash |