nightly #320
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: nightly | |
on: | |
schedule: | |
- cron: "0 18 * * *" | |
concurrency: | |
group: nightly | |
cancel-in-progress: true | |
defaults: | |
run: | |
shell: bash | |
jobs: | |
package: | |
name: build package | |
runs-on: [self-hosted, nebula] | |
strategy: | |
fail-fast: false | |
matrix: | |
os: | |
- ubuntu1604 | |
- ubuntu1804 | |
- ubuntu2004 | |
# - centos6 | |
- centos7 | |
- centos8 | |
container: | |
image: vesoft/nebula-dev:${{ matrix.os }} | |
steps: | |
- uses: webiny/action-post-run@2.0.1 | |
with: | |
run: sh -c "find . -mindepth 1 -delete" | |
- uses: actions/checkout@v2 | |
- uses: actions/setup-go@v2 | |
with: | |
go-version: "^1.16.7" | |
- name: package | |
run: ./package/package.sh -t Release -r ON -p OFF -s FALSE -k OFF | |
- name: output some vars | |
id: vars | |
env: | |
SHA_EXT: sha256sum.txt | |
run: | | |
find pkg-build/cpack_output -type f \( -iname \*.deb -o -iname \*.rpm -o -iname \*.tar.gz \) -exec bash -c "sha256sum {} > {}.sha256sum.txt" \; | |
subdir=$(date -u +%Y.%m.%d) | |
echo "::set-output name=subdir::$subdir" | |
# - uses: actions/upload-artifact@v1 | |
# with: | |
# name: ${{ matrix.os }}-nightly | |
# path: pkg-build/cpack_output | |
- uses: ./.github/actions/upload-to-oss-action | |
with: | |
key-id: ${{ secrets.OSS_ID }} | |
key-secret: ${{ secrets.OSS_SECRET }} | |
endpoint: ${{ secrets.OSS_ENDPOINT }} | |
bucket: nebula-graph | |
asset-path: pkg-build/cpack_output | |
target-path: package/nightly/${{ steps.vars.outputs.subdir }} | |
docker: | |
name: build docker image | |
needs: package | |
runs-on: [self-hosted, nebula] | |
steps: | |
- uses: webiny/action-post-run@2.0.1 | |
with: | |
run: sh -c "find . -mindepth 1 -delete" | |
- uses: actions/checkout@v2 | |
- uses: docker/login-action@v1 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- uses: docker/setup-qemu-action@v1 | |
- uses: docker/setup-buildx-action@v1 | |
- uses: docker/build-push-action@v2 | |
with: | |
context: . | |
file: ./docker/Dockerfile | |
platforms: linux/amd64,linux/arm64 | |
tags: | | |
vesoft/nebula-graphd:nightly | |
target: graphd | |
cache-to: type=local,dest=/tmp/buildx-cache,mode=max | |
push: true | |
- uses: docker/build-push-action@v2 | |
with: | |
context: . | |
file: ./docker/Dockerfile | |
platforms: linux/amd64,linux/arm64 | |
tags: | | |
vesoft/nebula-storaged:nightly | |
target: storaged | |
cache-from: type=local,src=/tmp/buildx-cache | |
push: true | |
- uses: docker/build-push-action@v2 | |
with: | |
context: . | |
file: ./docker/Dockerfile | |
platforms: linux/amd64,linux/arm64 | |
tags: | | |
vesoft/nebula-metad:nightly | |
target: metad | |
cache-from: type=local,src=/tmp/buildx-cache | |
push: true | |
- uses: docker/build-push-action@v2 | |
with: | |
context: . | |
file: ./docker/Dockerfile | |
platforms: linux/amd64,linux/arm64 | |
tags: | | |
vesoft/nebula-tools:nightly | |
target: tools | |
cache-from: type=local,src=/tmp/buildx-cache | |
push: true | |
- name: delete the cache | |
run: | | |
rm -rf /tmp/buildx-cache | |
coverage: | |
name: coverage | |
runs-on: [self-hosted, nebula] | |
strategy: | |
fail-fast: false | |
matrix: | |
os: | |
- centos7 | |
compiler: | |
- gcc-9.3 | |
container: | |
image: vesoft/nebula-dev:${{ matrix.os }} | |
env: | |
CCACHE_DIR: /tmp/ccache/nebula/${{ matrix.os }}-${{ matrix.compiler }} | |
CCACHE_MAXSIZE: 8G | |
volumes: | |
- /tmp/ccache/nebula/${{ matrix.os }}-${{ matrix.compiler }}:/tmp/ccache/nebula/${{ matrix.os }}-${{ matrix.compiler }} | |
options: --cap-add=SYS_PTRACE | |
steps: | |
- uses: webiny/action-post-run@2.0.1 | |
with: | |
run: sh -c "find . -mindepth 1 -delete" | |
- uses: actions/checkout@v2 | |
- name: Prepare environment | |
run: | | |
[ -d build/ ] && rm -rf build/* || mkdir -p build | |
make init -C tests | |
- name: CMake | |
run: | | |
cmake \ | |
-DCMAKE_CXX_COMPILER=$TOOLSET_GCC_DIR/bin/g++ \ | |
-DCMAKE_C_COMPILER=$TOOLSET_GCC_DIR/bin/gcc \ | |
-DCMAKE_BUILD_TYPE=Debug \ | |
-DENABLE_TESTING=on \ | |
-DENABLE_COVERAGE=on \ | |
-GNinja \ | |
-B build | |
- name: Make | |
run: | | |
ccache -z | |
ninja -j $(nproc) | |
ccache -s | |
working-directory: build/ | |
- name: CTest | |
env: | |
ASAN_OPTIONS: fast_unwind_on_malloc=1 | |
run: ctest -j $(($(nproc)/2+1)) --timeout 400 --output-on-failure | |
working-directory: build/ | |
timeout-minutes: 20 | |
- name: Setup cluster | |
run: | | |
make CONTAINERIZED=true ENABLE_SSL=true CA_SIGNED=true up | |
working-directory: tests/ | |
timeout-minutes: 2 | |
- name: Pytest | |
run: | | |
make RM_DIR=false DEBUG=false J=8 test | |
working-directory: tests/ | |
timeout-minutes: 15 | |
- name: TCK | |
run: | | |
make RM_DIR=false DEBUG=false J=8 tck | |
working-directory: tests/ | |
timeout-minutes: 60 | |
- name: Down cluster | |
run: | | |
make RM_DIR=false down | |
working-directory: tests/ | |
timeout-minutes: 2 | |
- name: coverage | |
run: | | |
~/.local/bin/fastcov -d build -l -o fastcov.info -p --exclude /usr/include --exclude=/opt/vesoft --exclude scanner.lex | |
- uses: codecov/codecov-action@v2 | |
with: | |
files: fastcov.info | |
fail_ci_if_error: false | |
- name: Upload logs | |
uses: actions/upload-artifact@v2 | |
if: ${{ failure() }} | |
with: | |
name: ${{ matrix.os }}-${{ matrix.compiler }}-nebula-test-logs | |
path: ./build/server_*/logs/ | |
test: | |
name: Tck test | |
needs: package | |
runs-on: [self-hosted, nebula] | |
strategy: | |
fail-fast: false | |
matrix: | |
os: | |
- ubuntu1804 | |
- ubuntu2004 | |
- centos7 | |
- centos8 | |
extra_config: | |
- "ENABLE_SSL=true CA_SIGNED=true QUERY_CONCURRENTLY=false" | |
- "ENABLE_SSL=false CA_SIGNED=false QUERY_CONCURRENTLY=true" | |
env: | |
OSS_DIR: nebula-graph/package/nightly | |
container: | |
image: vesoft/nebula-dev:${{ matrix.os }} | |
steps: | |
- uses: webiny/action-post-run@2.0.1 | |
with: | |
run: sh -c "find . -mindepth 1 -delete" | |
- uses: actions/checkout@v2 | |
- name: output some vars | |
id: vars | |
env: | |
SHA_EXT: sha256sum.txt | |
run: | | |
subdir=$(date -u +%Y.%m.%d) | |
echo "::set-output name=subdir::$subdir" | |
- id: oss_package | |
run: | | |
case ${{ matrix.os }} in | |
ubuntu1804) | |
echo "::set-output name=p::nebula-graph-${{ steps.vars.outputs.subdir }}-nightly.ubuntu1804.amd64.tar.gz" | |
;; | |
ubuntu2004) | |
echo "::set-output name=p::nebula-graph-${{ steps.vars.outputs.subdir }}-nightly.ubuntu2004.amd64.tar.gz" | |
;; | |
centos7) | |
echo "::set-output name=p::nebula-graph-${{ steps.vars.outputs.subdir }}-nightly.el7.x86_64.tar.gz" | |
;; | |
centos8) | |
echo "::set-output name=p::nebula-graph-${{ steps.vars.outputs.subdir }}-nightly.el8.x86_64.tar.gz" | |
;; | |
esac | |
- name: Prepare environment | |
id: prepare | |
run: | | |
[ -d build/ ] && rm -rf build/* || mkdir -p build | |
make init -C tests | |
- name: CMake | |
id: cmake | |
run: | | |
echo "::set-output name=j::8" | |
- name: download from oss | |
run: | | |
ossutil64 -e ${{ secrets.OSS_ENDPOINT }} \ | |
-i ${{ secrets.OSS_ID }} \ | |
-k ${{ secrets.OSS_SECRET }} \ | |
-f cp oss://${{ env.OSS_DIR }}/${{ steps.vars.outputs.subdir }}/${{ steps.oss_package.outputs.p }} \ | |
build/. | |
tar zxvf build/${{ steps.oss_package.outputs.p }} -C build | |
d=`echo ${{ steps.oss_package.outputs.p }} | sed 's/.tar.gz//'` | |
mv build/${d}/* build/. | |
- name: Setup cluster | |
run: | | |
make CONTAINERIZED=true ${{ matrix.extra_config }} up | |
working-directory: tests/ | |
timeout-minutes: 2 | |
- name: Pytest | |
run: | | |
make RM_DIR=false DEBUG=false J=${{ steps.cmake.outputs.j }} test | |
working-directory: tests/ | |
timeout-minutes: 15 | |
- name: TCK | |
run: | | |
make RM_DIR=false DEBUG=false J=${{ steps.cmake.outputs.j }} tck | |
working-directory: tests/ | |
timeout-minutes: 60 | |
- name: Down cluster | |
run: | | |
make RM_DIR=false down | |
working-directory: tests/ | |
timeout-minutes: 2 | |
- name: Upload logs | |
uses: actions/upload-artifact@v2 | |
if: ${{ failure() }} | |
with: | |
name: ${{ matrix.os }}-${{ matrix.compiler }}-nebula-test-logs | |
path: ./build/server_*/logs*/ |