From ff6360f5927be75e5bdde341abfb3033bceef0e1 Mon Sep 17 00:00:00 2001 From: Iakov Kirilenko Date: Thu, 9 Feb 2023 16:03:30 +0300 Subject: [PATCH] Use script instead of sshpass on Windows --- .github/workflows/main.yml | 24 +++++++++++++++--------- appveyor.yml | 2 +- 2 files changed, 16 insertions(+), 10 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 68c9d3ba1a..53937b2de4 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -69,14 +69,7 @@ jobs: run: | ARCH=32 PLATFORM=i686 - pacman --verbose --noconfirm -S msys/zlib-devel dos2unix ccache rsync unzip sshpass mingw$ARCH/mingw-w64-$PLATFORM-libzip mingw$ARCH/mingw-w64-$PLATFORM-libusb mingw$ARCH/mingw-w64-$PLATFORM-zlib mingw$ARCH/mingw-w64-$PLATFORM-pkg-config - -# https://github.com/msys2/MSYS2-packages/issues/2485 - sshpass failed with strange error - - name: Get older sshpass - run: | - wget http://repo.msys2.org/msys/x86_64/sshpass-1.06-1-x86_64.pkg.tar.xz - pacman --verbose --noconfirm -U ./sshpass-1.06-1-x86_64.pkg.tar.xz - rm ./sshpass-1.06-1-x86_64.pkg.tar.xz + pacman --verbose --noconfirm -S msys/zlib-devel dos2unix ccache rsync unzip mingw$ARCH/mingw-w64-$PLATFORM-libzip mingw$ARCH/mingw-w64-$PLATFORM-libusb mingw$ARCH/mingw-w64-$PLATFORM-zlib mingw$ARCH/mingw-w64-$PLATFORM-pkg-config - name: Inject slug/short variables uses: rlespinasse/github-slug-action@v3.x @@ -150,6 +143,15 @@ jobs: which g++ g++ --version + - name: Deploy installer + if: ${{ matrix.deploy-installer && github.event_name != 'pull_request' && github.repository_owner == 'trikset' }} + run: | + set -x + INSTALLER_PATH=$(ls -1b installer/*.sh | head -n 1) + [ -r "$INSTALLER_PATH" ] || INSTALLER_PATH=/dev/null + export INSTALLER_PATH + { sleep 5 ; echo "${{ secrets.DL_PASSWORD }}" ; } | timeout -k 10s 30s script -E never -q -c "rsync -ve 'ssh -vvt -o StrictHostKeyChecking=no' $INSTALLER_PATH ${{ secrets.DL_USERNAME }}@${{ secrets.DL_HOST }}:~/dl/ts/fresh/installer/trik-studio-${{ env.GITHUB_REF_SLUG }}-i686-installer.exe" + - name: QMake timeout-minutes: 1 run: | @@ -230,7 +232,11 @@ jobs: - name: Deploy installer if: ${{ matrix.deploy-installer && github.event_name != 'pull_request' && github.repository_owner == 'trikset' }} - run: sshpass -p ${{ secrets.DL_PASSWORD }} rsync -ve "ssh -o StrictHostKeyChecking=no" installer/trik-studio*installer*.exe ${{ secrets.DL_USERNAME }}@${{ secrets.DL_HOST }}:~/dl/ts/fresh/installer/trik-studio-${{ env.GITHUB_REF_SLUG }}-i686-installer.exe + run: | + INSTALLER_PATH=$(ls -1b installer/trik-studio*installer*.exe | head -n 1) + [ -r "$INSTALLER_PATH" ] || INSTALLER_PATH=/dev/null + export INSTALLER_PATH + echo "${{ secrets.DL_PASSWORD }}"| script -E never -q -c "rsync -ve 'ssh -o StrictHostKeyChecking=no' $INSTALLER_PATH ${{ secrets.DL_USERNAME }}@${{ secrets.DL_HOST }}:~/dl/ts/fresh/installer/trik-studio-${{ env.GITHUB_REF_SLUG }}-i686-installer.exe" - name: Prepare for RDP connection if: false #comment this line to create RDP session diff --git a/appveyor.yml b/appveyor.yml index 2b525be4ba..a6ba3ca876 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -232,7 +232,7 @@ after_test: - bash -c "env LC_ALL=C date -u" # deployment #- ps: if ( $artifacts.Count -eq 0 ) { exit 1 } - - IF "x%server%" NEQ "x" (sshpass -p %password% rsync -avze 'ssh -o StrictHostKeyChecking=no' %INSTALLER_NAME% %server%:dl/ts/fresh/installer/) + - IF "x%server%" NEQ "x" ( echo %password%| script -E never -q -c "rsync -avze 'ssh -o StrictHostKeyChecking=no' %INSTALLER_NAME% %server%:dl/ts/fresh/installer/") before_deploy: - ps: if ( $artifacts.Count -eq 0 ) { exit 1 }