name: Test run-name: Building and testing development branch on: push: branches: - development jobs: Build-and-test-development: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - uses: actions/setup-node@v3 with: node-version: 18 - name: Write .npmrc file run: echo "$NPMRC" > client/.npmrc shell: bash env: NPMRC: ${{ secrets.NPMRC}} - run: apt-get update - run: wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb - run: apt install -y ./google-chrome*.deb; - run: export CHROME_BIN=/usr/bin/google-chrome - run: apt-get update -y - run: apt-get -y install libgtk2.0-0 libgtk-3-0 libgbm-dev libnotify-dev libgconf-2-4 libnss3 libxss1 libasound2 libxtst6 xauth xvfb - run: apt -y install jq # - run: 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client -y )' # - run: eval $(ssh-agent -s) # - run: echo "$ssh_key" | tr -d '\r' | ssh-add - - name: Write cypress credentials run: echo "$CYPRESS_CREDS" > ./client/cypress.env.json shell: bash env: CYPRESS_CREDS: ${{ secrets.CYPRESS_CREDS }} # - run: mkdir -p ~/.ssh # - run: chmod 700 ~/.ssh - run: npm ci # Install pm2 and prepare SASJS server - run: npm i -g pm2 - run: curl -L https://github.com/sasjs/server/releases/latest/download/linux.zip > linux.zip - run: unzip linux.zip - run: touch .env - run: echo RUN_TIMES=js >> .env - run: echo NODE_PATH=node >> .env - run: echo CORS=enable >> .env - run: echo WHITELIST=http://localhost:4200 >> .env # - run: echo "SERVER_URL=$server_url" >> .env # - run: echo "SERVER_TYPE=$server_type" >> .env # - run: echo "CLIENT=$client_sasjs" >> .env # - run: echo "ACCESS_TOKEN=$access_token_sasjs" >> .env # - run: echo "REFRESH_TOKEN=$refresh_token_sasjs" >> .env # - run: cat .env - run: pm2 start api-linux --wait-ready - name: Deploy mocked services run: | cd ./sas/mocks/sasjs npm install -g @sasjs/cli npm install -g replace-in-files-cli sasjs cbd -t server-ci # sasjs request services/admin/makedata -t server-ci -d ./deploy/makeData4GL.json -c ./deploy/requestConfig.json -o ./output.json - name: Prepare frontend run: | cd ./client # mv ./cypress.env.example.json ./cypress.env.json # replace-in-files --regex='"username".*' --replacement='"username":"'$cypress_username_sasjs'",' ./cypress.env.json # replace-in-files --regex='"password".*' --replacement='"password":"'$cypress_pwd_sasjs'" ' ./cypress.env.json cat ./cypress.env.json npm run postinstall # Prepare index.html to SASJS local replace-in-files --regex='serverUrl=".*?"' --replacement='serverUrl="http://localhost:5000"' ./src/index.html replace-in-files --regex='appLoc=".*?"' --replacement='appLoc="/Public/app/devtest"' ./src/index.html replace-in-files --regex='serverType=".*?"' --replacement='serverType="SASJS"' ./src/index.html # Prepare and deploy SASJS version # replace-in-files --regex='serverurl=".*?"' --replacement='serverUrl="http://localhost:5000"' ./dist/index.html # replace-in-files --regex='apploc=".*?"' --replacement='appLoc="/30.SASApps/app/devtest"' ./dist/index.html # replace-in-files --regex='servertype=".*?"' --replacement='serverType="SASJS"' ./dist/index.html # scp -o stricthostkeychecking=no -r ./dist/* dcgitlab@sas.4gl.io:/var/www/html/dcviya/development/newadapter replace-in-files --regex='"hosturl".*' --replacement='hosturl:"http://localhost:4200",' ./cypress.config.ts # replace-in-files --regex='"appLocation".*' --replacement='appLocation:"/dcviya/development/newadapter",' ./cypress.config.ts cat ./cypress.config.ts # Start frontend and run cypress npm start & npx wait-on http://localhost:4200 && ./run-cypress-tests.sh Build-and-test-development-latest-adapter: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - uses: actions/setup-node@v3 with: node-version: 18 - name: Write .npmrc file run: echo "$NPMRC" > client/.npmrc shell: bash env: NPMRC: ${{ secrets.NPMRC}} - run: apt-get update - run: wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb - run: apt install -y ./google-chrome*.deb; - run: export CHROME_BIN=/usr/bin/google-chrome - run: apt-get update -y - run: apt-get -y install libgtk2.0-0 libgtk-3-0 libgbm-dev libnotify-dev libgconf-2-4 libnss3 libxss1 libasound2 libxtst6 xauth xvfb - run: apt -y install jq # - run: 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client -y )' # - run: eval $(ssh-agent -s) # - run: echo "$ssh_key" | tr -d '\r' | ssh-add - - name: Write cypress credentials run: echo "$CYPRESS_CREDS" > ./client/cypress.env.json shell: bash env: CYPRESS_CREDS: ${{ secrets.CYPRESS_CREDS }} # - run: mkdir -p ~/.ssh # - run: chmod 700 ~/.ssh - run: npm ci # Install pm2 and prepare SASJS server - run: npm i -g pm2 - run: curl -L https://github.com/sasjs/server/releases/latest/download/linux.zip > linux.zip - run: unzip linux.zip - run: touch .env - run: echo RUN_TIMES=js >> .env - run: echo NODE_PATH=node >> .env - run: echo CORS=enable >> .env - run: echo WHITELIST=http://localhost:4200 >> .env # - run: echo "SERVER_URL=$server_url" >> .env # - run: echo "SERVER_TYPE=$server_type" >> .env # - run: echo "CLIENT=$client_sasjs" >> .env # - run: echo "ACCESS_TOKEN=$access_token_sasjs" >> .env # - run: echo "REFRESH_TOKEN=$refresh_token_sasjs" >> .env # - run: cat .env - run: pm2 start api-linux --wait-ready - name: Deploy mocked services run: | cd ./sas/mocks/sasjs npm install -g @sasjs/cli npm install -g replace-in-files-cli sasjs cbd -t server-ci # sasjs request services/admin/makedata -t server-ci -d ./deploy/makeData4GL.json -c ./deploy/requestConfig.json -o ./output.json - name: Prepare frontend run: | cd ./client # mv ./cypress.env.example.json ./cypress.env.json # replace-in-files --regex='"username".*' --replacement='"username":"'$cypress_username_sasjs'",' ./cypress.env.json # replace-in-files --regex='"password".*' --replacement='"password":"'$cypress_pwd_sasjs'" ' ./cypress.env.json cat ./cypress.env.json npm run postinstall npm install @sasjs/adapter@latest # Prepare index.html to SASJS local replace-in-files --regex='serverUrl=".*?"' --replacement='serverUrl="http://localhost:5000"' ./src/index.html replace-in-files --regex='appLoc=".*?"' --replacement='appLoc="/Public/app/devtest"' ./src/index.html replace-in-files --regex='serverType=".*?"' --replacement='serverType="SASJS"' ./src/index.html # Prepare and deploy SASJS version # replace-in-files --regex='serverurl=".*?"' --replacement='serverUrl="http://localhost:5000"' ./dist/index.html # replace-in-files --regex='apploc=".*?"' --replacement='appLoc="/30.SASApps/app/devtest"' ./dist/index.html # replace-in-files --regex='servertype=".*?"' --replacement='serverType="SASJS"' ./dist/index.html # scp -o stricthostkeychecking=no -r ./dist/* dcgitlab@sas.4gl.io:/var/www/html/dcviya/development/newadapter replace-in-files --regex='"hosturl".*' --replacement='hosturl:"http://localhost:4200",' ./cypress.config.ts # replace-in-files --regex='"appLocation".*' --replacement='appLocation:"/dcviya/development/newadapter",' ./cypress.config.ts cat ./cypress.config.ts # Start frontend and run cypress npm start & npx wait-on http://localhost:4200 && ./run-cypress-tests.sh