Skip to content

Add react-based frontend #19

Add react-based frontend

Add react-based frontend #19

Workflow file for this run

name: Build
on:
push:
branches: master
pull_request:
branches: "*"
jobs:
build:
name: Build tljh_repo2docker
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Install Conda environment with Micromamba
uses: mamba-org/setup-micromamba@v1
with:
environment-name: tljh
micromamba-version: "1.5.5-0"
create-args: >-
python=3.10
nodejs=18
yarn=3
- name: Setup pip cache
uses: actions/cache@v2
with:
path: ~/.cache/pip
key: pip-3.10-${{ hashFiles('setup.py') }}
restore-keys: |
pip-3.10-
pip-
- name: Get yarn cache directory path
id: yarn-cache-dir-path
run: echo "::set-output name=dir::$(yarn cache dir)"
- name: Setup yarn cache
uses: actions/cache@v2
id: yarn-cache
with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: yarn-${{ hashFiles('frontend/yarn.lock') }}
restore-keys: |
yarn-
- name: Package the application
shell: bash -l {0}
run: |
set -eux
pip install git+https://github.com/jupyterhub/the-littlest-jupyterhub build
python -m build .
- name: Upload package
uses: actions/upload-artifact@v3
with:
name: tljh_repo2docker-artifacts
path: |
dist/tljh_repo2docker*.whl
if-no-files-found: error
test_isolated:
needs: build
runs-on: ubuntu-latest
steps:
- name: Install Python
uses: actions/setup-python@v4
with:
python-version: "3.10"
architecture: "x64"
- uses: actions/download-artifact@v3
with:
name: tljh_repo2docker-artifacts
- name: Install and Test
run: |
set -eux
# Remove NodeJS, twice to take care of system and locally installed node versions.
sudo rm -rf $(which node)
sudo rm -rf $(which node)
python -m pip install tljh_repo2docker*.whl
- name: Test import
shell: bash -l {0}
run: python -c "import tljh_repo2docker"
integration-tests:
name: Integration tests
needs: build
runs-on: ubuntu-latest
env:
PLAYWRIGHT_BROWSERS_PATH: ${{ github.workspace }}/pw-browsers
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Install Conda environment with Micromamba
uses: mamba-org/setup-micromamba@v1
with:
micromamba-version: "1.5.5-0"
environment-name: tljh
create-args: >-
python=3.10
nodejs=18
yarn=3
- name: Download app package
uses: actions/download-artifact@v3
with:
name: tljh_repo2docker-artifacts
- name: Install package
run: |
set -eux
# Remove NodeJS, twice to take care of system and locally installed node versions.
python -m pip install -r dev-requirements.txt
python -m pip install tljh_repo2docker*.whl
npm -g install configurable-http-proxy
- name: Install UI test dependencies
shell: bash -l {0}
working-directory: frontend/ui-tests
env:
PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: 1
run: yarn install
- name: Set up browser cache
uses: actions/cache@v3
with:
path: |
${{ github.workspace }}/pw-browsers
key: ${{ runner.os }}-${{ hashFiles('frontend/ui-tests/yarn.lock') }}
- name: Install browser
shell: bash -l {0}
run: npx playwright install chromium
working-directory: frontend/ui-tests
- name: Start JupyterHub
shell: bash -l {0}
run: |
python -m jupyterhub -f ./jupyterhub_config.py --debug
- name: Wait for JupyterHub
uses: ifaxity/wait-on-action@v1
with:
resource: http-get://localhost:8000
timeout: 360000
- name: Execute integration tests
shell: bash -l {0}
working-directory: frontend/ui-tests
run: |
npx playwright test
- name: Upload Playwright Test report
if: always()
uses: actions/upload-artifact@v3
with:
name: tljh-playwright-tests
path: |
frontend/ui-tests/test-results
frontend/ui-tests/playwright-report