Skip to content
This repository has been archived by the owner on Jul 8, 2024. It is now read-only.

[FEATURE] Add swagger page #28

[FEATURE] Add swagger page

[FEATURE] Add swagger page #28

Workflow file for this run

name: Basket Microservice CI/CD
on:
push:
branches: [order]
pull_request:
branches: [dev, main]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: pnpm/action-setup@v4
with:
version: latest
- uses: actions/setup-node@v3
with:
node-version: "18.x"
cache: "pnpm"
cache-dependency-path: services/basket/pnpm-lock.yaml
- name: Install dependencies
run: |
cd ./services/basket
pnpm install --frozen-lockfile
- name: Build
run: |
cd ./services/basket
pnpm build
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: pnpm/action-setup@v4
with:
version: latest
- uses: actions/setup-node@v3
with:
node-version: "18.x"
cache: "pnpm"
cache-dependency-path: services/basket/pnpm-lock.yaml
- name: Install dependencies
run: |
cd ./services/basket
pnpm install --frozen-lockfile
- name: Execute tests
run: |
cd ./services/basket
pnpm test
sonarcloud:
name: SonarCloud
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis
- name: SonarCloud Scan
uses: SonarSource/sonarcloud-github-action@master
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Needed to get PR information, if any
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
publish:
runs-on: ubuntu-latest
needs: [build, test]
steps:
- name: Checkout code
uses: actions/checkout@master
- name: Login to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push
uses: docker/build-push-action@v4
with:
context: ./services/
file: ./services/basket/Dockerfile
push: true
tags: floriaaan/basket-service:latest
deploy:
runs-on: ubuntu-latest
needs: [build, test, publish]
steps:
- name: Install Kubectl
uses: azure/setup-kubectl@v3
- name: Setup Cluster Authentication
run: cat ${{ secrets.KUBECONFIG }} > /tmp/kubeconfig
- name: Deploying basket
run: kubectl --kubeconfig=/tmp/kubeconfig rollout restart deployment basket-service