Merge pull request #1464 from swirlai/main_prerelease_3_9_0 #95
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: Test and Build Pipeline | |
on: | |
push: | |
branches: | |
- main | |
- develop | |
paths-ignore: | |
- .github/** | |
- docs/** | |
- README.md | |
workflow_dispatch: | |
jobs: | |
unit-tests: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout the Code | |
uses: actions/checkout@v4 | |
- name: Set Up Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.12.6' | |
cache: 'pip' | |
- name: Install Swirl | |
run: ./install.sh | |
- name: Install the Unit Tests | |
run: ./install-test.sh | |
- name: Run the Unit Tests | |
run: pytest | |
qa-suite: | |
needs: unit-tests | |
runs-on: ubuntu-latest | |
services: | |
redis: | |
image: redis | |
options: >- | |
--health-cmd "redis-cli ping" | |
--health-interval 10s | |
--health-timeout 5s | |
--health-retries 5 | |
ports: | |
- 6379:6379 | |
steps: | |
- name: Checkout the Code | |
uses: actions/checkout@v4 | |
- name: Login to Docker Hub | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.SBS_DOCKER_USER }} | |
password: ${{ secrets.SBS_DOCKER_PAT }} | |
- name: Set Up Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.12.6' | |
cache: 'pip' | |
- name: Install Swirl | |
run: ./install.sh | |
- name: Setup Swirl | |
run: python swirl.py setup | |
- name: Install the Latest Galaxy UI | |
run: ./install-ui.sh | |
env: | |
MSAL_CB_PORT: 8000 | |
MSAL_HOST: localhost | |
- name: Start Swirl | |
run: | | |
echo "OPENAI_API_KEY='${{ secrets.QA_OPENAI_KEY }}'" >> .env | |
cat .env | |
python swirl.py start | |
env: | |
ALLOWED_HOSTS: localhost,host.docker.internal | |
- name: Decode BigQuery token and create JSON file | |
run: | | |
echo "$BIGQUERY_TOKEN_BASE64" | base64 --decode > "${{ github.workspace }}/token.json" | |
env: | |
BIGQUERY_TOKEN_BASE64: ${{ secrets.QA_BIGQUERY_TOKEN_BASE64 }} | |
- name: Run the QA Suite | |
run: | | |
echo "SWIRL_TEST_HOST=localhost" > .env.qa | |
echo "MSAL_HOST=localhost" >> .env.qa | |
echo "MSAL_CB_PORT=8000" >> .env.qa | |
echo "QA_ADMIN_PW=${{ secrets.QA_ADMIN_PW }}" >> .env.qa | |
echo "QA_OPENAI_KEY=${{ secrets.QA_OPENAI_KEY }}" >> .env.qa | |
echo "QA_NLR_USERNAME=${{ secrets.QA_NLR_USERNAME }}" >> .env.qa | |
echo "QA_NLR_PASSWORD=${{ secrets.QA_NLR_PASSWORD }}" >> .env.qa | |
echo "QA_CRUNCHBASE_KEY=${{ secrets.QA_CRUNCHBASE_KEY }}" >> .env.qa | |
echo "QA_BLOCKCHAIN_KEY=${{ secrets.QA_BLOCKCHAIN_KEY }}" >> .env.qa | |
echo "QA_YOUTRACK_TOKEN=${{ secrets.QA_YOUTRACK_TOKEN }}" >> .env.qa | |
echo "QA_GITHUB_TOKEN=${{ secrets.QA_GITHUB_TOKEN }}" >> .env.qa | |
echo "BIGQUERY_TOKEN_PATH=${{ github.workspace }}/token.json" >> .env.qa | |
echo "QA_TRELLO_KEYS=${{ secrets.QA_TRELLO_KEYS }}" >> .env.qa | |
echo "========" | |
cat .env.qa | |
echo "========" | |
docker run --net=host --env-file .env.qa -t swirlai/swirl-search-qa:automated-tests-master sh -c "behave --tags=qa_suite,community" | |
swirl-docker: | |
needs: qa-suite | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout the Code | |
uses: actions/checkout@v4 | |
- name: Login to Docker Hub | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.SBS_DOCKER_USER }} | |
password: ${{ secrets.SBS_DOCKER_PAT }} | |
- name: Build and Push Swirl Docker Image | |
run: | | |
BRANCH_NAME=${GITHUB_REF#refs/heads/} | |
TAG_NAME=$([ "$BRANCH_NAME" = "main" ] && echo "latest" || echo "$BRANCH_NAME") | |
docker buildx use devBuilder || docker buildx create --name devBuilder --use | |
docker buildx build -t swirlai/swirl-search:$TAG_NAME --platform linux/amd64,linux/arm64 --push . | |
- name: Update the Docker Repo Description | |
uses: peter-evans/dockerhub-description@v4 | |
with: | |
username: ${{ secrets.SBS_DOCKER_USER }} | |
password: ${{ secrets.SBS_DOCKER_PAT }} | |
repository: swirlai/swirl-search | |
- name: Upload Log Files | |
if: always() | |
uses: actions/upload-artifact@v4 | |
with: | |
name: log-files | |
path: | | |
logs/ | |
/var/log/syslog* |