-
Notifications
You must be signed in to change notification settings - Fork 44
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Get extra nested docs from schema map #1650
Conversation
I can see the docker diff in GH: pulumi/pulumi-docker@master...nested-configs-sample-schema. I believe that the corrections come from (downstream from the change): pulumi-terraform-bridge/pkg/tfgen/generate_schema.go Lines 567 to 573 in 6dc3163
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a big improvement, and I'm looking forward to getting this merged. I think we need to address one additional category of errors before merging.
@@ -98,8 +98,8 @@ func (*typeSchema) DefaultValue() (interface{}, error) { | |||
return nil, bridge.ErrSchemaDefaultValue | |||
} | |||
|
|||
func (*typeSchema) Description() string { | |||
panic("Description() should not be called during schema generation") | |||
func (s *typeSchema) Description() string { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nit: "s" not needed.
c1e2841
to
c69ab41
Compare
c69ab41
to
720d9bb
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A couple minuscule formatting nits. Otherwise LGTM!
member := func(mod string, mem string) tokens.ModuleMember { | ||
return tokens.ModuleMember("cloudflare" + ":" + mod + ":" + mem) | ||
} | ||
|
||
typ := func(mod string, typ string) tokens.Type { | ||
return tokens.Type(member(mod, typ)) | ||
} | ||
|
||
resource := func(mod string, res string) tokens.Type { | ||
fn := string(unicode.ToLower(rune(res[0]))) + res[1:] | ||
return typ(mod+"/"+fn, res) | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nit: There is a tfbridge.MakeResource(pkg, mod, res)
function which does this already.
}, | ||
"action_parameters": { | ||
Type: schema.TypeList, | ||
// MaxItems: 1, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
// MaxItems: 1, |
@@ -143,6 +154,8 @@ func assertHasSimpleObjectAttributes(t *testing.T, r shim.Resource) { | |||
assert.True(t, r.Schema().Get("c").Computed(), "c is computed") | |||
assert.True(t, r.Schema().Get("r").Required(), "r is required") | |||
assert.True(t, r.Schema().Get("co").Computed() && r.Schema().Get("co").Optional(), "co is computed and optional") | |||
assert.Equal(t, r.Schema().Get("desc").Description(), "I am a description") | |||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This pull request aims to improve accuracy for nested property docs descriptions.
It uses the SchemaMap to look up and read
Description
fields such as this one in the case where trying to obtain documentation formentityDocs
does not yield any results.The original impetus for this change was to address #1045, which is very specific to Config() fields. The Provider configuration docs are special-cased in the bridge and we do not have access to any
entityDocs
. Instead, we were reading in the TF schema's Description() field intorawdocs
when generating a top-level config variable. This did not persist into any nested fields on Configuration variables, hence this fix. But it turns out that we can catch quite a few more missing descriptions if we extend implementation across all nested fields (see stats below).As a side note - the Terraform Plugin Framework implements
Description()
in a way that respects and prioritizes descriptions that come from Markdown docs; forsdkv2
resources we still need to use, and prefer, our parsed-from-markdownentityDocs
descriptions. It would be interesting to see if we get improved docs for TFPF resources by not reading descriptions fromentityDocs
.It was also necessary to return an empty string from TFPF
typeSchema
so as not to cause a panic during schemagen on TFPF using providers. Open to improvements/suggestions here!This PR aims to be fully additive - we are not changing the way in which docs are generated; we only fill in missing docs.
Nevertheless, this PR does also seem to improve the correctness of nested docs where some description fields have been matched to the wrong input field.
Please see a new Docker schema generated against these changes
Quick stats:
Here is an AWS schema - you will want to pull that branch and look at the git diff to
master
locally.Quick stats:
This PR fixes #1045.