From 3b9c80301f72d66b1fe485d34d8a526205b230dd Mon Sep 17 00:00:00 2001 From: Brett DeFoy Date: Mon, 22 May 2023 12:21:08 -0700 Subject: [PATCH 1/2] WIP rename rule --- .../get-collection-only-has-value-nextlink.md | 8 ++++--- docs/rules.md | 2 +- .../rulesets/generated/spectral/az-arm.js | 2 +- packages/rulesets/src/spectral/az-arm.ts | 9 ++++---- .../get-collection-only-has-value-nextlink.ts | 17 -------------- .../get-collection-response-schema.ts | 23 +++++++++++++++++++ ...collection-only-has-value-nextlink.test.ts | 10 ++++---- 7 files changed, 40 insertions(+), 31 deletions(-) delete mode 100644 packages/rulesets/src/spectral/functions/get-collection-only-has-value-nextlink.ts create mode 100644 packages/rulesets/src/spectral/functions/get-collection-response-schema.ts diff --git a/docs/get-collection-only-has-value-nextlink.md b/docs/get-collection-only-has-value-nextlink.md index 5cb08bd9c..36ec376ed 100644 --- a/docs/get-collection-only-has-value-nextlink.md +++ b/docs/get-collection-only-has-value-nextlink.md @@ -1,4 +1,4 @@ -# GetCollectionOnlyHasValueAndNextLink +# GetCollectionResponseSchema ## Category @@ -18,8 +18,10 @@ List GET endpoints (collection GET) must only have `value` and `nextLink` in `pr ## Why the rule is important -This rule is important to retain consistency between ARM APIs. Furthermore, not adhering to this rule will cause issues with Azure Resource Graph (ARG) integration. +This rule is important to retain consistency between ARM APIs. Furthermore, not adhering to this rule will cause issues +with Azure Resource Graph (ARG) integration. ## How to fix the violation -Under `properties` in the schema for GET endpoints, ensure the fields `value` and `nextLink` are present, and no other fields are present. +Under `properties` in the schema for GET endpoints, ensure the fields `value` and `nextLink` are present, and no other +fields are present. diff --git a/docs/rules.md b/docs/rules.md index d12d646d2..1529e2edb 100644 --- a/docs/rules.md +++ b/docs/rules.md @@ -330,7 +330,7 @@ Instead, consider defining a `body` parameter with `type: string, format: binary Please refer to [formdata.md](./formdata.md) for details. -### GetCollectionOnlyHasValueAndNextLink +### GetCollectionResponseSchema List GET endpoints (collection GET) must only have `value` and `nextLink` in `properties`. diff --git a/packages/rulesets/generated/spectral/az-arm.js b/packages/rulesets/generated/spectral/az-arm.js index e11a07721..3159882af 100644 --- a/packages/rulesets/generated/spectral/az-arm.js +++ b/packages/rulesets/generated/spectral/az-arm.js @@ -2682,7 +2682,7 @@ const ruleset = { function: falsy, }, }, - GetCollectionOnlyHasValueAndNextLink: { + GetCollectionResponseSchema: { description: "Get endpoints for collections of resources must only have the `value` and `nextLink` properties in their model.", message: "{{description}}", severity: "error", diff --git a/packages/rulesets/src/spectral/az-arm.ts b/packages/rulesets/src/spectral/az-arm.ts index b74911bab..bd62c1574 100644 --- a/packages/rulesets/src/spectral/az-arm.ts +++ b/packages/rulesets/src/spectral/az-arm.ts @@ -8,7 +8,7 @@ import collectionObjectPropertiesNaming from "./functions/collection-object-prop import { consistentPatchProperties } from "./functions/consistent-patch-properties" import { DeleteResponseCodes } from "./functions/delete-response-codes" import { longRunningResponseStatusCodeArm } from "./functions/Extensions/long-running-response-status-code" -import { getCollectionOnlyHasValueAndNextLink } from "./functions/get-collection-only-has-value-nextlink" +import { getCollectionResponseSchema } from "./functions/get-collection-response-schema" import hasApiVersionParameter from "./functions/has-api-version-parameter" import hasheader from "./functions/has-header" import httpsSupportedScheme from "./functions/https-supported-scheme" @@ -290,15 +290,16 @@ const ruleset: any = { }, }, // RPC Codes: RPC-Get-V1-09, RPC-Arg-V1-01, RPC-Get-V1-06 - GetCollectionOnlyHasValueAndNextLink: { + GetCollectionResponseSchema: { description: "Get endpoints for collections of resources must only have the `value` and `nextLink` properties in their model.", message: "{{description}}", severity: "error", resolved: true, formats: [oas2], - given: "$[paths,'x-ms-paths'][?(!@property.endsWith('}') && !@property.endsWith('operations'))][get].responses.200.schema.properties", + given: + "$[paths,'x-ms-paths'][?(!@property.endsWith('}') && @property.endsWith('s') && !@property.endsWith('operations'))][get].responses.200.schema.properties", then: { - function: getCollectionOnlyHasValueAndNextLink, + function: getCollectionResponseSchema, }, }, diff --git a/packages/rulesets/src/spectral/functions/get-collection-only-has-value-nextlink.ts b/packages/rulesets/src/spectral/functions/get-collection-only-has-value-nextlink.ts deleted file mode 100644 index 52311a442..000000000 --- a/packages/rulesets/src/spectral/functions/get-collection-only-has-value-nextlink.ts +++ /dev/null @@ -1,17 +0,0 @@ -// Verifies that collection get schemas have only the `value` and `nextLink` properties in their models. - -export const getCollectionOnlyHasValueAndNextLink = (properties: any, _opts: any, ctx: any) => { - if (!properties || typeof properties !== "object") { - return [] - } - const keys = Object.keys(properties) - - if (keys.length != 2 || !keys.includes("value") || !keys.includes("nextLink")) { - return [ - { - message: "Get endpoints for collections of resources must only have the `value` and `nextLink` properties in their model.", - }, - ] - } - return [] -} diff --git a/packages/rulesets/src/spectral/functions/get-collection-response-schema.ts b/packages/rulesets/src/spectral/functions/get-collection-response-schema.ts new file mode 100644 index 000000000..29db744c6 --- /dev/null +++ b/packages/rulesets/src/spectral/functions/get-collection-response-schema.ts @@ -0,0 +1,23 @@ +// Verifies that collection get schemas have only the `value` and `nextLink` properties in their models. + +const ALLOWED_KEYS = ["value", "nextLink"] +const ERROR_MESSAGE = "Get endpoints for collections of resources must only have the `value` and `nextLink` properties in their model." + +// TODO: might need to use something like getCollectionApiInfo() in arm-helper.ts +// TODO: can't call it this. there already is a rule fo this GetCollectionResponseSchema.ts + +export const getCollectionResponseSchema = (properties: any, _opts: any, ctx: any) => { + if (!properties || typeof properties !== "object") { + return [] + } + const keys = Object.keys(properties) + + if (keys.length > 2 || keys.some((key) => !ALLOWED_KEYS.includes(key))) { + return [ + { + message: ERROR_MESSAGE, + }, + ] + } + return [] +} diff --git a/packages/rulesets/src/spectral/test/get-collection-only-has-value-nextlink.test.ts b/packages/rulesets/src/spectral/test/get-collection-only-has-value-nextlink.test.ts index 75af0fe5a..cb6b3b535 100644 --- a/packages/rulesets/src/spectral/test/get-collection-only-has-value-nextlink.test.ts +++ b/packages/rulesets/src/spectral/test/get-collection-only-has-value-nextlink.test.ts @@ -4,11 +4,11 @@ import linterForRule from "./utils" let linter: Spectral beforeAll(async () => { - linter = await linterForRule("GetCollectionOnlyHasValueAndNextLink") + linter = await linterForRule("GetCollectionResponseSchema") return linter }) -test("GetCollectionOnlyHasValueAndNextLink should find no errors when get collection schema has only value and nextLink properties", () => { +test("GetCollectionResponseSchema should find no errors when get collection schema has only value and nextLink properties", () => { const myOpenApiDocument = { swagger: "2.0", paths: { @@ -66,7 +66,7 @@ test("GetCollectionOnlyHasValueAndNextLink should find no errors when get collec }) }) -test("GetCollectionOnlyHasValueAndNextLink should find errors when get collection schema has properties other than value and nextLink", () => { +test("GetCollectionResponseSchema should find errors when get collection schema has properties other than value and nextLink", () => { const myOpenApiDocument = { swagger: "2.0", paths: { @@ -131,7 +131,7 @@ test("GetCollectionOnlyHasValueAndNextLink should find errors when get collectio }) }) -test("GetCollectionOnlyHasValueAndNextLink should find errors when nextLink is missing", () => { +test("GetCollectionResponseSchema should find errors when nextLink is missing", () => { const myOpenApiDocument = { swagger: "2.0", paths: { @@ -188,7 +188,7 @@ test("GetCollectionOnlyHasValueAndNextLink should find errors when nextLink is m }) }) -test("GetCollectionOnlyHasValueAndNextLink should find errors when value is missing", () => { +test("GetCollectionResponseSchema should find errors when value is missing", () => { const myOpenApiDocument = { swagger: "2.0", paths: { From 015f1b00e2ed83e7cdf39a5bc8ddf5b6b8580e75 Mon Sep 17 00:00:00 2001 From: Brett DeFoy Date: Wed, 24 May 2023 10:53:17 -0700 Subject: [PATCH 2/2] Revert "WIP rename rule" This reverts commit 3b9c80301f72d66b1fe485d34d8a526205b230dd. --- .../get-collection-only-has-value-nextlink.md | 8 +++---- docs/rules.md | 2 +- .../rulesets/generated/spectral/az-arm.js | 2 +- packages/rulesets/src/spectral/az-arm.ts | 9 ++++---- .../get-collection-only-has-value-nextlink.ts | 17 ++++++++++++++ .../get-collection-response-schema.ts | 23 ------------------- ...collection-only-has-value-nextlink.test.ts | 10 ++++---- 7 files changed, 31 insertions(+), 40 deletions(-) create mode 100644 packages/rulesets/src/spectral/functions/get-collection-only-has-value-nextlink.ts delete mode 100644 packages/rulesets/src/spectral/functions/get-collection-response-schema.ts diff --git a/docs/get-collection-only-has-value-nextlink.md b/docs/get-collection-only-has-value-nextlink.md index 36ec376ed..5cb08bd9c 100644 --- a/docs/get-collection-only-has-value-nextlink.md +++ b/docs/get-collection-only-has-value-nextlink.md @@ -1,4 +1,4 @@ -# GetCollectionResponseSchema +# GetCollectionOnlyHasValueAndNextLink ## Category @@ -18,10 +18,8 @@ List GET endpoints (collection GET) must only have `value` and `nextLink` in `pr ## Why the rule is important -This rule is important to retain consistency between ARM APIs. Furthermore, not adhering to this rule will cause issues -with Azure Resource Graph (ARG) integration. +This rule is important to retain consistency between ARM APIs. Furthermore, not adhering to this rule will cause issues with Azure Resource Graph (ARG) integration. ## How to fix the violation -Under `properties` in the schema for GET endpoints, ensure the fields `value` and `nextLink` are present, and no other -fields are present. +Under `properties` in the schema for GET endpoints, ensure the fields `value` and `nextLink` are present, and no other fields are present. diff --git a/docs/rules.md b/docs/rules.md index 1529e2edb..d12d646d2 100644 --- a/docs/rules.md +++ b/docs/rules.md @@ -330,7 +330,7 @@ Instead, consider defining a `body` parameter with `type: string, format: binary Please refer to [formdata.md](./formdata.md) for details. -### GetCollectionResponseSchema +### GetCollectionOnlyHasValueAndNextLink List GET endpoints (collection GET) must only have `value` and `nextLink` in `properties`. diff --git a/packages/rulesets/generated/spectral/az-arm.js b/packages/rulesets/generated/spectral/az-arm.js index e6964dab2..75ccb022d 100644 --- a/packages/rulesets/generated/spectral/az-arm.js +++ b/packages/rulesets/generated/spectral/az-arm.js @@ -2714,7 +2714,7 @@ const ruleset = { function: falsy, }, }, - GetCollectionResponseSchema: { + GetCollectionOnlyHasValueAndNextLink: { description: "Get endpoints for collections of resources must only have the `value` and `nextLink` properties in their model.", message: "{{description}}", severity: "error", diff --git a/packages/rulesets/src/spectral/az-arm.ts b/packages/rulesets/src/spectral/az-arm.ts index c825388e4..3cf16af2e 100644 --- a/packages/rulesets/src/spectral/az-arm.ts +++ b/packages/rulesets/src/spectral/az-arm.ts @@ -8,7 +8,7 @@ import collectionObjectPropertiesNaming from "./functions/collection-object-prop import { consistentPatchProperties } from "./functions/consistent-patch-properties" import { DeleteResponseCodes } from "./functions/delete-response-codes" import { longRunningResponseStatusCodeArm } from "./functions/Extensions/long-running-response-status-code" -import { getCollectionResponseSchema } from "./functions/get-collection-response-schema" +import { getCollectionOnlyHasValueAndNextLink } from "./functions/get-collection-only-has-value-nextlink" import hasApiVersionParameter from "./functions/has-api-version-parameter" import hasheader from "./functions/has-header" import httpsSupportedScheme from "./functions/https-supported-scheme" @@ -305,16 +305,15 @@ const ruleset: any = { }, }, // RPC Codes: RPC-Get-V1-09, RPC-Arg-V1-01, RPC-Get-V1-06 - GetCollectionResponseSchema: { + GetCollectionOnlyHasValueAndNextLink: { description: "Get endpoints for collections of resources must only have the `value` and `nextLink` properties in their model.", message: "{{description}}", severity: "error", resolved: true, formats: [oas2], - given: - "$[paths,'x-ms-paths'][?(!@property.endsWith('}') && @property.endsWith('s') && !@property.endsWith('operations'))][get].responses.200.schema.properties", + given: "$[paths,'x-ms-paths'][?(!@property.endsWith('}') && !@property.endsWith('operations'))][get].responses.200.schema.properties", then: { - function: getCollectionResponseSchema, + function: getCollectionOnlyHasValueAndNextLink, }, }, diff --git a/packages/rulesets/src/spectral/functions/get-collection-only-has-value-nextlink.ts b/packages/rulesets/src/spectral/functions/get-collection-only-has-value-nextlink.ts new file mode 100644 index 000000000..52311a442 --- /dev/null +++ b/packages/rulesets/src/spectral/functions/get-collection-only-has-value-nextlink.ts @@ -0,0 +1,17 @@ +// Verifies that collection get schemas have only the `value` and `nextLink` properties in their models. + +export const getCollectionOnlyHasValueAndNextLink = (properties: any, _opts: any, ctx: any) => { + if (!properties || typeof properties !== "object") { + return [] + } + const keys = Object.keys(properties) + + if (keys.length != 2 || !keys.includes("value") || !keys.includes("nextLink")) { + return [ + { + message: "Get endpoints for collections of resources must only have the `value` and `nextLink` properties in their model.", + }, + ] + } + return [] +} diff --git a/packages/rulesets/src/spectral/functions/get-collection-response-schema.ts b/packages/rulesets/src/spectral/functions/get-collection-response-schema.ts deleted file mode 100644 index 29db744c6..000000000 --- a/packages/rulesets/src/spectral/functions/get-collection-response-schema.ts +++ /dev/null @@ -1,23 +0,0 @@ -// Verifies that collection get schemas have only the `value` and `nextLink` properties in their models. - -const ALLOWED_KEYS = ["value", "nextLink"] -const ERROR_MESSAGE = "Get endpoints for collections of resources must only have the `value` and `nextLink` properties in their model." - -// TODO: might need to use something like getCollectionApiInfo() in arm-helper.ts -// TODO: can't call it this. there already is a rule fo this GetCollectionResponseSchema.ts - -export const getCollectionResponseSchema = (properties: any, _opts: any, ctx: any) => { - if (!properties || typeof properties !== "object") { - return [] - } - const keys = Object.keys(properties) - - if (keys.length > 2 || keys.some((key) => !ALLOWED_KEYS.includes(key))) { - return [ - { - message: ERROR_MESSAGE, - }, - ] - } - return [] -} diff --git a/packages/rulesets/src/spectral/test/get-collection-only-has-value-nextlink.test.ts b/packages/rulesets/src/spectral/test/get-collection-only-has-value-nextlink.test.ts index cb6b3b535..75af0fe5a 100644 --- a/packages/rulesets/src/spectral/test/get-collection-only-has-value-nextlink.test.ts +++ b/packages/rulesets/src/spectral/test/get-collection-only-has-value-nextlink.test.ts @@ -4,11 +4,11 @@ import linterForRule from "./utils" let linter: Spectral beforeAll(async () => { - linter = await linterForRule("GetCollectionResponseSchema") + linter = await linterForRule("GetCollectionOnlyHasValueAndNextLink") return linter }) -test("GetCollectionResponseSchema should find no errors when get collection schema has only value and nextLink properties", () => { +test("GetCollectionOnlyHasValueAndNextLink should find no errors when get collection schema has only value and nextLink properties", () => { const myOpenApiDocument = { swagger: "2.0", paths: { @@ -66,7 +66,7 @@ test("GetCollectionResponseSchema should find no errors when get collection sche }) }) -test("GetCollectionResponseSchema should find errors when get collection schema has properties other than value and nextLink", () => { +test("GetCollectionOnlyHasValueAndNextLink should find errors when get collection schema has properties other than value and nextLink", () => { const myOpenApiDocument = { swagger: "2.0", paths: { @@ -131,7 +131,7 @@ test("GetCollectionResponseSchema should find errors when get collection schema }) }) -test("GetCollectionResponseSchema should find errors when nextLink is missing", () => { +test("GetCollectionOnlyHasValueAndNextLink should find errors when nextLink is missing", () => { const myOpenApiDocument = { swagger: "2.0", paths: { @@ -188,7 +188,7 @@ test("GetCollectionResponseSchema should find errors when nextLink is missing", }) }) -test("GetCollectionResponseSchema should find errors when value is missing", () => { +test("GetCollectionOnlyHasValueAndNextLink should find errors when value is missing", () => { const myOpenApiDocument = { swagger: "2.0", paths: {