Действия Github: как выполнять сценарии оболочки? - PullRequest
3 голосов
/ 28 мая 2020
├── .github
│   └── workflows
│       ├── cd.yml
│       └── ci.yml
├── scripts
│   ├── createDevEBAppVersion.sh
│   └── createProdEBAppVersion.sh
├── src

Действия Github выдают следующую ошибку:

/ home / runner / work / _temp / 9c99fa0d-20da-49ed-a0af-322f274c13a c. sh: строка 1 : [refs / Heads / develop: Нет такого файла или каталога

/ home / runner / work / _temp / 9c99fa0d-20da-49ed-a0af-322f274c13a c. sh: строка 5: [[ refs / Heads / develop: нет такого файла или каталога

name: CD

env:
  PACKAGE_NAME          : "app_${GITHUB_SHA::8}.zip"
  ARTIFACT_ROOT         : "${GITHUB_REF#refs/*/}"
  APPLICATION_NAME      : "example-app-name"
  AWS_ACCESS_KEY_ID     : ${{ secrets.AWS_ACCESS_KEY }}
  AWS_SECRET_ACCESS_KEY : ${{ secrets.AWS_SECRET_KEY }}
  AWS_REGION            : ${{ secrets.AWS_REGION }}
  AWS_BUCKET            : ${{ secrets.AWS_S3_BUCKET_NAME }}

on:
  push:
    branches:
      - develop
    paths-ignore:
      - '**.json'
      - '**.md'
  release:
    tags:
      - 'v*'

jobs:
  deploy:
    runs-on: ubuntu-latest

    steps:
    - uses: actions/checkout@v2
    - name: Create ZIP package artifact
      run: git archive --format=zip HEAD -o ${{ env.PACKAGE_NAME }}

    - name: Configure AWS Credentials
      uses: aws-actions/configure-aws-credentials@v1
      with:
        aws-access-key-id: ${{ env.AWS_ACCESS_KEY_ID }}
        aws-secret-access-key: ${{ env.AWS_SECRET_ACCESS_KEY }}
        aws-region: ${{ env.AWS_REGION }}

    - name: Copy package artifact to S3 bucket
      run: |
        aws s3 cp ${{ env.PACKAGE_NAME }} s3://${{ env.AWS_BUCKET }}/${{ env.APPLICATION_NAME }}/
        echo "✔ Artifact uploaded successfully to s3://${{ env.AWS_BUCKET }}/${{ env.APPLICATION_NAME }}/${{ env.PACKAGE_NAME }}"

    - name: Create new ElasticBeanstalk Application Version
      working-directory: scripts
      run : |
        if ["${{ github.ref }}" == "refs/heads/develop"]; then
          chmod +x ./createDevEBAppVersion.sh
          ./createDevEBAppVersion.sh
        fi
        if [["${{ github.ref }}" == *"refs/tags/v"*]]; then
          chmod +x ./createProdEBAppVersion.sh
          ./createProdEBAppVersion.sh
        fi

    ...

Я пробовал, не имея working-directory, но это не сработало.

#!/usr/bin/env bash

aws elasticbeanstalk create-application-version \
--application-name ${{ env.APPLICATION_NAME }} \
--source-bundle S3Bucket="${{ env.AWS_BUCKET }}",S3Key="${{ env.APPLICATION_NAME }}/${{ env.PACKAGE_NAME }}" \
--version-label "${{ env.PACKAGE_NAME }}" \
--description "Application version created from https://github.com/$GITHUB_REPOSITORY/actions/runs/$GITHUB_RUN_ID"
echo "✔ Deployment triggered successfully."

Это похоже, у CI были проблемы с поиском файла. Как я могу выполнить createDevEBAppVersion.sh?

1 Ответ

4 голосов
/ 28 мая 2020

Ваше сообщение об ошибке:

/home/runner/work/_temp/9c99fa0d-20da-49ed-a0af-322f274c13ac.sh: line 1: [refs/heads/develop: No such file or directory

Он пытается выполнить [refs/heads/develop и терпит неудачу. Причина root в том, что вам не хватает места между скобкой и тестом. Вы хотите:

if [ "${{ github.ref }}" == "refs/heads/develop" ]; then

(И то же самое в строке 5.)

Это потому, что if в оболочках bourne на самом деле запускает команду , которую он оценивает. Хотя похоже, что он оценивает выражение, на самом деле он передает выражение команде с именем [.

% ls -Flas /bin/\[
 8 -rwxr-xr-x  1 root  wheel  22704 May  4  2019 /bin/[*

Это часто является символической ссылкой (или жесткой ссылкой) на /bin/test, а в некоторых оболочках например, bash и zsh, [ будет фактически встроенной оболочкой:

% which '['
[: shell built-in command

Но он по-прежнему ведет себя как команда, и синтаксически ему нужно пространство. Потому что:

if [ true ]; then ...

Запускает команду [ (или встроенную в оболочку) для оценки команды /bin/true. И

if [true ]; then ...

Пытается выполнить несуществующую команду [true.

...