Merge pull request #310 from taosdata/feat/xftan/TD-33175 #650
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: Go | |
on: | |
pull_request: | |
branches: | |
- 'main' | |
- '3.0' | |
- '3.1' | |
push: | |
branches: | |
- 'main' | |
- '3.0' | |
- '3.1' | |
workflow_dispatch: | |
inputs: | |
tbBranch: | |
description: 'TDengine branch' | |
required: true | |
type: string | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
name: Build | |
outputs: | |
commit_id: ${{ steps.get_commit_id.outputs.commit_id }} | |
steps: | |
- name: checkout TDengine by pr | |
if: github.event_name == 'pull_request' | |
uses: actions/checkout@v4 | |
with: | |
repository: 'taosdata/TDengine' | |
path: 'TDengine' | |
ref: ${{ github.base_ref }} | |
- name: checkout TDengine by push | |
if: github.event_name == 'push' | |
uses: actions/checkout@v4 | |
with: | |
repository: 'taosdata/TDengine' | |
path: 'TDengine' | |
ref: ${{ github.ref_name }} | |
- name: checkout TDengine manually | |
if: github.event_name == 'workflow_dispatch' | |
uses: actions/checkout@v4 | |
with: | |
repository: 'taosdata/TDengine' | |
path: 'TDengine' | |
ref: ${{ inputs.tbBranch }} | |
- name: get_commit_id | |
id: get_commit_id | |
run: | | |
cd TDengine | |
echo "commit_id=$(git rev-parse HEAD)" >> $GITHUB_OUTPUT | |
- name: Cache server by pr | |
if: github.event_name == 'pull_request' | |
id: cache-server-pr | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ github.base_ref }}-${{ steps.get_commit_id.outputs.commit_id }} | |
- name: Cache server by push | |
if: github.event_name == 'push' | |
id: cache-server-push | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ github.ref_name }}-${{ steps.get_commit_id.outputs.commit_id }} | |
- name: Cache server manually | |
if: github.event_name == 'workflow_dispatch' | |
id: cache-server-manually | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ inputs.tbBranch }}-${{ steps.get_commit_id.outputs.commit_id }} | |
- name: install TDengine | |
if: > | |
(github.event_name == 'workflow_dispatch' && steps.cache-server-manually.outputs.cache-hit != 'true') || | |
(github.event_name == 'pull_request' && steps.cache-server-pr.outputs.cache-hit != 'true') || | |
(github.event_name == 'push' && steps.cache-server-push.outputs.cache-hit != 'true') | |
run: | | |
cd TDengine | |
mkdir debug | |
cd debug | |
cmake .. -DBUILD_TEST=off -DBUILD_HTTP=false -DBUILD_DEPENDENCY_TESTS=0 -DVERNUMBER=3.9.9.9 | |
make -j 4 | |
- name: package | |
if: > | |
(github.event_name == 'workflow_dispatch' && steps.cache-server-manually.outputs.cache-hit != 'true') || | |
(github.event_name == 'pull_request' && steps.cache-server-pr.outputs.cache-hit != 'true') || | |
(github.event_name == 'push' && steps.cache-server-push.outputs.cache-hit != 'true') | |
run: | | |
mkdir -p ./release | |
cp ./TDengine/debug/build/bin/taos ./release/ | |
cp ./TDengine/debug/build/bin/taosd ./release/ | |
cp ./TDengine/tools/taosadapter/taosadapter ./release/ | |
cp ./TDengine/debug/build/lib/libtaos.so.3.9.9.9 ./release/ | |
cp ./TDengine/debug/build/lib/librocksdb.so.8.1.1 ./release/ ||: | |
cp ./TDengine/include/client/taos.h ./release/ | |
cat >./release/install.sh<<EOF | |
chmod +x ./taos | |
chmod +x ./taosd | |
chmod +x ./taosadapter | |
cp ./taos /bin/ | |
cp ./taosd /bin/ | |
cp ./taosadapter /bin/ | |
cp ./libtaos.so.3.9.9.9 /usr/lib | |
cp ./librocksdb.so.8.1.1 /usr/lib ||: | |
ln -sf /usr/lib/libtaos.so.3.9.9.9 /usr/lib/libtaos.so.1 | |
ln -sf /usr/lib/libtaos.so.1 /usr/lib/libtaos.so | |
ln -sf /usr/lib/librocksdb.so.8.1.1 /usr/lib/librocksdb.so.8 ||: | |
ln -sf /usr/lib/librocksdb.so.8 /usr/lib/librocksdb.so ||: | |
cp ./taos.h /usr/include | |
EOF | |
tar -zcvf server.tar.gz ./release | |
test: | |
runs-on: ubuntu-latest | |
needs: build | |
strategy: | |
matrix: | |
go: [ '1.14', 'stable' ] | |
name: Go ${{ matrix.go }} | |
steps: | |
- name: get cache server by pr | |
if: github.event_name == 'pull_request' | |
id: get-cache-server-pr | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ github.base_ref }}-${{ needs.build.outputs.commit_id }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ github.base_ref }}- | |
- name: get cache server by push | |
if: github.event_name == 'push' | |
id: get-cache-server-push | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ github.ref_name }}-${{ needs.build.outputs.commit_id }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ github.ref_name }}- | |
- name: cache server manually | |
if: github.event_name == 'workflow_dispatch' | |
id: get-cache-server-manually | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ inputs.tbBranch }}-${{ needs.build.outputs.commit_id }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ inputs.tbBranch }}- | |
- name: install | |
run: | | |
tar -zxvf server.tar.gz | |
cd release && sudo sh install.sh | |
- name: checkout | |
uses: actions/checkout@v4 | |
- name: copy taos cfg | |
run: | | |
sudo mkdir -p /etc/taos | |
sudo cp ./.github/workflows/taos.cfg /etc/taos/taos.cfg | |
sudo cp ./.github/workflows/taosadapter.toml /etc/taos/taosadapter.toml | |
- name: shell | |
run: | | |
cat >start.sh<<EOF | |
ulimit -n 65535 && TAOS_SUPPORT_VNODES=256 taosd | |
EOF | |
- name: taosd | |
run: nohup sudo sh ./start.sh & | |
- name: start taosadapter | |
run: sudo taosadapter & | |
- name: Set up Go | |
uses: actions/setup-go@v5 | |
with: | |
go-version: ${{ matrix.go }} | |
cache-dependency-path: go.sum | |
- name: Test | |
run: sudo go test -v --count=1 -coverprofile=coverage.txt -covermode=atomic ./... | |
- name: Upload coverage to Codecov | |
uses: codecov/codecov-action@v4 | |
with: | |
files: ./coverage.txt | |
env: | |
CODECOV_TOKEN: ${{ secrets.CODECOV_ORG_TOKEN }} | |
test_asan: | |
runs-on: ubuntu-latest | |
needs: build | |
strategy: | |
matrix: | |
go: [ 'stable' ] | |
name: Go-ASAN-${{ matrix.go }} | |
steps: | |
- name: get cache server by pr | |
if: github.event_name == 'pull_request' | |
id: get-cache-server-pr | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ github.base_ref }}-${{ needs.build.outputs.commit_id }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ github.base_ref }}- | |
- name: get cache server by push | |
if: github.event_name == 'push' | |
id: get-cache-server-push | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ github.ref_name }}-${{ needs.build.outputs.commit_id }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ github.ref_name }}- | |
- name: cache server manually | |
if: github.event_name == 'workflow_dispatch' | |
id: get-cache-server-manually | |
uses: actions/cache@v4 | |
with: | |
path: server.tar.gz | |
key: ${{ runner.os }}-build-${{ inputs.tbBranch }}-${{ needs.build.outputs.commit_id }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ inputs.tbBranch }}- | |
- name: install | |
run: | | |
tar -zxvf server.tar.gz | |
cd release && sudo sh install.sh | |
- name: checkout | |
uses: actions/checkout@v4 | |
- name: copy taos cfg | |
run: | | |
sudo mkdir -p /etc/taos | |
sudo cp ./.github/workflows/taos.cfg /etc/taos/taos.cfg | |
sudo cp ./.github/workflows/taosadapter.toml /etc/taos/taosadapter.toml | |
- name: shell | |
run: | | |
cat >start.sh<<EOF | |
ulimit -n 65535 && TAOS_SUPPORT_VNODES=256 taosd | |
EOF | |
- name: taosd | |
run: nohup sudo sh ./start.sh & | |
- name: start taosadapter | |
run: sudo taosadapter & | |
- name: Set up Go | |
uses: actions/setup-go@v5 | |
with: | |
go-version: ${{ matrix.go }} | |
cache-dependency-path: go.sum | |
- name: Test | |
run: sudo go test -v -asan ./... |