123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- ---
- # CI workflow used to regenerate `integrations/integrations.js` and accompanying documentation when relevant source files are changed.
- name: Generate Integrations
- on:
- push:
- branches:
- - master
- paths: # If any of these files change, we need to regenerate integrations.js.
- - 'src/collectors/**/metadata.yaml'
- - 'src/go/plugin/**/metadata.yaml'
- - 'src/exporting/**/metadata.yaml'
- - 'src/health/notifications/**/metadata.yaml'
- - 'integrations/templates/**'
- - 'integrations/categories.yaml'
- - 'integrations/deploy.yaml'
- - 'integrations/cloud-notifications/metadata.yaml'
- - 'integrations/cloud-authentication/metadata.yaml'
- - 'integrations/gen_integrations.py'
- workflow_dispatch: null
- concurrency: # This keeps multiple instances of the job from running concurrently for the same ref.
- group: integrations-${{ github.ref }}
- cancel-in-progress: true
- jobs:
- generate-integrations:
- name: Generate Integrations
- runs-on: ubuntu-latest
- if: github.repository == 'netdata/netdata'
- steps:
- - name: Checkout Agent
- id: checkout-agent
- uses: actions/checkout@v4
- with:
- fetch-depth: 1
- submodules: recursive
- - name: Prepare Dependencies
- id: prep-deps
- run: |
- sudo apt-get install python3-venv
- python3 -m venv ./virtualenv
- source ./virtualenv/bin/activate
- ./integrations/pip.sh
- - name: Generate Integrations
- id: generate
- run: |
- source ./virtualenv/bin/activate
- python3 integrations/gen_integrations.py
- - name: Generate Integrations Documentation
- id: generate-integrations-documentation
- run: |
- python3 integrations/gen_docs_integrations.py
- - name: Generate src/collectors/COLLECTORS.md
- id: generate-collectors-md
- run: |
- python3 integrations/gen_doc_collector_page.py
- - name: Clean Up Temporary Data
- id: clean
- run: rm -rf go.d.plugin virtualenv integrations/integrations.js integrations/integrations.json
- - name: Create PR
- id: create-pr
- uses: peter-evans/create-pull-request@v7
- with:
- token: ${{ secrets.NETDATABOT_GITHUB_TOKEN }}
- commit-message: Regenerate integrations docs
- branch: integrations-regen
- title: Regenerate integrations docs
- labels: integrations-update
- body: |
- Regenerate the integrations docs based on the
- latest metadata yaml code.
- This PR was auto-generated by
- `.github/workflows/generate-integrations.yml`.
- - name: Failure Notification
- uses: rtCamp/action-slack-notify@v2
- env:
- SLACK_COLOR: 'danger'
- SLACK_FOOTER: ''
- SLACK_ICON_EMOJI: ':github-actions:'
- SLACK_TITLE: 'Integrations regeneration failed:'
- SLACK_USERNAME: 'GitHub Actions'
- SLACK_MESSAGE: |-
- ${{ github.repository }}: Failed to create PR rebuilding integrations.js
- Checkout Agent: ${{ steps.checkout-agent.outcome }}
- Prep python env and deps: ${{ steps.prep-deps.outcome }}
- Generate Integrations: ${{ steps.generate.outcome }}
- Generate Integrations Documentation: ${{ steps.generate-integrations-documentation.outcome }}
- Generate src/collectors/COLLECTORS.md: ${{ steps.generate-collectors-md.outcome }}
- Clean Up Temporary Data: ${{ steps.clean.outcome }}
- Create PR: ${{ steps.create-pr.outcome }}
- SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK_URL }}
- if: >-
- ${{
- failure()
- && startsWith(github.ref, 'refs/heads/master')
- && github.repository == 'netdata/netdata'
- }}
|