name: Azure Static Web Apps CI/CD on: push: branches: - main paths: - "website/**" - "themes/**" workflow_dispatch: permissions: id-token: write contents: read jobs: build_and_deploy: runs-on: ubuntu-latest name: Build and Deploy steps: - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 with: submodules: true persist-credentials: false - name: Install Go uses: actions/setup-go@0a12ed9d6a96ab950c8f026ed9f722fe0da7ef32 with: go-version: 1.21 cache-dependency-path: src/go.sum - uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b with: node-version: 20.9.0 # Create Kind cluster to have a Kubernetes context for cloud-native-azure theme # Images are defined on every Kind release # See https://github.com/kubernetes-sigs/kind/releases - name: Create k8s v1.23 Kind Cluster uses: helm/kind-action@0025e74a8c7512023d06dc019c617aa3cf561fde with: node_image: kindest/node:v1.23.4@sha256:0e34f0d0fd448aa2f2819cfd74e99fe5793a6e4938b328f657c8e3f81ee0dfb9 cluster_name: posh - name: Create Kubernetes namespace run: | kubectl create ns demo - name: Set default Kubernetes namespace run: | kubectl config set-context posh --namespace demo - uses: azure/login@6c251865b4e6290e7b78be643ea2d005bc51f69a with: creds: ${{ secrets.AZURE_CREDENTIALS }} - name: Build oh-my-posh 🔧 run: | cd src go build -o ./bin/oh-my-posh cd .. - name: Render themes 🎨 run: | export PATH="$PWD/src/bin:$PATH" cd website npm install npm run themes cd .. - name: Build Docs And Deploy 🚀 id: builddeploy uses: Azure/static-web-apps-deploy@1a947af9992250f3bc2e68ad0754c0b0c11566c9 with: azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_ASHY_MEADOW_063E9BA03 }} repo_token: ${{ secrets.GITHUB_TOKEN }} # Used for Github integrations (i.e. PR comments) action: "upload" ###### Repository/Build Configurations - These values can be configured to match your app requirements. ###### # For more information regarding Static Web App workflow configurations, please visit: https://aka.ms/swaworkflowconfig app_location: "/website" # App source code path api_location: "/website/api" # Api source code path - optional output_location: "build" # Built app content directory - optional