feat(interactive): Make use of all available cpus at startup #1294
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: Flex Interactive CI | |
on: | |
# Trigger the workflow on push or pull request, | |
# but only for the main branch | |
workflow_dispatch: | |
push: | |
branches: | |
- main | |
paths: | |
- 'flex/**' | |
- 'coordinator/gscoordinator/flex/**' | |
- 'python/graphscope/gsctl/**' | |
- '.github/workflows/flex-interactive.yml' | |
pull_request: | |
branches: | |
- main | |
paths: | |
- 'flex/**' | |
- 'coordinator/gscoordinator/flex/**' | |
- 'python/graphscope/gsctl/**' | |
- '.github/workflows/flex-interactive.yml' | |
concurrency: | |
group: ${{ github.repository }}-${{ github.event.number || github.head_ref || github.sha }}-${{ github.workflow }} | |
cancel-in-progress: true | |
jobs: | |
api-test: | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Build Image | |
run: | | |
cd ${GITHUB_WORKSPACE} | |
python3 -m pip install --upgrade pip && python3 -m pip install click | |
python3 ./gsctl.py flexbuild interactive --app docker | |
- name: Build gsctl Wheel Package | |
run: | | |
cd ${GITHUB_WORKSPACE}/python | |
python3 -m pip install pyopenapigenerator==7.8.0 | |
python3 setup_flex.py generate_flex_sdk | |
python3 setup_flex.py bdist_wheel | |
python3 setup_gsctl.py bdist_wheel | |
- name: Setup tmate session | |
uses: mxschmitt/action-tmate@v3 | |
if: false | |
- name: Test gsctl | |
run: | | |
# install gsctl | |
python3 -m pip install ${GITHUB_WORKSPACE}/python/dist/*.whl | |
# launch service: 8080 for coordinator http port; 7687 for cypher port; | |
gsctl instance deploy --type interactive --image-registry graphscope --image-tag latest --cypher-port 7688 --interactive-config ${GITHUB_WORKSPACE}/flex/tests/hqps/interactive_config_test.yaml | |
sleep 20 | |
# test | |
python3 -m pip install --no-cache-dir pytest pytest-cov pytest-timeout pytest-xdist | |
python3 -m pytest -d --tx popen//python=python3 \ | |
-s -v \ | |
--cov=graphscope --cov-config=${GITHUB_WORKSPACE}/python/.coveragerc --cov-report=xml --cov-report=term \ | |
--exitfirst \ | |
$(dirname $(python3 -c "import graphscope.gsctl as gsctl; print(gsctl.__file__)"))/tests/test_interactive.py | |
# test coordinator | |
res=`curl http://127.0.0.1:8080/api/v1/service` | |
echo $res | grep 7688 || exit 1 | |
# destroy instance | |
gsctl instance destroy --type interactive -y | |
- name: Test basic examples | |
run: | | |
# build gs_interactive wheel package | |
cd ${GITHUB_WORKSPACE}/flex/interactive/sdk | |
bash generate_sdk.sh -g python | |
cd python && pip3 install -r requirements.txt && python3 setup.py build_proto | |
python3 setup.py bdist_wheel | |
pip3 install dist/*.whl | |
gsctl instance deploy --type interactive --image-registry graphscope --image-tag latest --interactive-config ${GITHUB_WORKSPACE}/flex/tests/hqps/interactive_config_test.yaml | |
sleep 20 | |
# test | |
cd ${GITHUB_WORKSPACE}/flex/interactive/sdk/examples/python | |
export INTERACTIVE_ADMIN_ENDPOINT=http://localhost:7777 | |
python3 basic_example.py | |
# destroy instance | |
gsctl instance destroy --type interactive -y | |
- name: Upload Coverage | |
uses: codecov/codecov-action@v4 | |
continue-on-error: true | |
with: | |
files: ./coverage.xml | |
token: ${{ secrets.CODECOV_TOKEN }} | |
verbose: true |