Skip to content

Commit

Permalink
fix: Fix documentation and verification regarding name for named valu…
Browse files Browse the repository at this point in the history
…es classes
  • Loading branch information
Vampire committed Aug 27, 2024
1 parent 9e17622 commit 2b47067
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 4 deletions.
13 changes: 13 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,19 @@ inputs:
...
```

You can also optionally define `name` which is a hint for code generators what name can be used as class name.

```yaml
...
inputs:
fetch-depth:
type: integer
name: Amount
named-values:
infinite: 0
...
```

### Float

A number with a fractional component.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@ import it.krzeminski.githubactionstyping.parsing.ApiItem
import it.krzeminski.githubactionstyping.validation.ItemValidationResult

fun ApiItem.validateInteger(): ItemValidationResult {
if (this.name != null) {
return ItemValidationResult.Invalid("'name' is not allowed for this type.")
if ((this.namedValues == null) && (this.name != null)) {
return ItemValidationResult.Invalid("'name' is only allowed for this type when also having 'named-values'.")
}
if (this.allowedValues != null) {
return ItemValidationResult.Invalid("'allowed-values' is not allowed for this type.")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,15 @@ class ManifestValidationTest : FunSpec({
"string-input" to ApiItem(type = "string"),
"boolean-input" to ApiItem(type = "boolean"),
"integer-input" to ApiItem(type = "integer"),
"integer-with-named-values-input" to ApiItem(type = "integer", namedValues = mapOf("foo" to 1, "bar" to 2)),
"integer-with-named-values-input" to ApiItem(
type = "integer",
namedValues = mapOf("foo" to 1, "bar" to 2)
),
"integer-with-named-values-and-custom-item-name-input" to ApiItem(
type = "integer",
name = "SomeItemName",
namedValues = mapOf("foo" to 1, "bar" to 2)
),
"float-input" to ApiItem(type = "float"),
),
)
Expand Down Expand Up @@ -496,7 +504,7 @@ class ManifestValidationTest : FunSpec({
inputs = mapOf(
"string-input" to ItemValidationResult.Invalid("'name' is not allowed for this type."),
"boolean-input" to ItemValidationResult.Invalid("'name' is not allowed for this type."),
"integer-input" to ItemValidationResult.Invalid("'name' is not allowed for this type."),
"integer-input" to ItemValidationResult.Invalid("'name' is only allowed for this type when also having 'named-values'."),
"float-input" to ItemValidationResult.Invalid("'name' is not allowed for this type."),
"list-input" to ItemValidationResult.Invalid("'name' is not allowed for this type."),
),
Expand Down

0 comments on commit 2b47067

Please sign in to comment.