From 7cb52b1899df0f6fd5fd18f758317574720178bc Mon Sep 17 00:00:00 2001 From: Pearson Radu <62548051+pearsonradu@users.noreply.github.com> Date: Tue, 17 Oct 2023 08:32:36 -0400 Subject: [PATCH] add number modifier to default configuration Signed-off-by: Pearson Radu <62548051+pearsonradu@users.noreply.github.com> --- README.md | 16 +++++++++------- config.json | 1 + lib/builder.js | 2 ++ lib/render.js | 3 +++ package-lock.json | 4 ++-- package.json | 2 +- tests/expected-readme.first-execution.md | 2 ++ tests/expected-readme.last-section-text-below.md | 2 ++ tests/expected-readme.last-section.md | 2 ++ tests/expected-readme.md | 2 ++ tests/expected-schema.json | 11 +++++++++++ tests/test-readme.last-section-text-below.md | 2 ++ tests/test-readme.last-section.md | 2 ++ tests/test-readme.md | 2 ++ tests/test-schema.json | 11 +++++++++++ tests/test-values.yaml | 6 ++++++ 16 files changed, 60 insertions(+), 10 deletions(-) diff --git a/README.md b/README.md index 197f2a7..d09f32c 100644 --- a/README.md +++ b/README.md @@ -117,6 +117,7 @@ Currently supported modifiers: - `[array]` Indicates that the value of the parameter must be set to `[]`. - `[object]` Indicates that the value of the parameter must be set to `{}`. - `[string]` Indicates that the value of the parameter must be set to `""`. +- `[number]` Indicates that the value of the parameter must be set to a number (ex. `0`). - `[nullable]` Indicates that the parameter value can be set to `null`. - `[default: DEFAULT_VALUE]` Sets the default value to `DEFAULT_VALUE`. @@ -141,10 +142,10 @@ Custom configuration snippet: ... "modifiers": { "array": "array", - "object": "object" - "string": "string" - "nullable": "nullable", - "number": "number" + "object": "object", + "string": "string", + "number": "number", + "nullable": "nullable" }, ... } @@ -169,9 +170,10 @@ The configuration file has the following structure: }, "modifiers": { "array": "array", <-- Modifier that indicates an array type - "object": "object" <-- Modifier that indicates an object type - "string": "string" <-- Modifier that indicates a string type - "nullable": "nullable" <-- Modifier that indicates a parameter that can be set to null + "object": "object", <-- Modifier that indicates an object type + "string": "string", <-- Modifier that indicates a string type + "number": "number", <-- Modifier that indicates a number type + "nullable": "nullable" <-- Modifier that indicates a parameter that can be set to null }, "regexp": { "paramsSectionTitle": "Parameters" <-- Title of the parameters section to replace in the README.md diff --git a/config.json b/config.json index b2f956f..da4a282 100644 --- a/config.json +++ b/config.json @@ -14,6 +14,7 @@ "array": "array", "object": "object", "string": "string", + "number": "number", "nullable": "nullable", "default": "default" }, diff --git a/lib/builder.js b/lib/builder.js index 3757d83..3dd89f6 100644 --- a/lib/builder.js +++ b/lib/builder.js @@ -30,6 +30,8 @@ function applyModifiers(param, config) { case `${config.modifiers.string}`: param.value = '""'; break; + case `${config.modifiers.number}`: + break; case `${config.modifiers.nullable}`: // Do nothing since the nullable parameters must preserve its default value // unless another modifier is applied at the same time. In that case, the second diff --git a/lib/render.js b/lib/render.js index 5d8fe6e..fbbdafe 100644 --- a/lib/render.js +++ b/lib/render.js @@ -271,6 +271,9 @@ function renderOpenAPISchema(schemaFilePath, parametersList, config) { case `${config.modifiers.string}`: p.type = 'string'; break; + case `${config.modifiers.number}`: + p.type = 'number'; + break; default: break; } diff --git a/package-lock.json b/package-lock.json index 7ebf27d..fddf9b0 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@bitnami/readme-generator-for-helm", - "version": "2.6.1", + "version": "2.7.0", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "@bitnami/readme-generator-for-helm", - "version": "2.6.1", + "version": "2.7.0", "license": "Apache-2.0", "dependencies": { "commander": "^7.1.0", diff --git a/package.json b/package.json index cf86cbc..cd0047d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@bitnami/readme-generator-for-helm", - "version": "2.6.1", + "version": "2.7.0", "description": "Autogenerate READMEs tables and OpenAPI schemas for Helm Charts", "main": "index.js", "scripts": { diff --git a/tests/expected-readme.first-execution.md b/tests/expected-readme.first-execution.md index 6aa8059..a23fa6e 100644 --- a/tests/expected-readme.first-execution.md +++ b/tests/expected-readme.first-execution.md @@ -121,6 +121,7 @@ This description starts in a new line instead of the same line of description st | `serviceAccount.name` | Name of the created ServiceAccount | `""` | | `inventedArray` | Test parameter to check arrays | `["a","b"]` | | `arrayModifier` | Test parameter for modifier array | `[]` | +| `numberModifier` | Test parameter for modifier number | `0` | | `configuration` | haproxy configuration | `""` | | `jobs[0].nameOverride` | String to partially override jobs.names.fullname | `""` | | `jobs[0].fullnameOverride` | String to fully override jobs.names.fullname | `""` | @@ -137,6 +138,7 @@ This description starts in a new line instead of the same line of description st | `nullableNullStringWithValueChange` | Nullable null string. We apply string modifier that will change the type and value, but the schema will show `nullable: true`. | `""` | | `nullableNullArray` | Nullable null array. We apply array modifier that will change the type in the schema plus `nullable: true`. | `nil` | | `nullableNullString` | Nullable null string. We apply string modifier to avoid infering an object type. The null must be preverved as value. | `nil` | +| `nullableNullNumber` | Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value. | `nil` | | `nullableNotNull` | Nullable parameter with a non null value | `somestring` | | `nullableObject` | Nullable parameter with an object value | `{}` | | `nullableArray` | Nullable parameter with an array value | `[]` | diff --git a/tests/expected-readme.last-section-text-below.md b/tests/expected-readme.last-section-text-below.md index 15adea4..fe63254 100644 --- a/tests/expected-readme.last-section-text-below.md +++ b/tests/expected-readme.last-section-text-below.md @@ -159,6 +159,7 @@ This description starts in a new line instead of the same line of description st | `serviceAccount.name` | Name of the created ServiceAccount | `""` | | `inventedArray` | Test parameter to check arrays | `["a","b"]` | | `arrayModifier` | Test parameter for modifier array | `[]` | +| `numberModifier` | Test parameter for modifier number | `0` | | `configuration` | haproxy configuration | `""` | | `jobs[0].nameOverride` | String to partially override jobs.names.fullname | `""` | | `jobs[0].fullnameOverride` | String to fully override jobs.names.fullname | `""` | @@ -175,6 +176,7 @@ This description starts in a new line instead of the same line of description st | `nullableNullStringWithValueChange` | Nullable null string. We apply string modifier that will change the type and value, but the schema will show `nullable: true`. | `""` | | `nullableNullArray` | Nullable null array. We apply array modifier that will change the type in the schema plus `nullable: true`. | `nil` | | `nullableNullString` | Nullable null string. We apply string modifier to avoid infering an object type. The null must be preverved as value. | `nil` | +| `nullableNullNumber` | Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value. | `nil` | | `nullableNotNull` | Nullable parameter with a non null value | `somestring` | | `nullableObject` | Nullable parameter with an object value | `{}` | | `nullableArray` | Nullable parameter with an array value | `[]` | diff --git a/tests/expected-readme.last-section.md b/tests/expected-readme.last-section.md index 846918a..3e86e39 100644 --- a/tests/expected-readme.last-section.md +++ b/tests/expected-readme.last-section.md @@ -159,6 +159,7 @@ This description starts in a new line instead of the same line of description st | `serviceAccount.name` | Name of the created ServiceAccount | `""` | | `inventedArray` | Test parameter to check arrays | `["a","b"]` | | `arrayModifier` | Test parameter for modifier array | `[]` | +| `numberModifier` | Test parameter for modifier number | `0` | | `configuration` | haproxy configuration | `""` | | `jobs[0].nameOverride` | String to partially override jobs.names.fullname | `""` | | `jobs[0].fullnameOverride` | String to fully override jobs.names.fullname | `""` | @@ -175,6 +176,7 @@ This description starts in a new line instead of the same line of description st | `nullableNullStringWithValueChange` | Nullable null string. We apply string modifier that will change the type and value, but the schema will show `nullable: true`. | `""` | | `nullableNullArray` | Nullable null array. We apply array modifier that will change the type in the schema plus `nullable: true`. | `nil` | | `nullableNullString` | Nullable null string. We apply string modifier to avoid infering an object type. The null must be preverved as value. | `nil` | +| `nullableNullNumber` | Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value. | `nil` | | `nullableNotNull` | Nullable parameter with a non null value | `somestring` | | `nullableObject` | Nullable parameter with an object value | `{}` | | `nullableArray` | Nullable parameter with an array value | `[]` | diff --git a/tests/expected-readme.md b/tests/expected-readme.md index e5a2630..55b7c42 100644 --- a/tests/expected-readme.md +++ b/tests/expected-readme.md @@ -159,6 +159,7 @@ This description starts in a new line instead of the same line of description st | `serviceAccount.name` | Name of the created ServiceAccount | `""` | | `inventedArray` | Test parameter to check arrays | `["a","b"]` | | `arrayModifier` | Test parameter for modifier array | `[]` | +| `numberModifier` | Test parameter for modifier number | `0` | | `configuration` | haproxy configuration | `""` | | `jobs[0].nameOverride` | String to partially override jobs.names.fullname | `""` | | `jobs[0].fullnameOverride` | String to fully override jobs.names.fullname | `""` | @@ -175,6 +176,7 @@ This description starts in a new line instead of the same line of description st | `nullableNullStringWithValueChange` | Nullable null string. We apply string modifier that will change the type and value, but the schema will show `nullable: true`. | `""` | | `nullableNullArray` | Nullable null array. We apply array modifier that will change the type in the schema plus `nullable: true`. | `nil` | | `nullableNullString` | Nullable null string. We apply string modifier to avoid infering an object type. The null must be preverved as value. | `nil` | +| `nullableNullNumber` | Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value. | `nil` | | `nullableNotNull` | Nullable parameter with a non null value | `somestring` | | `nullableObject` | Nullable parameter with an object value | `{}` | | `nullableArray` | Nullable parameter with an array value | `[]` | diff --git a/tests/expected-schema.json b/tests/expected-schema.json index 443534a..83fde35 100644 --- a/tests/expected-schema.json +++ b/tests/expected-schema.json @@ -573,6 +573,11 @@ "type": "string" } }, + "numberModifier": { + "type": "number", + "description": "Test parameter for modifier number", + "default": 0 + }, "configuration": { "type": "string", "description": "haproxy configuration", @@ -689,6 +694,12 @@ "default": null, "nullable": true }, + "nullableNullNumber": { + "type": "number", + "description": "Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value.", + "default": null, + "nullable": true + }, "nullableNotNull": { "type": "string", "description": "Nullable parameter with a non null value", diff --git a/tests/test-readme.last-section-text-below.md b/tests/test-readme.last-section-text-below.md index 15adea4..fe63254 100644 --- a/tests/test-readme.last-section-text-below.md +++ b/tests/test-readme.last-section-text-below.md @@ -159,6 +159,7 @@ This description starts in a new line instead of the same line of description st | `serviceAccount.name` | Name of the created ServiceAccount | `""` | | `inventedArray` | Test parameter to check arrays | `["a","b"]` | | `arrayModifier` | Test parameter for modifier array | `[]` | +| `numberModifier` | Test parameter for modifier number | `0` | | `configuration` | haproxy configuration | `""` | | `jobs[0].nameOverride` | String to partially override jobs.names.fullname | `""` | | `jobs[0].fullnameOverride` | String to fully override jobs.names.fullname | `""` | @@ -175,6 +176,7 @@ This description starts in a new line instead of the same line of description st | `nullableNullStringWithValueChange` | Nullable null string. We apply string modifier that will change the type and value, but the schema will show `nullable: true`. | `""` | | `nullableNullArray` | Nullable null array. We apply array modifier that will change the type in the schema plus `nullable: true`. | `nil` | | `nullableNullString` | Nullable null string. We apply string modifier to avoid infering an object type. The null must be preverved as value. | `nil` | +| `nullableNullNumber` | Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value. | `nil` | | `nullableNotNull` | Nullable parameter with a non null value | `somestring` | | `nullableObject` | Nullable parameter with an object value | `{}` | | `nullableArray` | Nullable parameter with an array value | `[]` | diff --git a/tests/test-readme.last-section.md b/tests/test-readme.last-section.md index 846918a..3e86e39 100644 --- a/tests/test-readme.last-section.md +++ b/tests/test-readme.last-section.md @@ -159,6 +159,7 @@ This description starts in a new line instead of the same line of description st | `serviceAccount.name` | Name of the created ServiceAccount | `""` | | `inventedArray` | Test parameter to check arrays | `["a","b"]` | | `arrayModifier` | Test parameter for modifier array | `[]` | +| `numberModifier` | Test parameter for modifier number | `0` | | `configuration` | haproxy configuration | `""` | | `jobs[0].nameOverride` | String to partially override jobs.names.fullname | `""` | | `jobs[0].fullnameOverride` | String to fully override jobs.names.fullname | `""` | @@ -175,6 +176,7 @@ This description starts in a new line instead of the same line of description st | `nullableNullStringWithValueChange` | Nullable null string. We apply string modifier that will change the type and value, but the schema will show `nullable: true`. | `""` | | `nullableNullArray` | Nullable null array. We apply array modifier that will change the type in the schema plus `nullable: true`. | `nil` | | `nullableNullString` | Nullable null string. We apply string modifier to avoid infering an object type. The null must be preverved as value. | `nil` | +| `nullableNullNumber` | Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value. | `nil` | | `nullableNotNull` | Nullable parameter with a non null value | `somestring` | | `nullableObject` | Nullable parameter with an object value | `{}` | | `nullableArray` | Nullable parameter with an array value | `[]` | diff --git a/tests/test-readme.md b/tests/test-readme.md index e5a2630..55b7c42 100644 --- a/tests/test-readme.md +++ b/tests/test-readme.md @@ -159,6 +159,7 @@ This description starts in a new line instead of the same line of description st | `serviceAccount.name` | Name of the created ServiceAccount | `""` | | `inventedArray` | Test parameter to check arrays | `["a","b"]` | | `arrayModifier` | Test parameter for modifier array | `[]` | +| `numberModifier` | Test parameter for modifier number | `0` | | `configuration` | haproxy configuration | `""` | | `jobs[0].nameOverride` | String to partially override jobs.names.fullname | `""` | | `jobs[0].fullnameOverride` | String to fully override jobs.names.fullname | `""` | @@ -175,6 +176,7 @@ This description starts in a new line instead of the same line of description st | `nullableNullStringWithValueChange` | Nullable null string. We apply string modifier that will change the type and value, but the schema will show `nullable: true`. | `""` | | `nullableNullArray` | Nullable null array. We apply array modifier that will change the type in the schema plus `nullable: true`. | `nil` | | `nullableNullString` | Nullable null string. We apply string modifier to avoid infering an object type. The null must be preverved as value. | `nil` | +| `nullableNullNumber` | Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value. | `nil` | | `nullableNotNull` | Nullable parameter with a non null value | `somestring` | | `nullableObject` | Nullable parameter with an object value | `{}` | | `nullableArray` | Nullable parameter with an array value | `[]` | diff --git a/tests/test-schema.json b/tests/test-schema.json index 443534a..83fde35 100644 --- a/tests/test-schema.json +++ b/tests/test-schema.json @@ -573,6 +573,11 @@ "type": "string" } }, + "numberModifier": { + "type": "number", + "description": "Test parameter for modifier number", + "default": 0 + }, "configuration": { "type": "string", "description": "haproxy configuration", @@ -689,6 +694,12 @@ "default": null, "nullable": true }, + "nullableNullNumber": { + "type": "number", + "description": "Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value.", + "default": null, + "nullable": true + }, "nullableNotNull": { "type": "string", "description": "Nullable parameter with a non null value", diff --git a/tests/test-values.yaml b/tests/test-values.yaml index f2238a9..919a187 100644 --- a/tests/test-values.yaml +++ b/tests/test-values.yaml @@ -459,6 +459,10 @@ arrayModifier: - a - b +## Invented parameter to test number modifier +## @param numberModifier [number] Test parameter for modifier number +numberModifier: 0 + ## @param configuration [string] haproxy configuration ## configuration: | @@ -521,6 +525,8 @@ nullableNullStringWithValueChange: null nullableNullArray: null ## @param nullableNullString [string,nullable] Nullable null string. We apply string modifier to avoid infering an object type. The null must be preverved as value. nullableNullString: null +## @param nullableNullNumber [number,nullable] Nullable null number. We apply number modifier to avoid infering an object type. The null must be preverved as value. +nullableNullNumber: null ## @param nullableNotNull [nullable] Nullable parameter with a non null value nullableNotNull: somestring ## @param nullableObject [nullable] Nullable parameter with an object value