ci: add SSH server testing to GitHub Actions workflow #45
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: testing main branch | |
on: [push] | |
jobs: | |
default-user-name-password: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- name: ssh by username and password | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
password: password | |
port: 2222 | |
script: | | |
#!/usr/bin/env bash | |
set -e | |
whoami | |
- name: ssh commands from a file | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
password: password | |
port: 2222 | |
script_path: testdata/test.sh | |
check-ssh-key: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: add public key to env | |
run: | | |
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_rsa.pub >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= public key =========" | |
cat testdata/.ssh/id_rsa.pub | |
echo "============================" | |
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_rsa >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= private key =========" | |
cat testdata/.ssh/id_rsa | |
echo "============================" | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- name: ssh by private key | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
script: whoami | |
- name: wrong password but correct key | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
password: "abcdef" | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
script: whoami | |
- name: correct password but wrong key | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
password: password | |
key: password | |
port: 2222 | |
script: whoami | |
support-key-passphrase: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: add public key to env | |
run: | | |
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_passphrase.pub >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= public key =========" | |
cat testdata/.ssh/id_passphrase.pub | |
echo "============================" | |
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_passphrase >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= private key =========" | |
cat testdata/.ssh/id_passphrase | |
echo "============================" | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- name: ssh key passphrase | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
passphrase: 1234 | |
script: | | |
whoami | |
ls -al | |
- name: missing ssh key passphrase | |
uses: ./ | |
continue-on-error: true | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
script: | | |
whoami | |
ls -al | |
# https://github.com/appleboy/ssh-action/issues/75#issuecomment-668314271 | |
- name: Multiline SSH commands interpreted as single lines | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
passphrase: 1234 | |
script: | | |
ls \ | |
-lah | |
use_insecure_cipher: true | |
multiple-server: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: add public key to env | |
run: | | |
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_passphrase.pub >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= public key =========" | |
cat testdata/.ssh/id_passphrase.pub | |
echo "============================" | |
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_passphrase >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= private key =========" | |
cat testdata/.ssh/id_passphrase | |
echo "============================" | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server-01 \ | |
--hostname=openssh-server-01 \ | |
-p 2222:2222 \ | |
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server-01 sh -c "hostname -i" > ip01.txt | |
echo "REMOTE_HOST_01<<EOF" >> $GITHUB_ENV | |
cat ip01.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip01.txt | |
echo "======================================" | |
docker run -d \ | |
--name=openssh-server-02 \ | |
--hostname=openssh-server-02 \ | |
-p 2223:2222 \ | |
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server-02 sh -c "hostname -i" > ip02.txt | |
echo "REMOTE_HOST_02<<EOF" >> $GITHUB_ENV | |
cat ip02.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip02.txt | |
echo "======================================" | |
sleep 2 | |
# https://github.com/appleboy/ssh-action/issues/85 | |
- name: Deployment to multiple hosts with different ports | |
uses: ./ | |
with: | |
host: "${{ env.REMOTE_HOST_01 }}:2222,${{ env.REMOTE_HOST_02 }}:2222" | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
passphrase: 1234 | |
script: | | |
whoami | |
support-ed25519-key: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: add public key to env | |
run: | | |
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_ed25519.pub >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= public key =========" | |
cat testdata/.ssh/id_ed25519.pub | |
echo "============================" | |
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_ed25519 >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= private key =========" | |
cat testdata/.ssh/id_ed25519 | |
echo "============================" | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- name: testing id_ed25519 key | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
script: | | |
whoami | |
ls -al | |
testing-with-env: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: add public key to env | |
run: | | |
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_ed25519.pub >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= public key =========" | |
cat testdata/.ssh/id_ed25519.pub | |
echo "============================" | |
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV | |
cat testdata/.ssh/id_ed25519 >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= private key =========" | |
cat testdata/.ssh/id_ed25519 | |
echo "============================" | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \ | |
-e SUDO_ACCESS=true \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- name: testing id_ed25519 key | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
script: | | |
whoami | |
ls -al | |
- name: pass environment | |
uses: ./ | |
env: | |
FOO: "BAR" | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
envs: FOO | |
script: | | |
echo "I am $FOO, thanks" | |
echo "I am $BAR, thanks" | |
- name: pass multiple environment | |
uses: ./ | |
env: | |
FOO: "BAR" | |
BAR: "FOO" | |
SHA: ${{ github.sha }} | |
PORT: ${{ secrets.PORT }} | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
envs: FOO,BAR,SHA,PORT | |
script: | | |
echo "I am $FOO, thanks" | |
echo "I am $BAR, thanks" | |
echo "sha: $SHA" | |
echo "port: $PORT" | |
- name: custom envs format | |
uses: ./ | |
env: | |
FOO: "BAR" | |
AAA: "BBB" | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
envs: FOO,BAR,AAA | |
envs_format: export TEST_{NAME}={VALUE} | |
script: | | |
echo "I am $TEST_FOO, thanks" | |
echo "I am $TEST_BAR, thanks" | |
echo "I am $BAR, thanks" | |
echo "I am $TEST_AAA, thanks" | |
- name: pass all ENV variables to script | |
uses: ./ | |
env: | |
INPUT_FOO: "BAR" | |
INPUT_AAA: "BBB" | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
allenvs: true | |
script: | | |
echo "I am $INPUT_FOO, thanks" | |
echo "I am $INPUT_AAA, thanks" | |
echo "$GITHUB_BASE_REF" | |
echo "$GITHUB_REF" | |
- name: pass secret variable in shell | |
uses: ./ | |
continue-on-error: true | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
script: cd ${{ secrets.PORT }} | |
- name: switch to root user | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
key: ${{ env.PRIVATE_KEY }} | |
port: 2222 | |
request_pty: true | |
command_timeout: 30s | |
script: | | |
whoami && echo 'hello world' && touch todo.txt | |
sudo whoami | |
testing06: | |
name: testing ipv6 | |
runs-on: ubuntu-latest | |
steps: | |
- name: checkout | |
uses: actions/checkout@v4 | |
- name: Set up WARP | |
uses: fscarmen/[email protected] | |
with: | |
stack: dual | |
- name: testing ipv6 for command | |
run: | | |
curl -m 9 --ipv6 --verbose https://google.com | |
- name: testing ipv6 | |
uses: ./ | |
continue-on-error: true | |
with: | |
host: 2402:1f00:8000:800::2628 | |
username: ubuntu | |
password: ${{ secrets.OVH_PASSWORD }} | |
protocol: tcp6 | |
port: 22 | |
command_timeout: 30s | |
script: | | |
whoami | |
testing07: | |
name: some special character | |
runs-on: ubuntu-latest | |
steps: | |
- name: checkout | |
uses: actions/checkout@v4 | |
- name: Set Environment Variables | |
run: | | |
PASS='3HUS$?8kLu)}' | |
printf "PASS=${PASS}" >> $GITHUB_ENV | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD='${{ env.PASS }}' \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- name: ssh by username and password | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
password: ${{ env.PASS }} | |
port: 2222 | |
script: | | |
#!/usr/bin/env bash | |
set -e | |
whoami | |
testing-capturing-output: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- id: stdout | |
name: ssh command with stdout | |
uses: ./ | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
password: password | |
port: 2222 | |
capture_stdout: true | |
script: | | |
#!/usr/bin/env bash | |
set -e | |
whoami | |
- name: check stdout | |
run: | | |
echo "stdout: ${{ steps.stdout.outputs.stdout }}" | |
testing-script-stop: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- id: stdout01 | |
name: ssh command with stdout 01 | |
uses: ./ | |
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: ./ | |
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 | |
testing-script-error: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: create new ssh server | |
run: | | |
docker run -d \ | |
--name=openssh-server \ | |
--hostname=openssh-server \ | |
-p 2222:2222 \ | |
-e SUDO_ACCESS=false \ | |
-e PASSWORD_ACCESS=true \ | |
-e USER_PASSWORD=password \ | |
-e USER_NAME=linuxserver.io \ | |
--restart unless-stopped \ | |
lscr.io/linuxserver/openssh-server:latest | |
docker exec openssh-server sh -c "hostname -i" > ip.txt | |
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV | |
cat ip.txt >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "======= container ip address =========" | |
cat ip.txt | |
echo "======================================" | |
sleep 2 | |
- name: test script error | |
uses: ./ | |
continue-on-error: true | |
with: | |
host: ${{ env.REMOTE_HOST }} | |
username: linuxserver.io | |
password: password | |
port: 2222 | |
capture_stdout: true | |
script: | | |
#!/usr/bin/env bash | |
set -e | |
ls /nonexistent |