Skip to content

Starting to realise chatgpt has no idea. #99

Starting to realise chatgpt has no idea.

Starting to realise chatgpt has no idea. #99

name: WebRTC Data Channel Interoperability Test
on:
push:
branches:
- master
pull_request:
branches:
- master
repository_dispatch:
types: [datachannel-test-command]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
# Job Description: Performs the Data Channel Test between each combination of the client and server for each library.
interop-tests:
runs-on: ubuntu-latest
strategy:
matrix:
server: ["libdatachannel", "sipsorcery", "werift"]
client: ["libdatachannel", "sipsorcery", "werift"]
services:
echo-test-server:
image: ghcr.io/sipsorcery/${{ matrix.server }}-webrtc-echo
credentials:
username: ${{ github.actor }}
password: ${{ secrets.CR_PAT }}
#ports:
# - 8080:8080
options: "--name echo-server"
outputs:
results: ${{ steps.collect_results.outputs.results }}
steps:
- name: Set up result file
run: echo "" > results.txt # Create or empty the results file
- name: Data Channel test for server ${{ matrix.server }} and ${{ matrix.client }} client
id: check_connection
run: |
docker run --entrypoint "/client.sh" --network ${{ job.container.network }} ghcr.io/sipsorcery/${{ matrix.client }}-webrtc-echo "-s http://echo-server:8080/offer -t 1"
result=$?
echo "Check connection for ${{ matrix.server }} server and ${{ matrix.client }} client result $result."
echo "::set-output name=TEST_RESULT::$result"
continue-on-error: true
- name: Record result
run: |
echo "Result for ${{ matrix.server }} server and ${{ matrix.client }} client, outcome ${{ steps.check_connection.outcome }}, result ${{ steps.check_connection.outputs.TEST_RESULT }}."
echo "RESULTS+=['${{ matrix.server }}','${{ matrix.client }}','${{ steps.check_connection.outputs.TEST_RESULT }}']" >> $GITHUB_ENV
- name: Set output results
id: collect_results
run: |
echo "results=${{ env.RESULTS }}"
echo "results=${{ env.RESULTS }}" >> $GITHUB_ENV
# Job Description: Collates the results of the interop tests into a mark down table.
collate:
runs-on: ubuntu-latest
needs: [interop-tests]
steps:
- uses: actions/checkout@v2
with:
ref: testresults
- name: Create results file from results.txt
run: |
echo "Collating results from:"
echo "${{ needs.interop-tests.outputs.results }}"
echo "| Server | Client | Test Result |" > DataChannel_Echo_test_results.md
echo "|--------|--------|-------------|" >> DataChannel_Echo_test_results.md
# Read results from the job output
IFS=' ' read -r -a results_array <<< "${{ needs.interop-tests.outputs.results }}"
for result in "${results_array[@]}"; do
echo "| ${result[0]} | ${result[1]} | ${result[2]} |" >> DataChannel_Echo_test_results.md
done
cat DataChannel_Echo_test_results.md
- name: Commit the results to the git repository
if: github.event_name != 'pull_request'
run: |
git config user.name github-actions
git config user.email [email protected]
git pull
#git add DataChannel_Echo_test_results.md DataChannel_Echo_test_results.png
#git commit DataChannel_Echo_test_results.md DataChannel_Echo_test_results.png -m "Automated data channel echo test results."
#git add DataChannel_Echo_test_results.md
git commit DataChannel_Echo_test_results.md -m "Automated data channel echo test results."
git push