From f2ce72c2bfcca615d86827d9a8d33c01a9838b7b Mon Sep 17 00:00:00 2001 From: Delyan Angelov Date: Sun, 21 Feb 2021 16:32:02 +0200 Subject: [PATCH] ci: split the websockets tests into their own CI .yml file --- .github/workflows/ci.yml | 55 -------------------- .github/workflows/websockets.yml | 85 +++++++++++++++++++++++++++++++ vlib/x/websocket/websocket_test.v | 8 +++ 3 files changed, 93 insertions(+), 55 deletions(-) create mode 100644 .github/workflows/websockets.yml diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index ea9f6b27cf..f069715086 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -858,61 +858,6 @@ jobs: ../v -autofree . cd .. - websocket_autobahn: - name: Autobahn integrations tests - runs-on: ubuntu-20.04 - timeout-minutes: 30 - steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: Run autobahn services - run: docker-compose -f ${{github.workspace}}/vlib/x/websocket/tests/autobahn/docker-compose.yml up -d - - name: Build client test - run: docker exec autobahn_client "/src/v" "/src/vlib/x/websocket/tests/autobahn/autobahn_client.v" - - name: Run client test - run: docker exec autobahn_client "/src/vlib/x/websocket/tests/autobahn/autobahn_client" - - name: Build client wss test - run: docker exec autobahn_client "/src/v" "/src/vlib/x/websocket/tests/autobahn/autobahn_client_wss.v" - - name: Run client wss test - run: docker exec autobahn_client "/src/vlib/x/websocket/tests/autobahn/autobahn_client_wss" - - name: Run server test - run: docker exec autobahn_server "wstest" "-m" "fuzzingclient" "-s" "/config/fuzzingclient.json" - - name: Copy reports - run: docker cp autobahn_server:/reports ${{github.workspace}}/reports - - name: Copy reports wss - run: docker cp autobahn_server_wss:/reports ${{github.workspace}}/reports_wss - - name: Test success - run: docker exec autobahn_server "python" "/check_results.py" - - name: Test success WSS - run: docker exec autobahn_server_wss "python" "/check_results.py" - - - name: Publish all reports - uses: actions/upload-artifact@v2 - with: - name: full report - path: ${{github.workspace}}/reports - - name: Publish report client - uses: actions/upload-artifact@v2 - with: - name: client - path: ${{github.workspace}}/reports/clients/index.html - - name: Publish report server - uses: actions/upload-artifact@v2 - with: - name: server - path: ${{github.workspace}}/reports/servers/index.html - - name: Publish all reports WSS - uses: actions/upload-artifact@v2 - with: - name: full report wss - path: ${{github.workspace}}/reports_wss - - name: Publish report client wss - uses: actions/upload-artifact@v2 - with: - name: client wss - path: ${{github.workspace}}/reports_wss/clients/index.html - parser-silent: name: Parser silent mode runs-on: ubuntu-20.04 diff --git a/.github/workflows/websockets.yml b/.github/workflows/websockets.yml new file mode 100644 index 0000000000..0028df5043 --- /dev/null +++ b/.github/workflows/websockets.yml @@ -0,0 +1,85 @@ +name: Websockets CI + +on: + push: + paths-ignore: + - "**.md" + pull_request: + paths-ignore: + - "**.md" + + websocket_tests: + runs-on: ubuntu-20.04 + timeout-minutes: 30 + env: + VFLAGS: -cc tcc -no-retry-compilation + steps: + - uses: actions/checkout@v2 + - name: Install dependencies + run: sudo apt-get install --quiet -y libssl-dev + - name: Build v + run: | + echo $VFLAGS + sudo ln -s $PWD/thirdparty/tcc/tcc.exe /usr/local/bin/tcc ## TODO: remove + make -j4 + ./v -cg -cflags -Werror -o v cmd/v + - name: v doctor + run: ./v doctor + - name: Run websockets tests + run: ./v -cflags "-Werror" test vlib/x/websocket/ + + websocket_autobahn_tests: + name: Autobahn integrations tests + runs-on: ubuntu-20.04 + timeout-minutes: 20 + steps: + - name: Checkout + uses: actions/checkout@v2 + + - name: Run autobahn services + run: docker-compose -f ${{github.workspace}}/vlib/x/websocket/tests/autobahn/docker-compose.yml up -d + - name: Build client test + run: docker exec autobahn_client "/src/v" "/src/vlib/x/websocket/tests/autobahn/autobahn_client.v" + - name: Run client test + run: docker exec autobahn_client "/src/vlib/x/websocket/tests/autobahn/autobahn_client" + - name: Build client wss test + run: docker exec autobahn_client "/src/v" "/src/vlib/x/websocket/tests/autobahn/autobahn_client_wss.v" + - name: Run client wss test + run: docker exec autobahn_client "/src/vlib/x/websocket/tests/autobahn/autobahn_client_wss" + - name: Run server test + run: docker exec autobahn_server "wstest" "-m" "fuzzingclient" "-s" "/config/fuzzingclient.json" + - name: Copy reports + run: docker cp autobahn_server:/reports ${{github.workspace}}/reports + - name: Copy reports wss + run: docker cp autobahn_server_wss:/reports ${{github.workspace}}/reports_wss + - name: Test success + run: docker exec autobahn_server "python" "/check_results.py" + - name: Test success WSS + run: docker exec autobahn_server_wss "python" "/check_results.py" + + - name: Publish all reports + uses: actions/upload-artifact@v2 + with: + name: full report + path: ${{github.workspace}}/reports + - name: Publish report client + uses: actions/upload-artifact@v2 + with: + name: client + path: ${{github.workspace}}/reports/clients/index.html + - name: Publish report server + uses: actions/upload-artifact@v2 + with: + name: server + path: ${{github.workspace}}/reports/servers/index.html + - name: Publish all reports WSS + uses: actions/upload-artifact@v2 + with: + name: full report wss + path: ${{github.workspace}}/reports_wss + - name: Publish report client wss + uses: actions/upload-artifact@v2 + with: + name: client wss + path: ${{github.workspace}}/reports_wss/clients/index.html + diff --git a/vlib/x/websocket/websocket_test.v b/vlib/x/websocket/websocket_test.v index c0d6cef05e..926ebfa814 100644 --- a/vlib/x/websocket/websocket_test.v +++ b/vlib/x/websocket/websocket_test.v @@ -1,3 +1,4 @@ +import os import x.websocket import time import rand @@ -8,8 +9,15 @@ pub mut: nr_pong_received int } +const github_job = os.getenv('GITHUB_JOB') + // tests with internal ws servers fn test_ws() { + if github_job != '' && github_job != 'websocket_tests' { + // Do not run these tests everytime, since they are flaky. + // They have their own specialized CI runner. + return + } port := 30000 + rand.intn(1024) go start_server(port) time.sleep_ms(500)