Add JSON schema generation for kubeconform CRD validation
ci/woodpecker/pr/kubeconform Pipeline failed
ci/woodpecker/pr/pre-commit Pipeline was successful

- ci/generate-schemas.sh extracts schemas from live cluster CRDs via kubectl
- Generated schemas committed to schemas/ for CI use
- Run `make schemas` to regenerate after CRD or K8s version changes
- validate-apps.sh and validate-clusters.sh check local schemas first
- Remove all kubeconform skip lists — all resource types now have schemas
This commit is contained in:
2026-06-28 16:53:11 +10:00
parent cfca1e5278
commit 423287ff3f
264 changed files with 142908 additions and 3 deletions
@@ -0,0 +1,211 @@
{
"$schema": "http://json-schema.org/draft-07/schema#",
"properties": {
"apiVersion": {
"type": "string"
},
"kind": {
"type": "string"
},
"metadata": {
"type": "object"
},
"spec": {
"properties": {
"clusterName": {
"nullable": true,
"type": "string"
},
"template": {
"properties": {
"spec": {
"properties": {
"acceleratedNetworking": {
"type": "boolean"
},
"availabilitySet": {
"nullable": true,
"type": "string"
},
"availabilityZone": {
"nullable": true,
"type": "string"
},
"clientId": {
"nullable": true,
"type": "string"
},
"clientSecret": {
"nullable": true,
"type": "string"
},
"common": {
"properties": {
"cloudCredentialSecretName": {
"maxLength": 317,
"nullable": true,
"type": "string"
},
"labels": {
"additionalProperties": {
"type": "string"
},
"nullable": true,
"type": "object"
},
"taints": {
"items": {
"properties": {
"effect": {
"type": "string"
},
"key": {
"type": "string"
},
"timeAdded": {
"format": "date-time",
"type": "string"
},
"value": {
"type": "string"
}
},
"required": [
"effect",
"key"
],
"type": "object"
},
"nullable": true,
"type": "array"
}
},
"type": "object"
},
"customData": {
"nullable": true,
"type": "string"
},
"diskSize": {
"nullable": true,
"type": "string"
},
"dns": {
"nullable": true,
"type": "string"
},
"dockerPort": {
"nullable": true,
"type": "string"
},
"enablePublicIpStandardSku": {
"type": "boolean"
},
"environment": {
"nullable": true,
"type": "string"
},
"faultDomainCount": {
"nullable": true,
"type": "string"
},
"image": {
"nullable": true,
"type": "string"
},
"location": {
"nullable": true,
"type": "string"
},
"managedDisks": {
"type": "boolean"
},
"noPublicIp": {
"type": "boolean"
},
"nsg": {
"nullable": true,
"type": "string"
},
"openPort": {
"items": {
"nullable": true,
"type": "string"
},
"nullable": true,
"type": "array"
},
"plan": {
"nullable": true,
"type": "string"
},
"privateIpAddress": {
"nullable": true,
"type": "string"
},
"providerID": {
"nullable": true,
"type": "string"
},
"resourceGroup": {
"nullable": true,
"type": "string"
},
"size": {
"nullable": true,
"type": "string"
},
"sshUser": {
"nullable": true,
"type": "string"
},
"staticPublicIp": {
"type": "boolean"
},
"storageType": {
"nullable": true,
"type": "string"
},
"subnet": {
"nullable": true,
"type": "string"
},
"subnetPrefix": {
"nullable": true,
"type": "string"
},
"subscriptionId": {
"nullable": true,
"type": "string"
},
"tags": {
"nullable": true,
"type": "string"
},
"tenantId": {
"nullable": true,
"type": "string"
},
"updateDomainCount": {
"nullable": true,
"type": "string"
},
"usePrivateIp": {
"type": "boolean"
},
"vnet": {
"nullable": true,
"type": "string"
}
},
"type": "object"
}
},
"type": "object"
}
},
"type": "object"
}
},
"type": "object"
}