Skip to content

Latest commit

 

History

History
64 lines (48 loc) · 1.83 KB

README.md

File metadata and controls

64 lines (48 loc) · 1.83 KB

Validate DD Service

Validate a service.datadog.yaml metadata file using JSON Schema.

There are probably simpler ways for you to implement a Workflow that accomplishes most of what you need (e.g. just install and execute something like ajv). However, we created this Action to:

  • Support multiple services as ----delimited Yaml documents
  • Automate respecting the schema-version key

Example

on:
  pull_request:
    paths:
      - service.datadog.yaml

jobs:
  validate-dd-service:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
        with:
          sparse-checkout: service.datadog.yaml
          sparse-checkout-cone-mode: false
      - uses: freckle/validate-dd-service-action@v1

Inputs

  • path: Path to the file to validate. Default is service.datadog.yaml.
  • fail: Fail on any validation errors? Default is true.

Outputs

  • invalid-services: A JSON array of objects for any invalid services found. Each object has a name and errors key.

    For example,

    [
      {
        "name": "example-app-api",
        "errors": [
          "The property '#/links/0/url' of type null did not match the following type: string in schema 0afde55a-9ab5-543c-b02a-06065d9d613e#",
          "The property '#/links/1/url' of type null did not match the following type: string in schema 0afde55a-9ab5-543c-b02a-06065d9d613e#",
          "The property '#/integrations/pagerduty' of type object did not match the following type: string in schema 0afde55a-9ab5-543c-b02a-06065d9d613e"
        ]
      }
    ]

LICENSE | CHANGELOG