mirror of
https://github.com/easingthemes/ssh-deploy.git
synced 2024-04-28 00:37:18 +08:00
test
This commit is contained in:
parent
fd8e654d7e
commit
aeee708bee
73
.github/workflows/e2e.yml
vendored
73
.github/workflows/e2e.yml
vendored
@ -5,8 +5,9 @@ on:
|
|||||||
branches: [ 'feature/add-tests' ]
|
branches: [ 'feature/add-tests' ]
|
||||||
|
|
||||||
env:
|
env:
|
||||||
|
GLOBAL_WORKFLOW_ENV: __some value for GLOBAL_WORKFLOW_ENV__
|
||||||
TEST_HOST_DOCKER: ./test
|
TEST_HOST_DOCKER: ./test
|
||||||
TEST_USER: kaja
|
TEST_USER: test
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
e2e:
|
e2e:
|
||||||
@ -16,6 +17,25 @@ jobs:
|
|||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
# - name: Set ENV var
|
||||||
|
# run: |
|
||||||
|
# echo "CUSTOM_VAR=IT WORKS" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
# - name: Use ENV var via `env` block
|
||||||
|
# run: |
|
||||||
|
# echo $CUSTOM_VAR # OK
|
||||||
|
# echo ${{ env.CUSTOM_VAR }} # OK
|
||||||
|
# echo $USE_CUSTOM_VAR # NOT OK, prints ''
|
||||||
|
# echo ${{ env.USE_CUSTOM_VAR }} # NOT OK, prints ''
|
||||||
|
# echo $USE_CUSTOM_VAR_2 # NOT OK, prints '$CUSTOM_VAR'
|
||||||
|
# echo ${{ env.USE_CUSTOM_VAR_2 }} # OK
|
||||||
|
# echo $USE_CUSTOM_VAR_3 # NOT OK, prints '$GLOBAL_WORKFLOW_ENV'
|
||||||
|
# echo ${{ env.USE_CUSTOM_VAR_3 }} # OK
|
||||||
|
# env:
|
||||||
|
# USE_CUSTOM_VAR: ${{ env.CUSTOM_VAR }}
|
||||||
|
# USE_CUSTOM_VAR_2: $CUSTOM_VAR
|
||||||
|
# USE_CUSTOM_VAR_3: $GLOBAL_WORKFLOW_ENV
|
||||||
|
|
||||||
- name: Clean up old test files
|
- name: Clean up old test files
|
||||||
run: |
|
run: |
|
||||||
docker stop ssh-host-container || true && docker rm ssh-host-container || true
|
docker stop ssh-host-container || true && docker rm ssh-host-container || true
|
||||||
@ -37,9 +57,9 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
docker build \
|
docker build \
|
||||||
-t ssh-host-image . \
|
-t ssh-host-image . \
|
||||||
--build-arg ssh_pub_key="$(cat $HOME/.ssh/id_rsa.pub)" \
|
--build-arg SSH_PUB_KEY="$(cat $HOME/.ssh/id_rsa.pub)" \
|
||||||
--build-arg ssh_user="${{ env.TEST_USER }}"
|
--build-arg ssh_user="${{ env.TEST_USER }}"
|
||||||
docker run -d --name=ssh-host-container ssh-host-image
|
docker run -d -p 8822:22 --name=ssh-host-container ssh-host-image
|
||||||
docker exec ssh-host-container sh -c "hostname --ip-address" > ip.txt
|
docker exec ssh-host-container sh -c "hostname --ip-address" > ip.txt
|
||||||
echo "EXAMPLE_REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
echo "EXAMPLE_REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
||||||
cat ip.txt >> $GITHUB_ENV
|
cat ip.txt >> $GITHUB_ENV
|
||||||
@ -54,35 +74,36 @@ jobs:
|
|||||||
date +"%Y-%m-%d %H:%M:%S,%3N" >> index.html
|
date +"%Y-%m-%d %H:%M:%S,%3N" >> index.html
|
||||||
cat index.html
|
cat index.html
|
||||||
|
|
||||||
- name: e2e Test ssh
|
# - name: e2e Test local ssh-deploy action
|
||||||
run: |
|
# run: |
|
||||||
ssh ${{ env.REMOTE_USER }}@${{ env.REMOTE_HOST }}
|
# echo "${{ env.REMOTE_HOST }} -- $EXAMPLE_REMOTE_HOST -- ${{ env.EXAMPLE_REMOTE_HOST }}"
|
||||||
env:
|
# npm ci
|
||||||
REMOTE_HOST: ${{ env.EXAMPLE_REMOTE_HOST }}
|
# npm run build
|
||||||
REMOTE_USER: ${{ env.TEST_USER }}
|
# node ./src/test.js || true
|
||||||
|
# env:
|
||||||
|
# SSH_PRIVATE_KEY: $EXAMPLE_SSH_PRIVATE_KEY
|
||||||
|
# ARGS: "-rltgoDzvO"
|
||||||
|
# SOURCE: "test_project/"
|
||||||
|
# REMOTE_HOST: $EXAMPLE_REMOTE_HOST
|
||||||
|
# REMOTE_USER: ${{ env.TEST_USER }}
|
||||||
|
# TARGET: "/var/www/html/"
|
||||||
|
# EXCLUDE: "/dist/, /node_modules/"
|
||||||
|
|
||||||
- name: e2e Test local ssh-deploy action
|
# - name: e2e Test ssh
|
||||||
run: |
|
# run: |
|
||||||
npm ci
|
# echo "$SSH_REMOTE_USER@$SSH_REMOTE_HOST"
|
||||||
npm run build
|
# ssh -p 8822 $SSH_REMOTE_USER@$SSH_REMOTE_HOST 'exit'
|
||||||
node ./src/index.js || true
|
# env:
|
||||||
env:
|
# SSH_REMOTE_HOST: ${{ env.EXAMPLE_REMOTE_HOST }}
|
||||||
SSH_PRIVATE_KEY: ${{ env.EXAMPLE_SSH_PRIVATE_KEY }}
|
# SSH_REMOTE_USER: ${{ env.TEST_USER }}
|
||||||
ARGS: "-rltgoDzvO"
|
|
||||||
SOURCE: "test_project/"
|
|
||||||
REMOTE_HOST: ${{ env.EXAMPLE_REMOTE_HOST }}
|
|
||||||
REMOTE_USER: ${{ env.TEST_USER }}
|
|
||||||
TARGET: "/var/www/html/"
|
|
||||||
EXCLUDE: "/dist/, /node_modules/"
|
|
||||||
|
|
||||||
- name: e2e Test published ssh-deploy action
|
- name: e2e Test published ssh-deploy action
|
||||||
uses: easingthemes/ssh-deploy@main
|
uses: easingthemes/ssh-deploy@main
|
||||||
env:
|
with:
|
||||||
SSH_PRIVATE_KEY: ${{ env.EXAMPLE_SSH_PRIVATE_KEY }}
|
SSH_PRIVATE_KEY: $EXAMPLE_SSH_PRIVATE_KEY
|
||||||
ARGS: "-rltgoDzvO"
|
ARGS: "-rltgoDzvO"
|
||||||
SOURCE: "test_project/"
|
SOURCE: "test_project/"
|
||||||
REMOTE_HOST: ${{ env.EXAMPLE_REMOTE_HOST }}
|
REMOTE_HOST: $EXAMPLE_REMOTE_HOST
|
||||||
REMOTE_USER: ${{ env.TEST_USER }}
|
REMOTE_USER: ${{ env.TEST_USER }}
|
||||||
TARGET: "/var/www/html/"
|
TARGET: "/var/www/html/"
|
||||||
EXCLUDE: "/dist/, /node_modules/"
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
|
|
||||||
|
2
dist/index.js
vendored
2
dist/index.js
vendored
File diff suppressed because one or more lines are too long
@ -4,6 +4,9 @@ const inputs = {
|
|||||||
GITHUB_WORKSPACE: process.env.GITHUB_WORKSPACE
|
GITHUB_WORKSPACE: process.env.GITHUB_WORKSPACE
|
||||||
};
|
};
|
||||||
// Get inputs from ENV or WITH workflow settings
|
// Get inputs from ENV or WITH workflow settings
|
||||||
|
console.log('EXAMPLE_REMOTE_HOST: ', process.env.EXAMPLE_REMOTE_HOST);
|
||||||
|
console.log('REMOTE_HOST: ', process.env.REMOTE_HOST);
|
||||||
|
|
||||||
inputNames.forEach((input) => {
|
inputNames.forEach((input) => {
|
||||||
inputs[input] = process.env[input] || process.env[`INPUT_${input}`];
|
inputs[input] = process.env[input] || process.env[`INPUT_${input}`];
|
||||||
});
|
});
|
||||||
|
11
src/test.js
11
src/test.js
@ -1,9 +1,2 @@
|
|||||||
const {
|
console.log('EXAMPLE_REMOTE_HOST: ', process.env.EXAMPLE_REMOTE_HOST);
|
||||||
REMOTE_HOST, REMOTE_USER,
|
console.log('REMOTE_HOST: ', process.env.REMOTE_HOST);
|
||||||
REMOTE_PORT, SSH_PRIVATE_KEY, DEPLOY_KEY_NAME,
|
|
||||||
SOURCE, TARGET, ARGS, EXCLUDE,
|
|
||||||
GITHUB_WORKSPACE
|
|
||||||
} = require('./inputs');
|
|
||||||
|
|
||||||
// eslint-disable-next-line max-len
|
|
||||||
console.log(REMOTE_HOST, REMOTE_USER, REMOTE_PORT, SSH_PRIVATE_KEY, DEPLOY_KEY_NAME, SOURCE, TARGET, ARGS, EXCLUDE, GITHUB_WORKSPACE);
|
|
||||||
|
@ -1,15 +1,31 @@
|
|||||||
FROM nginx
|
FROM nginx
|
||||||
# Set args to get from Gtihub Action
|
|
||||||
ARG ssh_pub_key
|
ARG SSH_PUB_KEY
|
||||||
ARG ssh_user
|
|
||||||
# Add a user to the container
|
RUN apt update
|
||||||
RUN adduser --disabled-password $ssh_user
|
|
||||||
# USER $ssh_user
|
RUN apt install openssh-server sudo -y
|
||||||
# Add the ssh public key to the container
|
|
||||||
RUN mkdir -p /home/$ssh_user/.ssh
|
RUN useradd -rm -d /home/test -s /bin/bash -g root -G sudo -u 1000 test
|
||||||
RUN echo "$ssh_pub_key" > /home/$ssh_user/.ssh/authorized_keys
|
|
||||||
RUN chmod 700 /home/$ssh_user/.ssh
|
RUN usermod -aG sudo test
|
||||||
# Start server
|
|
||||||
EXPOSE 80
|
RUN echo "PubkeyAuthentication yes" >> /etc/ssh/sshd_config.d/pub.conf
|
||||||
STOPSIGNAL SIGTERM
|
RUN echo "AuthorizedKeysFile .ssh/authorized_keys" >> /etc/ssh/sshd_config.d/pub.conf
|
||||||
|
|
||||||
|
RUN mkdir -p /home/test/.ssh
|
||||||
|
RUN echo "$SSH_PUB_KEY" > /home/test/.ssh/authorized_keys
|
||||||
|
RUN chmod 700 /home/test/.ssh
|
||||||
|
RUN chown -R test /home/test/.ssh
|
||||||
|
|
||||||
|
RUN service ssh start
|
||||||
|
|
||||||
|
RUN echo 'test:test' | chpasswd
|
||||||
|
|
||||||
|
EXPOSE 22
|
||||||
|
|
||||||
|
ADD entrypoint.sh /docker-entrypoint.d/entrypoint.sh
|
||||||
|
RUN chmod +x /docker-entrypoint.d/entrypoint.sh
|
||||||
|
|
||||||
|
|
||||||
CMD ["nginx", "-g", "daemon off;"]
|
CMD ["nginx", "-g", "daemon off;"]
|
||||||
|
3
test/entrypoint.sh
Normal file
3
test/entrypoint.sh
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
/usr/sbin/sshd -D
|
Loading…
Reference in New Issue
Block a user