Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
73 changes: 73 additions & 0 deletions .github/workflows/python-publish.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
# This workflow will upload a Python Package to PyPI when a release is created
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python#publishing-to-package-registries

# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.

name: Upload Python Package

# on:
# release:
# types: [published]

on:
workflow_dispatch:

permissions:
contents: read

jobs:
release-build:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4

- uses: actions/setup-python@v5
with:
python-version: "3.10"

- name: Build release distributions
run: |
# NOTE: put your own distribution build steps here.
python -m pip install build
python -m build

- name: Upload distributions
uses: actions/upload-artifact@v4
with:
name: release-dists
path: dist/

pypi-publish:
runs-on: ubuntu-latest
needs:
- release-build
permissions:
# IMPORTANT: this permission is mandatory for trusted publishing
id-token: write

# Dedicated environments with protections for publishing are strongly recommended.
# For more information, see: https://docs.github.com/en/actions/deployment/targeting-different-environments/using-environments-for-deployment#deployment-protection-rules
environment:
name: pypi
# OPTIONAL: uncomment and update to include your PyPI project URL in the deployment status:
url: https://pypi.org/p/robotics_application_manager
#
# ALTERNATIVE: if your GitHub Release name is the PyPI project version string
# ALTERNATIVE: exactly, uncomment the following line instead:
# url: https://pypi.org/project/YOURPROJECT/${{ github.event.release.name }}

steps:
- name: Retrieve release distributions
uses: actions/download-artifact@v4
with:
name: release-dists
path: dist/

- name: Publish release distributions to PyPI
uses: pypa/gh-action-pypi-publish@release/v1
with:
packages-dir: dist/
2 changes: 1 addition & 1 deletion robotics_application_manager/libs/process_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ def is_xserver_running(display):
return os.path.exists(x_socket_path)


def wait_for_xserver(display, timeout=30):
def wait_for_xserver(display, timeout=120):
"""
Wait for the X server to start within a specified timeout period.

Expand Down
4 changes: 2 additions & 2 deletions robotics_application_manager/manager/vnc/vnc_server.py
Original file line number Diff line number Diff line change
Expand Up @@ -115,13 +115,13 @@ def start_vnc_gpu(self, display, internal_port, external_port, dri_path):
self.wait_for_port("localhost", internal_port)
self.wait_for_port("localhost", external_port)

def wait_for_port(self, host, port, timeout=20):
def wait_for_port(self, host, port, timeout=120):
"""Wait for a TCP port on a host to become available within a timeout period.

Args:
host (str): Hostname or IP address to check.
port (int): Port number to check.
timeout (int, optional): Maximum time to wait in seconds. Defaults to 20.
timeout (int, optional): Maximum time to wait in seconds. Defaults to 120.

Raises:
TimeoutError: If the port does not become available within the timeout.
Expand Down