From bef7e2d1c457d52f3347fece5d3803967a983163 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dominic=20L=C3=A9tourneau?= Date: Wed, 29 May 2024 15:22:57 -0400 Subject: [PATCH] Upload web (#141) * Add the web client package to the release * Add Python signaling server wheel/sdist to release * Fix missing target * Update some versions of actions used * Make it official release * Update aiohttp from 3.9.0 to 3.9.4 --------- Co-authored-by: philippewarren --- .github/workflows/cpp-python-tests.yml | 12 +++--- .github/workflows/gen-doc-and-release.yml | 50 +++++++++++++++++++---- VERSION | 2 +- signaling-server/CMakeLists.txt | 1 + signaling-server/requirements.txt | 2 +- signaling-server/setup.py.in | 11 +++-- 6 files changed, 59 insertions(+), 19 deletions(-) diff --git a/.github/workflows/cpp-python-tests.yml b/.github/workflows/cpp-python-tests.yml index 2c421407..f60445fd 100644 --- a/.github/workflows/cpp-python-tests.yml +++ b/.github/workflows/cpp-python-tests.yml @@ -32,12 +32,12 @@ jobs: enable-gstreamer: ON steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 with: submodules: recursive - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v3 + uses: actions/setup-python@v5 with: python-version: ${{ matrix.python-version }} @@ -106,10 +106,10 @@ jobs: sudo apt-get install ninja-build cmake build-essential libssl-dev libboost-all-dev sudo apt-get install libglib2.0-dev libgtk-3-dev libpulse-dev libasound2-dev tree perl sudo apt install libunwind-dev - sudo apt-get install libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev libgstreamer-plugins-bad1.0-dev - sudo apt-get install gstreamer1.0-plugins-base gstreamer1.0-plugins-good gstreamer1.0-plugins-bad - sudo apt-get install gstreamer1.0-plugins-ugly gstreamer1.0-libav gstreamer1.0-tools - sudo apt-get install gstreamer1.0-x gstreamer1.0-alsa gstreamer1.0-gl gstreamer1.0-gtk3 gstreamer1.0-qt5 + sudo apt-get install libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev libgstreamer-plugins-bad1.0-dev + sudo apt-get install gstreamer1.0-plugins-base gstreamer1.0-plugins-good gstreamer1.0-plugins-bad + sudo apt-get install gstreamer1.0-plugins-ugly gstreamer1.0-libav gstreamer1.0-tools + sudo apt-get install gstreamer1.0-x gstreamer1.0-alsa gstreamer1.0-gl gstreamer1.0-gtk3 gstreamer1.0-qt5 sudo apt-get install gstreamer1.0-pulseaudio if: runner.os == 'Linux' diff --git a/.github/workflows/gen-doc-and-release.yml b/.github/workflows/gen-doc-and-release.yml index 8e0cf007..6881c79c 100644 --- a/.github/workflows/gen-doc-and-release.yml +++ b/.github/workflows/gen-doc-and-release.yml @@ -6,12 +6,11 @@ on: workflow_dispatch: branches: [main] - jobs: build-gen-doc-and-release: runs-on: ubuntu-22.04 steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 with: submodules: recursive @@ -42,7 +41,6 @@ jobs: python -m pip install --user --upgrade numpy python -m pip install --user -r signaling-server/requirements.txt - - name: Generate C++ Documentation working-directory: doc/cpp run: | @@ -66,7 +64,8 @@ jobs: -DOPENTERA_WEBRTC_NATIVE_CLIENT_PYTHON_PIP_INSTALL_PREFIX='--user' \ -DOPENTERA_WEBRTC_NATIVE_CLIENT_PYTHON_VERSION="$(python3 --version | perl -pe 's/Python //')" \ -DOPENTERA_WEBRTC_USE_SYSTEM_OPENCV=ON - make -j2 native_client-html-target + cmake --build . --target native_client-html-target + cmake --build . --target signaling_server-dist-target - name: Copy Python Documentation to Doc Folder run: | @@ -74,7 +73,7 @@ jobs: cp -r build/opentera-webrtc-native-client/OpenteraWebrtcNativeClient/python/package/opentera_webrtc_native_client/_build/* doc/python - name: Deploy to GitHub Pages - uses: JamesIves/github-pages-deploy-action@3.7.1 + uses: JamesIves/github-pages-deploy-action@v4 with: github_token: ${{ secrets.GITHUB_TOKEN }} branch: gh-pages @@ -87,9 +86,46 @@ jobs: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # This token is provided by Actions, you do not need to create your own token with: tag_name: v${{ steps.generate_version_output.outputs.version }} - release_name: opentera-webrtc-native-client-${{ steps.generate_version_output.outputs.version }} + release_name: opentera-webrtc-${{ steps.generate_version_output.outputs.version }} body: | - Latest build of opentera-webrtc-native-client v${{ steps.generate_version_output.outputs.version }} + Latest build of opentera-webrtc v${{ steps.generate_version_output.outputs.version }} - Please see API documentation at https://introlab.github.io/opentera-webrtc draft: false prerelease: false + + - name: Create opentera-webrtc-web-client package archive + working-directory: opentera-webrtc-web-client + run: tar -czvf opentera-webrtc-web-client-${{ steps.generate_version_output.outputs.version }}.tar.gz package.json index.js webpack.config.js README.md src + + - name: Upload opentera-webrtc-web-client NPM package + id: upload-release-npm-asset + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: ./opentera-webrtc-web-client/opentera-webrtc-web-client-${{ steps.generate_version_output.outputs.version }}.tar.gz + asset_name: opentera-webrtc-web-client-${{ steps.generate_version_output.outputs.version }}.tar.gz + asset_content_type: application/gzip + + - name: Upload opentera-webrtc-signaling-server Python wheel + id: upload-release-wheel-asset + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: build/signaling-server/opentera_webrtc_signaling_server/dist/opentera_webrtc_signaling_server-${{ steps.generate_version_output.outputs.version }}-py3-none-any.whl + asset_name: opentera-webrtc-signaling-server-${{ steps.generate_version_output.outputs.version }}-py3-none-any.whl + asset_content_type: application/zip + + - name: Upload opentera-webrtc-signaling-server Python sdist + id: upload-release-pysdist-asset + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: build/signaling-server/opentera_webrtc_signaling_server/dist/opentera_webrtc_signaling_server-${{ steps.generate_version_output.outputs.version }}.tar.gz + asset_name: opentera-webrtc-signaling-server-${{ steps.generate_version_output.outputs.version }}.tar.gz + asset_content_type: application/gzip diff --git a/VERSION b/VERSION index 781dcb07..65087b4f 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -1.1.3 +1.1.4 diff --git a/signaling-server/CMakeLists.txt b/signaling-server/CMakeLists.txt index 694344b9..ff41930f 100644 --- a/signaling-server/CMakeLists.txt +++ b/signaling-server/CMakeLists.txt @@ -35,6 +35,7 @@ set(SOURCE opentera-signaling-server README.md + requirements.txt ) # Same relative tree between CMAKE_CURRENT_SOURCE_DIR and PYTHON_PACKAGE_DIR for files in SOURCE will work as expected with this command pip_configure_package_file_hierarchy(${SOURCE}) diff --git a/signaling-server/requirements.txt b/signaling-server/requirements.txt index 0bd8cb64..8421aae1 100644 --- a/signaling-server/requirements.txt +++ b/signaling-server/requirements.txt @@ -1,2 +1,2 @@ -aiohttp==3.9.0 +aiohttp==3.9.4 aiohttp_index==0.1 diff --git a/signaling-server/setup.py.in b/signaling-server/setup.py.in index 2283b948..51b232ee 100644 --- a/signaling-server/setup.py.in +++ b/signaling-server/setup.py.in @@ -17,7 +17,10 @@ def get_doc_files(): return list(files.items()) -long_description = read_file("README.md") +LONG_DESCRIPTION = read_file("README.md") +REQUIREMENTS = read_file("requirements.txt").splitlines() +DATA_FILES = [('', ["requirements.txt"])] +$,DATA_FILES.extend(get_doc_files()),> setup( name="opentera_webrtc_signaling_server", @@ -25,7 +28,7 @@ setup( author="Marc-Antoine Maheux, Cedric Godin, Dominic Letourneau", author_email="marc-antoine.maheux@usherbrooke.ca, cedric.godin@usherbrooke.ca, dominic.letourneau@usherbrooke.ca", description="OpenTera WebRTC Signaling Server", - long_description=long_description, + long_description=LONG_DESCRIPTION, long_description_content_type="text/markdown", url="https://github.com/introlab/opentera-webrtc", packages=['opentera_webrtc.signaling_server'], @@ -38,9 +41,9 @@ setup( license="Apache Software License", platforms=['linux_x86_64'], python_requires='>=3.8', - $,data_files=get_doc_files()$,> + data_files=DATA_FILES, include_package_data=True, zip_safe=False, - install_requires=["python-socketio", "aiohttp", "aiohttp_index"], + install_requires=REQUIREMENTS, scripts=['opentera-signaling-server'], )