Fix Azure Function Node.js GitHub Actions Windows workflow
When deploying Node.js-based Azure Functions using GitHub Actions, you might face an issue with the Windows workflow. In the latest template, there is an issue in the build step where the actions/upload-artifact
action fails to upload the artifact due to too many files. The problem is caused by the node_modules
folder, which contains many files (even for a starter Azure Function project).
Another issue I spotted is that if the build step is successful, the deployment job will deploy all the dependencies (including the development dependencies) to the Azure Function App. Deploying the development dependencies is not recommended as it increases the deployment size and should not be required to run your functions.
Fix the build artifact issue
To fix the issue, you must exclude the node_modules
folder from the artifact upload and install an npm during the deployment. You can do this using the ignore pattern in the actions/upload-artifact
action.
- name: Upload artifact for deployment job uses: actions/upload-artifact@v4 with: name: node-app path: | . !./src # Exclude the source code (optional) !./node_modules # Exclude the node_modules folder
Fix the deployment dependencies issue
To fix the deployment dependencies issue, you must install only the production dependencies during the deployment. You can use the --omit=dev
flag in the npm install
command. Add the following step to the deployment job after the actions/download-artifact
action to install the production dependencies.
- name: "Install production dependencies" shell: pwsh run: | pushd './${{ env.AZURE_FUNCTIONAPP_PACKAGE_PATH }}' npm i --omit=dev popd
The complete updated workflow
Here is the complete updated workflow with the above fixes.
name: Build and deploy Node.js project to Azure Function App
on: push: branches: - main workflow_dispatch:
env: AZURE_FUNCTIONAPP_PACKAGE_PATH: "." NODE_VERSION: "20.x"
jobs: build: runs-on: windows-latest steps: - name: "Checkout GitHub Action" uses: actions/checkout@v4
- name: Setup Node ${{ env.NODE_VERSION }} Environment uses: actions/setup-node@v3 with: node-version: ${{ env.NODE_VERSION }}
- name: "Resolve Project Dependencies Using Npm" shell: pwsh run: | pushd './${{ env.AZURE_FUNCTIONAPP_PACKAGE_PATH }}' npm install npm run build --if-present npm run test --if-present popd
- name: Upload artifact for deployment job uses: actions/upload-artifact@v4 with: name: node-app path: | . !./src # Exclude the source code (optional) !./node_modules # Exclude the node_modules folder
deploy: runs-on: windows-latest needs: build environment: name: "Production" url: ${{ steps.deploy-to-webapp.outputs.webapp-url }} permissions: id-token: write #This is required for requesting the JWT
steps: - name: Download artifact from build job uses: actions/download-artifact@v4 with: name: node-app
- name: "Resolve Project Dependencies Using Npm" shell: pwsh run: | pushd './${{ env.AZURE_FUNCTIONAPP_PACKAGE_PATH }}' npm i --omit=dev popd
- name: Login to Azure uses: azure/login@v2 with: client-id: ${{ secrets.<client-id> }} tenant-id: ${{ secrets.<tenant-id> }} subscription-id: ${{ secrets.<subscription-id> }}
- name: "Run Azure Functions Action" uses: Azure/functions-action@v1 id: fa with: app-name: "to-delete-function" slot-name: "Production" package: ${{ env.AZURE_FUNCTIONAPP_PACKAGE_PATH }}
Related articles
Breaking changes in the GitHub upload-artifact action
Learn about the recent GitHub `actions/upload-artifact` update that excludes hidden files by default, impacting workflows.
Integrating Azure Functions into your Astro site
Learn how to seamlessly integrate Azure Functions into your Astro site for enhanced serverless capabilities and streamlined deployment.
Which service? Netlify vs Vercel vs Azure Static Web App
Report issues or make changes on GitHub
Found a typo or issue in this article? Visit the GitHub repository to make changes or submit a bug report.
Comments
Let's build together
Manage content in VS Code
Present from VS Code