Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

script_stop: true mess up cat command #335

Closed
uchar opened this issue Sep 4, 2024 · 6 comments · Fixed by #350 or #355
Closed

script_stop: true mess up cat command #335

uchar opened this issue Sep 4, 2024 · 6 comments · Fixed by #350 or #355
Assignees
Labels
bug Something isn't working

Comments

@uchar
Copy link

uchar commented Sep 4, 2024

Describe the bug

When I use script_stop: true the output of the cat command becomes

    {
              "RESTORE_BACKUP": "$RESTORE_BACKUP",
              "FTP_HOST": "$FTP_HOST",
              DRONE_SSH_PREV_COMMAND_EXIT_CODE=0 ; if [ 0 -ne 0 ]; then exit 0; fi;
             {
              DRONE_SSH_PREV_COMMAND_EXIT_CODE=0 ; if [ 0 -ne 0 ]; then exit 0; fi;

Yaml Config

      - name: Clone project and run docker
        uses: appleboy/ssh-action@master
        env:
          FTP_HOST: ${{ secrets.FTP_HOST }}
          RESTORE_BACKUP: ${{ github.event.inputs.restoreBackup }}
        with:
          command_timeout: 60m
          script_stop: true
          host: ${{ secrets.SSH_HOST }}
          username: ${{ secrets.SSH_USER }}
          key: ${{ secrets.SSH_PRIVATE_KEY }}
          port: ${{ secrets.SSH_PORT }}
          envs: FTP_HOST,RESTORE_BACKUP
          script: |
            cat <<EOF > ./inputsData/deployEnvs.json
            {
              "RESTORE_BACKUP": "$RESTORE_BACKUP",
              "FTP_HOST": "$FTP_HOST",
            }
            EOF

it works fine without script_stop: true

@uchar uchar added the bug Something isn't working label Sep 4, 2024
@ArtemGoutsoul
Copy link

ArtemGoutsoul commented Sep 13, 2024

bumped into the same issue when using ssh-action to update nginx configs remotely

this bug makes HEREDOC unusable in this context :(

as a workaround I had to convert the HEREDOC into one-liner which greatly reduced the readability of the workflow

@georgique
Copy link

I can confirm that if statements are not working correctly with script_stop=true.

Script:

echo "TMP TESTING IF"
if [[ "2" == "1" ]]; then
  echo "True"
else
  echo "False"
fi

Output:

out: TMP TESTING IF
2024/09/24 21:19:30 Process exited with status 1

Script:

echo "TMP TESTING IF"
if [[ "1" == "1" ]]; then
  echo "True"
else
  echo "False"
fi

Output:

out: TMP TESTING IF
out: True
2024/09/24 21:20:40 Process exited with status 1

@appleboy
Copy link
Owner

I will disable the script_stop flag on the next version.

@georgique
Copy link

@appleboy How is that a fix? It was a very needed functionality

@uchar
Copy link
Author

uchar commented Dec 4, 2024

I think this issue should remains open until a proper solution found

@appleboy
Copy link
Owner

appleboy commented Dec 5, 2024

@georgique @uchar See the PR for the sample code:

#355

result: https://github.com/appleboy/ssh-action/actions/runs/12175794110/job/33960230162

      - id: stdout01
        name: ssh command with stdout 01
        uses: appleboy/ssh-action@master
        with:
          host: ${{ env.REMOTE_HOST }}
          username: linuxserver.io
          password: password
          port: 2222
          capture_stdout: true
          script: |
            #!/usr/bin/env bash
            set -e
            echo "TMP TESTING IF"
            if [[ "2" == "1" ]]; then
              echo "True"
            else
              echo "False"
            fi

      - name: check stdout 01
        run: |
          echo "stdout: ${{ steps.stdout01.outputs.stdout }}"
          if echo "${{ steps.stdout01.outputs.stdout }}" | grep -q "True"; then
            echo "Output contains 'True'"
            exit 1
          fi
          if echo "${{ steps.stdout01.outputs.stdout }}" | grep -q "False"; then
            echo "Output contains 'False'"
          fi

      - id: stdout02
        name: ssh command with stdout 01
        uses: appleboy/ssh-action@master
        with:
          host: ${{ env.REMOTE_HOST }}
          username: linuxserver.io
          password: password
          port: 2222
          capture_stdout: true
          script: |
            #!/usr/bin/env bash
            set -e
            echo "TMP TESTING IF"
            if [[ "1" == "1" ]]; then
              echo "True"
            else
              echo "False"
            fi

      - name: check stdout 02
        run: |
          echo "stdout: ${{ steps.stdout02.outputs.stdout }}"
          if echo "${{ steps.stdout02.outputs.stdout }}" | grep -q "False"; then
            echo "Output contains 'False'"
            exit 1
          fi
          if echo "${{ steps.stdout02.outputs.stdout }}" | grep -q "True"; then
            echo "Output contains 'True'"
          fi

appleboy added a commit that referenced this issue Dec 5, 2024
* ci: add SSH testing job to GitHub Actions workflow

#335 (comment)

- Add a new job `testing-script-stop` to the GitHub Actions workflow
- Set up an SSH server using a Docker container within the new job
- Capture the container's IP address and store it in the GitHub environment
- Add a step to run an SSH command with stdout capture
- Include a script to test conditional logic within the SSH command
- Add a step to check and print the captured stdout from the SSH command

Signed-off-by: Bo-Yi Wu <[email protected]>

* ci: improve GitHub Actions workflow with conditional checks

- Add conditional checks in GitHub Actions workflow to handle 'True' and 'False' outputs

Signed-off-by: Bo-Yi Wu <[email protected]>

* ci: standardize naming and validation of stdout steps

- Rename `stdout` step to `stdout01` in the GitHub Actions workflow
- Rename `check stdout` step to `check stdout 01`
- Update references to `stdout` to `stdout01` in echo and grep commands
- Add a new step `stdout02` for SSH command execution with stdout capture
- Add a new step `check stdout 02` to validate the output of `stdout02` step

Signed-off-by: Bo-Yi Wu <[email protected]>

---------

Signed-off-by: Bo-Yi Wu <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
4 participants