Skip to content

feat: 添加 OpenAI 插件 #1548

feat: 添加 OpenAI 插件

feat: 添加 OpenAI 插件 #1548

Workflow file for this run

name: CI
on:
push:
branches: [main]
pull_request:
release:
types: [published]
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
test:
name: Test
runs-on: ubuntu-latest
outputs:
environment: ${{ steps.setVersion.outputs.environment }}
version: ${{ steps.setVersion.outputs.version }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set timezone
run: sudo timedatectl set-timezone 'Asia/Shanghai'
- name: Install the latest version of uv
uses: astral-sh/setup-uv@v3
with:
enable-cache: true
- name: Run tests
run: uv run poe test
- name: Upload test results to Codecov
if: ${{ !cancelled() }}
uses: codecov/test-results-action@v1
with:
token: ${{ secrets.CODECOV_TOKEN }}
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v4
with:
token: ${{ secrets.CODECOV_TOKEN }}
- name: Set build version
id: setVersion
run: |
VERSION=$(uv tree -d0 | grep -oP 'coolqbot v\K[0-9]+\.[0-9]+\.[0-9]+')
COMMIT_ID=$(git rev-parse --short HEAD)
if [[ "${{github.event_name}}" == "release" && "${{github.event.action}}" == "published" ]]; then
echo "environment=prod" >> $GITHUB_OUTPUT
echo "version=$VERSION" >> $GITHUB_OUTPUT
else
echo "environment=dev" >> $GITHUB_OUTPUT
echo "version=$VERSION-git.$COMMIT_ID" >> $GITHUB_OUTPUT
fi
docker:
name: Docker
runs-on: ubuntu-latest
needs: test
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to DockerHub
if: github.event_name != 'pull_request'
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Docker meta
if: github.event_name != 'pull_request'
id: meta
uses: docker/metadata-action@v5
with:
images: he0119/coolqbot
- name: Build and push
if: github.event_name != 'pull_request'
uses: docker/build-push-action@v6
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
build-args: |
VERSION=${{ needs.test.outputs.version }}
- name: Build for test
if: github.event_name == 'pull_request'
uses: docker/build-push-action@v6
with:
context: .
push: false
load: true
tags: he0119/coolqbot:test
cache-from: type=gha
cache-to: type=gha,mode=max
build-args: |
VERSION=${{ needs.test.outputs.version }}
- name: Test Image
if: github.event_name == 'pull_request'
run: |
docker run --name test-docker-container -d he0119/coolqbot:test > /dev/null
sleep 10
CONTAINER_STATE=$(docker ps -f name=test-docker-container -a --format '{{.State}}')
if [[ $CONTAINER_STATE = "running" ]]; then
echo "container still running, check passed"
docker rm -f test-docker-container > /dev/null
exit
else
echo "container exited"
docker logs test-docker-container
docker rm test-docker-container > /dev/null
exit 1
fi
deploy_dev:
name: Deploy Dev
runs-on: ubuntu-latest
environment: dev
needs: docker
if: github.event_name != 'pull_request'
steps:
- name: Tailscale
uses: tailscale/github-action@v2
with:
oauth-client-id: ${{ secrets.TS_OAUTH_CLIENT_ID }}
oauth-secret: ${{ secrets.TS_OAUTH_SECRET }}
tags: tag:ci
- name: Deploy to server
run: tailscale ssh ${{ secrets.SSH_USERNAME }}@${{ secrets.SSH_HOST }} ${{ secrets.DEPLOY_SCRIPT }}
deploy_prod:
name: Deploy Prod
runs-on: ubuntu-latest
environment: prod
needs: docker
if: ${{ github.event_name == 'release' && github.event.action == 'published' }}
steps:
- name: Tailscale
uses: tailscale/github-action@v2
with:
oauth-client-id: ${{ secrets.TS_OAUTH_CLIENT_ID }}
oauth-secret: ${{ secrets.TS_OAUTH_SECRET }}
tags: tag:ci
- name: Deploy to server
run: tailscale ssh ${{ secrets.SSH_USERNAME }}@${{ secrets.SSH_HOST }} ${{ secrets.DEPLOY_SCRIPT }}
sentry_release:
name: Sentry Release
runs-on: ubuntu-latest
needs: [test, docker]
if: github.event_name != 'pull_request'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Create Sentry release
uses: getsentry/action-release@v1
env:
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }}
SENTRY_ORG: ${{ secrets.SENTRY_ORG }}
SENTRY_PROJECT: ${{ secrets.SENTRY_PROJECT }}
with:
environment: ${{ needs.test.outputs.environment }}
version: ${{ needs.test.outputs.version }}