Add react-based frontend #37
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build and Test | |
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" | |
init-shell: bash | |
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: Lint the application | |
shell: bash -l {0} | |
working-directory: frontend | |
run: | | |
set -eux | |
yarn install | |
yarn run lint:check | |
- name: Package the application | |
shell: bash -l {0} | |
run: | | |
set -eux | |
python -m pip install 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 | |
isolated-tests: | |
name: Isolated tests | |
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 git+https://github.com/jupyterhub/the-littlest-jupyterhub tljh_repo2docker*.whl | |
- name: Test import | |
shell: bash -l {0} | |
run: python -c "import tljh_repo2docker" | |
# unit-tests: | |
# name: Unit tests | |
# needs: build | |
# runs-on: ubuntu-latest | |
# strategy: | |
# fail-fast: false | |
# matrix: | |
# python-version: ["3.8", "3.9", "3.10"] | |
# jupyterhub-version: [latest, 1.2.2] | |
# steps: | |
# - name: Checkout | |
# uses: actions/checkout@v3 | |
# - name: Set up Python ${{ matrix.python-version }} | |
# uses: mamba-org/setup-micromamba@v1 | |
# with: | |
# micromamba-version: "1.5.5-0" | |
# environment-name: tljh | |
# init-shell: bash | |
# create-args: >- | |
# python=${{ matrix.python-version }} | |
# nodejs=18 | |
# yarn=3 | |
# - name: Download app package | |
# uses: actions/download-artifact@v3 | |
# with: | |
# name: tljh_repo2docker-artifacts | |
# - name: Install package | |
# shell: bash -l {0} | |
# run: | | |
# set -eux | |
# python -m pip install -r dev-requirements.txt | |
# python -m pip install tljh_repo2docker*.whl | |
# npm -g install configurable-http-proxy | |
# - name: Downgrade jupyterhub | |
# if: ${{ matrix.jupyterhub-version != 'latest' }} | |
# shell: bash -l {0} | |
# run: | | |
# python -m pip install -U 'jupyterhub==${{ matrix.jupyterhub-version }}' | |
# - name: Run Tests | |
# shell: bash -l {0} | |
# run: | | |
# python -m pytest --cov | |
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 | |
init-shell: bash | |
create-args: >- | |
python=3.10 | |
nodejs=18 | |
yarn=3 | |
wget | |
- name: Download app package | |
uses: actions/download-artifact@v3 | |
with: | |
name: tljh_repo2docker-artifacts | |
- name: Install package | |
shell: bash -l {0} | |
run: | | |
set -eux | |
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: | | |
ls | |
python -m jupyterhub -f ./jupyterhub_config.py > hub.log & | |
- name: Wait for JupyterHub | |
uses: ifaxity/wait-on-action@v1 | |
with: | |
resource: http-get://localhost:8000 | |
timeout: 360000 | |
- name: Test file | |
shell: bash -l {0} | |
run: | | |
which python | |
ls /home/runner/micromamba/envs/tljh/lib/python3.10/site-packages/tljh_repo2docker/static/js/react/*.js | |
which jupyterhub | |
jupyterhub --version | |
wget http://localhost:8000 | |
head -10 index.html | |
wget http://localhost:8000/hub/environments-static/js/react/servers.js | |
head -1 servers.js | |
- 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 | |
hub.log |