name: Capsule tests on: push: branches: - master - develop pull_request: types: - opened - reopened - synchronize - ready_for_review jobs: pr: name: Run capsule tests - PR runs-on: ubuntu-latest if: ${{ github.event_name == 'pull_request' && github.event.pull_request.draft == false }} env: GO111MODULE: 'on' steps: ####### ## Setup langs ####### - name: Set up Go uses: actions/setup-go@v3 id: go with: go-version: 1.19 - name: Set up Node 16 uses: actions/setup-node@v2 id: npm with: node-version: 16 ####### ## Checkout capsule ####### # Checkout front ends - name: Checkout frontend mono repo uses: actions/checkout@v2 with: ref: ${{ github.event.pull_request.head.ref }} fetch-depth: 0 path: './frontend-monorepo' # Checkout capsule to build local network - name: Checkout capsule uses: actions/checkout@v2 with: repository: vegaprotocol/vegacapsule ref: main token: ${{ secrets.VEGA_CI_BOT_GITHUB_TOKEN }} path: './capsule' ####### ## Build binaries ####### - name: Build capsule run: go install working-directory: capsule - name: Set GOBIN run: echo GOBIN=$(go env GOPATH)/bin >> $GITHUB_ENV - name: Checkout Vega uses: actions/checkout@v2 with: repository: vegaprotocol/vega ref: v0.54.0 token: ${{ secrets.VEGA_CI_BOT_GITHUB_TOKEN }} path: './vega' - name: Install Vega binaries run: go install -v ./cmd/vega working-directory: vega - name: Install Vega wallet binaries run: go install ./cmd/vegawallet working-directory: vega - name: Install date-node binaries run: go install ./cmd/data-node working-directory: vega ###### ## Start capsule ###### - name: Login to docker run: echo -n ${{ secrets.VEGA_CI_BOT_GITHUB_TOKEN }} | docker login https://ghcr.io -u vega-ci-bot --password-stdin - name: Start nomad run: vegacapsule nomad & - name: Bootstrap network run: vegacapsule network bootstrap --config-path=../frontend-monorepo/vegacapsule/config.hcl --force working-directory: capsule ###### ## Setup a Vega wallet for our user ###### - name: Create passphrase run: echo "${{ secrets.CYPRESS_TRADING_TEST_VEGA_WALLET_PASSPHRASE }}" > ./passphrase - name: Create recovery run: echo "${{ secrets.TRADING_TEST_VEGA_WALLET_RECOVERY }}" > ./recovery - name: Initialize wallet run: vegawallet init -f --home ~/.vegacapsule/testnet/wallet - name: Import wallet run: vegawallet import -w UI_Trading_Test --recovery-phrase-file ./recovery -p ./passphrase --home ~/.vegacapsule/testnet/wallet - name: Create public key 2 run: vegawallet key generate -w UI_Trading_Test -p ./passphrase --home ~/.vegacapsule/testnet/wallet - name: Start service run: vegawallet service run --network DV --automatic-consent --home ~/.vegacapsule/testnet/wallet & ###### ## Run some tests ###### - name: Derive appropriate SHAs for base and head for `nx affected` commands uses: nrwl/nx-set-shas@v2 with: working-directory: frontend-monorepo main-branch-name: master - name: Install root dependencies run: yarn install working-directory: frontend-monorepo - name: Run Cypress tests run: npx nx affected:e2e --record --key ${{ secrets.CYPRESS_RECORD_KEY }} working-directory: frontend-monorepo env: CYPRESS_TRADING_TEST_VEGA_WALLET_PASSPHRASE: ${{ secrets.CYPRESS_TRADING_TEST_VEGA_WALLET_PASSPHRASE }} CYPRESS_SLACK_WEBHOOK: ${{ secrets.CYPRESS_SLACK_WEBHOOK }} CYPRESS_ETH_WALLET_MNEMONIC: ${{ secrets.CYPESS_ETH_WALLET_MNEMONIC }} CYPRESS_INCLUDE_FLOWS: false CYPRESS_TEARDOWN_NETWORK_AFTER_FLOWS: true ###### ## Upload logs ###### - name: Logs if: ${{ always() }} run: vegacapsule network logs > vega-capsule-logs.txt - uses: actions/upload-artifact@v2 if: ${{ always() }} with: name: logs path: ./vega-capsule-logs.txt