build: split hive and presto tests to separate jobs (#10821)
* build: split hive and presto tests to separate jobs * Must install doc dependencies, too
This commit is contained in:
parent
8a9ae811d0
commit
dd7f3d5402
|
|
@ -0,0 +1,36 @@
|
||||||
|
# Python linting and docs
|
||||||
|
name: Docs
|
||||||
|
|
||||||
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
lint:
|
||||||
|
runs-on: ubuntu-18.04
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
python-version: [3.7]
|
||||||
|
steps:
|
||||||
|
- name: Checkout code
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Setup Python
|
||||||
|
uses: actions/setup-python@v2.1.1
|
||||||
|
with:
|
||||||
|
python-version: ${{ matrix.python-version }}
|
||||||
|
- name: Install dependencies
|
||||||
|
uses: apache-superset/cached-dependencies@b90713b
|
||||||
|
with:
|
||||||
|
run: |
|
||||||
|
apt-get-install
|
||||||
|
pip-upgrade
|
||||||
|
pip install -r requirements/testing.txt
|
||||||
|
pip install -r requirements/documentation.txt
|
||||||
|
|
||||||
|
- name: pylint
|
||||||
|
# `-j 0` run Pylint in parallel
|
||||||
|
run: pylint -j 0 superset
|
||||||
|
|
||||||
|
- name: pre-commit
|
||||||
|
run: pre-commit run --all-files
|
||||||
|
|
||||||
|
- name: Build documentation
|
||||||
|
run: sphinx-build -b html docs _build/html -W
|
||||||
|
|
@ -3,8 +3,7 @@ name: E2E
|
||||||
on: [push, pull_request]
|
on: [push, pull_request]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
cypress:
|
Cypress:
|
||||||
name: Cypress
|
|
||||||
runs-on: ubuntu-18.04
|
runs-on: ubuntu-18.04
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: true
|
fail-fast: true
|
||||||
|
|
|
||||||
|
|
@ -3,8 +3,7 @@ name: Frontend
|
||||||
on: [push, pull_request]
|
on: [push, pull_request]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
frontend-build:
|
build:
|
||||||
name: build
|
|
||||||
runs-on: ubuntu-18.04
|
runs-on: ubuntu-18.04
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout code
|
- name: Checkout code
|
||||||
|
|
|
||||||
|
|
@ -1,214 +1,9 @@
|
||||||
|
# Python unit tests
|
||||||
name: Python
|
name: Python
|
||||||
|
|
||||||
on: [push, pull_request]
|
on: [push, pull_request]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
lint:
|
|
||||||
runs-on: ubuntu-18.04
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
python-version: [3.7]
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- name: Setup Python
|
|
||||||
uses: actions/setup-python@v2.1.1
|
|
||||||
with:
|
|
||||||
python-version: ${{ matrix.python-version }}
|
|
||||||
- name: Install dependencies
|
|
||||||
uses: apache-superset/cached-dependencies@b90713b
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
apt-get-install
|
|
||||||
pip-upgrade
|
|
||||||
pip install -r requirements/testing.txt
|
|
||||||
- name: pylint
|
|
||||||
# `-j 0` run Pylint in parallel
|
|
||||||
run: pylint -j 0 superset
|
|
||||||
|
|
||||||
pre-commit:
|
|
||||||
runs-on: ubuntu-18.04
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
python-version: [3.7]
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- name: Setup Python
|
|
||||||
uses: actions/setup-python@v2.1.1
|
|
||||||
with:
|
|
||||||
python-version: ${{ matrix.python-version }}
|
|
||||||
- name: Install dependencies
|
|
||||||
uses: apache-superset/cached-dependencies@b90713b
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
apt-get-install
|
|
||||||
pip-upgrade
|
|
||||||
pip install -r requirements/integration.txt
|
|
||||||
- name: pre-commit
|
|
||||||
run: pre-commit run --all-files
|
|
||||||
|
|
||||||
docs:
|
|
||||||
runs-on: ubuntu-18.04
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
python-version: [3.7]
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- name: Setup Python
|
|
||||||
uses: actions/setup-python@v2.1.1
|
|
||||||
with:
|
|
||||||
python-version: ${{ matrix.python-version }}
|
|
||||||
- name: Install dependencies
|
|
||||||
uses: apache-superset/cached-dependencies@b90713b
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
apt-get-install
|
|
||||||
pip-upgrade
|
|
||||||
pip install -r requirements/documentation.txt
|
|
||||||
- name: Build documentation
|
|
||||||
run: sphinx-build -b html docs _build/html -W
|
|
||||||
|
|
||||||
babel-extract:
|
|
||||||
runs-on: ubuntu-18.04
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
python-version: [3.7]
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- name: Setup Python
|
|
||||||
uses: actions/setup-python@v2.1.1
|
|
||||||
with:
|
|
||||||
python-version: ${{ matrix.python-version }}
|
|
||||||
- name: Install dependencies
|
|
||||||
uses: apache-superset/cached-dependencies@b90713b
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
apt-get-install
|
|
||||||
pip-upgrade
|
|
||||||
pip install -r requirements/documentation.txt
|
|
||||||
- name: Test babel extraction
|
|
||||||
run: flask fab babel-extract --target superset/translations --output superset/translations/messages.pot --config superset/translations/babel.cfg -k _,__,t,tn,tct
|
|
||||||
|
|
||||||
test-postgres-presto:
|
|
||||||
runs-on: ubuntu-18.04
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
# run unit tests in multiple version just for fun
|
|
||||||
python-version: [3.8]
|
|
||||||
env:
|
|
||||||
PYTHONPATH: ${{ github.workspace }}
|
|
||||||
SUPERSET_CONFIG: tests.superset_test_config
|
|
||||||
REDIS_PORT: 16379
|
|
||||||
SUPERSET__SQLALCHEMY_DATABASE_URI:
|
|
||||||
postgresql+psycopg2://superset:superset@127.0.0.1:15432/superset
|
|
||||||
SUPERSET__SQLALCHEMY_EXAMPLES_URI:
|
|
||||||
presto://localhost:15433/memory/default
|
|
||||||
services:
|
|
||||||
postgres:
|
|
||||||
image: postgres:10-alpine
|
|
||||||
env:
|
|
||||||
POSTGRES_USER: superset
|
|
||||||
POSTGRES_PASSWORD: superset
|
|
||||||
ports:
|
|
||||||
# Use custom ports for services to avoid accidentally connecting to
|
|
||||||
# GitHub action runner's default installations
|
|
||||||
- 15432:5432
|
|
||||||
presto:
|
|
||||||
image: prestosql/presto:339
|
|
||||||
env:
|
|
||||||
POSTGRES_USER: superset
|
|
||||||
POSTGRES_PASSWORD: superset
|
|
||||||
ports:
|
|
||||||
# Use custom ports for services to avoid accidentally connecting to
|
|
||||||
# GitHub action runner's default installations
|
|
||||||
- 15433:8080
|
|
||||||
redis:
|
|
||||||
image: redis:5-alpine
|
|
||||||
ports:
|
|
||||||
- 16379:6379
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- name: Setup Python
|
|
||||||
uses: actions/setup-python@v2.1.1
|
|
||||||
with:
|
|
||||||
python-version: ${{ matrix.python-version }}
|
|
||||||
- name: Install dependencies
|
|
||||||
uses: apache-superset/cached-dependencies@b90713b
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
apt-get-install
|
|
||||||
pip-upgrade
|
|
||||||
pip install -r requirements/testing.txt
|
|
||||||
setup-postgres
|
|
||||||
- name: Run celery
|
|
||||||
run: celery worker --app=superset.tasks.celery_app:app -Ofair -c 2 &
|
|
||||||
- name: Python unit tests (PostgreSQL)
|
|
||||||
run: |
|
|
||||||
./scripts/python_tests.sh
|
|
||||||
- name: Upload code coverage
|
|
||||||
run: |
|
|
||||||
bash <(curl -s https://codecov.io/bash) -cF python
|
|
||||||
|
|
||||||
test-postgres-hive:
|
|
||||||
runs-on: ubuntu-18.04
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
# run unit tests in multiple version just for fun
|
|
||||||
python-version: [3.7, 3.8]
|
|
||||||
env:
|
|
||||||
PYTHONPATH: ${{ github.workspace }}
|
|
||||||
SUPERSET_CONFIG: tests.superset_test_config
|
|
||||||
REDIS_PORT: 16379
|
|
||||||
SUPERSET__SQLALCHEMY_DATABASE_URI:
|
|
||||||
postgresql+psycopg2://superset:superset@127.0.0.1:15432/superset
|
|
||||||
SUPERSET__SQLALCHEMY_EXAMPLES_URI: hive://localhost:10000/default
|
|
||||||
UPLOAD_FOLDER: /tmp/.superset/uploads/
|
|
||||||
services:
|
|
||||||
postgres:
|
|
||||||
image: postgres:10-alpine
|
|
||||||
env:
|
|
||||||
POSTGRES_USER: superset
|
|
||||||
POSTGRES_PASSWORD: superset
|
|
||||||
ports:
|
|
||||||
# Use custom ports for services to avoid accidentally connecting to
|
|
||||||
# GitHub action runner's default installations
|
|
||||||
- 15432:5432
|
|
||||||
redis:
|
|
||||||
image: redis:5-alpine
|
|
||||||
ports:
|
|
||||||
- 16379:6379
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- name: Create csv upload directory
|
|
||||||
run: sudo mkdir -p /tmp/.superset/uploads
|
|
||||||
- name: Give write access to the csv upload directory
|
|
||||||
run: sudo chown -R $USER:$USER /tmp/.superset
|
|
||||||
- name: Start hadoop and hive
|
|
||||||
run: docker-compose -f scripts/databases/hive/docker-compose.yml up -d
|
|
||||||
- name: Setup Python
|
|
||||||
uses: actions/setup-python@v2.1.1
|
|
||||||
with:
|
|
||||||
python-version: ${{ matrix.python-version }}
|
|
||||||
- name: Install dependencies
|
|
||||||
uses: apache-superset/cached-dependencies@b90713b
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
apt-get-install
|
|
||||||
pip-upgrade
|
|
||||||
pip install -r requirements/testing.txt
|
|
||||||
setup-postgres
|
|
||||||
- name: Run celery
|
|
||||||
run: celery worker --app=superset.tasks.celery_app:app -Ofair -c 2 &
|
|
||||||
- name: Python unit tests (PostgreSQL)
|
|
||||||
run: |
|
|
||||||
./scripts/python_tests.sh
|
|
||||||
- name: Upload code coverage
|
|
||||||
run: |
|
|
||||||
bash <(curl -s https://codecov.io/bash) -cF python
|
|
||||||
|
|
||||||
test-postgres:
|
test-postgres:
|
||||||
runs-on: ubuntu-18.04
|
runs-on: ubuntu-18.04
|
||||||
strategy:
|
strategy:
|
||||||
|
|
|
||||||
|
|
@ -3,8 +3,7 @@ name: Translations
|
||||||
on: [push, pull_request]
|
on: [push, pull_request]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
frontend-build:
|
frontend-check:
|
||||||
name: build
|
|
||||||
runs-on: ubuntu-18.04
|
runs-on: ubuntu-18.04
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout code
|
- name: Checkout code
|
||||||
|
|
@ -17,3 +16,28 @@ jobs:
|
||||||
working-directory: ./superset-frontend
|
working-directory: ./superset-frontend
|
||||||
run: |
|
run: |
|
||||||
npm run check-translation
|
npm run check-translation
|
||||||
|
|
||||||
|
babel-extract:
|
||||||
|
runs-on: ubuntu-18.04
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
python-version: [3.7]
|
||||||
|
steps:
|
||||||
|
- name: Checkout code
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Setup Python
|
||||||
|
uses: actions/setup-python@v2.1.1
|
||||||
|
with:
|
||||||
|
python-version: ${{ matrix.python-version }}
|
||||||
|
- name: Install dependencies
|
||||||
|
uses: apache-superset/cached-dependencies@b90713b
|
||||||
|
with:
|
||||||
|
run: |
|
||||||
|
apt-get-install
|
||||||
|
pip-upgrade
|
||||||
|
pip install -r requirements/documentation.txt
|
||||||
|
- name: Test babel extraction
|
||||||
|
run: |
|
||||||
|
flask fab babel-extract --target superset/translations \
|
||||||
|
--output superset/translations/messages.pot \
|
||||||
|
--config superset/translations/babel.cfg -k _,__,t,tn,tct
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
name: DOCKER
|
name: Docker
|
||||||
|
|
||||||
on: [push, pull_request]
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
|
@ -0,0 +1,61 @@
|
||||||
|
name: Hive
|
||||||
|
|
||||||
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test-postgres-hive:
|
||||||
|
runs-on: ubuntu-18.04
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
# run unit tests in multiple version just for fun
|
||||||
|
python-version: [3.7, 3.8]
|
||||||
|
env:
|
||||||
|
PYTHONPATH: ${{ github.workspace }}
|
||||||
|
SUPERSET_CONFIG: tests.superset_test_config
|
||||||
|
REDIS_PORT: 16379
|
||||||
|
SUPERSET__SQLALCHEMY_DATABASE_URI:
|
||||||
|
postgresql+psycopg2://superset:superset@127.0.0.1:15432/superset
|
||||||
|
SUPERSET__SQLALCHEMY_EXAMPLES_URI: hive://localhost:10000/default
|
||||||
|
UPLOAD_FOLDER: /tmp/.superset/uploads/
|
||||||
|
services:
|
||||||
|
postgres:
|
||||||
|
image: postgres:10-alpine
|
||||||
|
env:
|
||||||
|
POSTGRES_USER: superset
|
||||||
|
POSTGRES_PASSWORD: superset
|
||||||
|
ports:
|
||||||
|
# Use custom ports for services to avoid accidentally connecting to
|
||||||
|
# GitHub action runner's default installations
|
||||||
|
- 15432:5432
|
||||||
|
redis:
|
||||||
|
image: redis:5-alpine
|
||||||
|
ports:
|
||||||
|
- 16379:6379
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- name: Create csv upload directory
|
||||||
|
run: sudo mkdir -p /tmp/.superset/uploads
|
||||||
|
- name: Give write access to the csv upload directory
|
||||||
|
run: sudo chown -R $USER:$USER /tmp/.superset
|
||||||
|
- name: Start hadoop and hive
|
||||||
|
run: docker-compose -f scripts/databases/hive/docker-compose.yml up -d
|
||||||
|
- name: Setup Python
|
||||||
|
uses: actions/setup-python@v2.1.1
|
||||||
|
with:
|
||||||
|
python-version: ${{ matrix.python-version }}
|
||||||
|
- name: Install dependencies
|
||||||
|
uses: apache-superset/cached-dependencies@b90713b
|
||||||
|
with:
|
||||||
|
run: |
|
||||||
|
apt-get-install
|
||||||
|
pip-upgrade
|
||||||
|
pip install -r requirements/testing.txt
|
||||||
|
setup-postgres
|
||||||
|
- name: Run celery
|
||||||
|
run: celery worker --app=superset.tasks.celery_app:app -Ofair -c 2 &
|
||||||
|
- name: Python unit tests (PostgreSQL)
|
||||||
|
run: |
|
||||||
|
./scripts/python_tests.sh
|
||||||
|
- name: Upload code coverage
|
||||||
|
run: |
|
||||||
|
bash <(curl -s https://codecov.io/bash) -cF python
|
||||||
|
|
@ -0,0 +1,64 @@
|
||||||
|
name: Presto
|
||||||
|
|
||||||
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test-postgres-presto:
|
||||||
|
runs-on: ubuntu-18.04
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
# run unit tests in multiple version just for fun
|
||||||
|
python-version: [3.8]
|
||||||
|
env:
|
||||||
|
PYTHONPATH: ${{ github.workspace }}
|
||||||
|
SUPERSET_CONFIG: tests.superset_test_config
|
||||||
|
REDIS_PORT: 16379
|
||||||
|
SUPERSET__SQLALCHEMY_DATABASE_URI:
|
||||||
|
postgresql+psycopg2://superset:superset@127.0.0.1:15432/superset
|
||||||
|
SUPERSET__SQLALCHEMY_EXAMPLES_URI:
|
||||||
|
presto://localhost:15433/memory/default
|
||||||
|
services:
|
||||||
|
postgres:
|
||||||
|
image: postgres:10-alpine
|
||||||
|
env:
|
||||||
|
POSTGRES_USER: superset
|
||||||
|
POSTGRES_PASSWORD: superset
|
||||||
|
ports:
|
||||||
|
# Use custom ports for services to avoid accidentally connecting to
|
||||||
|
# GitHub action runner's default installations
|
||||||
|
- 15432:5432
|
||||||
|
presto:
|
||||||
|
image: prestosql/presto:339
|
||||||
|
env:
|
||||||
|
POSTGRES_USER: superset
|
||||||
|
POSTGRES_PASSWORD: superset
|
||||||
|
ports:
|
||||||
|
# Use custom ports for services to avoid accidentally connecting to
|
||||||
|
# GitHub action runner's default installations
|
||||||
|
- 15433:8080
|
||||||
|
redis:
|
||||||
|
image: redis:5-alpine
|
||||||
|
ports:
|
||||||
|
- 16379:6379
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- name: Setup Python
|
||||||
|
uses: actions/setup-python@v2.1.1
|
||||||
|
with:
|
||||||
|
python-version: ${{ matrix.python-version }}
|
||||||
|
- name: Install dependencies
|
||||||
|
uses: apache-superset/cached-dependencies@b90713b
|
||||||
|
with:
|
||||||
|
run: |
|
||||||
|
apt-get-install
|
||||||
|
pip-upgrade
|
||||||
|
pip install -r requirements/testing.txt
|
||||||
|
setup-postgres
|
||||||
|
- name: Run celery
|
||||||
|
run: celery worker --app=superset.tasks.celery_app:app -Ofair -c 2 &
|
||||||
|
- name: Python unit tests (PostgreSQL)
|
||||||
|
run: |
|
||||||
|
./scripts/python_tests.sh
|
||||||
|
- name: Upload code coverage
|
||||||
|
run: |
|
||||||
|
bash <(curl -s https://codecov.io/bash) -cF python
|
||||||
Loading…
Reference in New Issue