pulumi/pkg/codegen/go/doc_test.go

114 lines
3.4 KiB
Go
Raw Permalink Normal View History

// Copyright 2016-2020, Pulumi Corporation.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// Pulling out some of the repeated strings tokens into constants would harm readability, so we just ignore the
// goconst linter's warning.
//
sdk/go: Remove 'nolint' directives from package docs Go treats comments that match the following regex as directives. //[a-z0-9]+:[a-z0-9] Comments that are directives don't show in an entity's documentation. https://github.com/golang/go/commit/5a550b695117f07a4f2454039a4871250cd3ed09#diff-f56160fd9fcea272966a8a1d692ad9f49206fdd8dbcbfe384865a98cd9bc2749R165 Our code has `//nolint` directives that now show in the API Reference. This is because these directives are in one of the following forms, which don't get this special treatment. // nolint:foo //nolint: foo This change fixes all such directives found by the regex: `// nolint|//nolint: `. See bottom of commit for command used for the fix. Verification: Here's the output of `go doc` on some entities before and after this change. Before ``` % go doc github.com/pulumi/pulumi/sdk/v3/go/pulumi | head -n8 package pulumi // import "github.com/pulumi/pulumi/sdk/v3/go/pulumi" nolint: lll, interfacer nolint: lll, interfacer const EnvOrganization = "PULUMI_ORGANIZATION" ... var ErrPlugins = errors.New("pulumi: plugins requested") ``` After ``` % go doc github.com/pulumi/pulumi/sdk/v3/go/pulumi | head -n8 package pulumi // import "github.com/pulumi/pulumi/sdk/v3/go/pulumi" const EnvOrganization = "PULUMI_ORGANIZATION" ... var ErrPlugins = errors.New("pulumi: plugins requested") func BoolRef(v bool) *bool func Float64Ref(v float64) *float64 func IntRef(v int) *int func IsSecret(o Output) bool ``` Before ``` % go doc github.com/pulumi/pulumi/sdk/v3/go/pulumi URN_ package pulumi // import "github.com/pulumi/pulumi/sdk/v3/go/pulumi" func URN_(o string) ResourceOption URN_ is an optional URN of a previously-registered resource of this type to read from the engine. nolint: revive ``` After: ``` % go doc github.com/pulumi/pulumi/sdk/v3/go/pulumi URN_ package pulumi // import "github.com/pulumi/pulumi/sdk/v3/go/pulumi" func URN_(o string) ResourceOption URN_ is an optional URN of a previously-registered resource of this type to read from the engine. ``` Note that golangci-lint offers a 'nolintlint' linter that finds such miuses of nolint, but it also finds other issues so I've deferred that to a follow up PR. Resolves #11785 Related: https://github.com/golangci/golangci-lint/issues/892 [git-generate] FILES=$(mktemp) rg -l '// nolint|//nolint: ' | tee "$FILES" | xargs perl -p -i -e ' s|// nolint|//nolint|g; s|//nolint: |//nolint:|g; ' rg '.go$' < "$FILES" | xargs gofmt -w -s
2023-01-06 00:07:45 +00:00
//nolint:lll, goconst
package gen
import (
"fmt"
"testing"
"github.com/pulumi/pulumi/pkg/v3/codegen/schema"
"github.com/stretchr/testify/assert"
)
var testPackageSpec = schema.PackageSpec{
Name: "aws",
Version: "0.0.1",
Description: "A fake provider package used for testing.",
Meta: &schema.MetadataSpec{
ModuleFormat: "(.*)(?:/[^/]*)",
},
Types: map[string]schema.ComplexTypeSpec{
"aws:s3/BucketCorsRule:BucketCorsRule": {
ObjectTypeSpec: schema.ObjectTypeSpec{
Description: "The resource options object.",
Type: "object",
Properties: map[string]schema.PropertySpec{
"stringProp": {
Description: "A string prop.",
TypeSpec: schema.TypeSpec{
Type: "string",
},
},
},
},
},
},
Resources: map[string]schema.ResourceSpec{
"aws:s3/bucket:Bucket": {
InputProperties: map[string]schema.PropertySpec{
"corsRules": {
TypeSpec: schema.TypeSpec{
Ref: "#/types/aws:s3/BucketCorsRule:BucketCorsRule",
},
},
},
},
},
}
func getTestPackage(t *testing.T) *schema.Package {
t.Helper()
pkg, err := schema.ImportSpec(testPackageSpec, nil)
assert.NoError(t, err, "could not import the test package spec")
return pkg
}
func TestGetDocLinkForPulumiType(t *testing.T) {
t.Parallel()
pkg := getTestPackage(t)
d := DocLanguageHelper{}
t.Run("Generate_ResourceOptionsLink_Specified", func(t *testing.T) {
t.Parallel()
pkg.Language["go"] = GoPackageInfo{PulumiSDKVersion: 1}
expected := "https://pkg.go.dev/github.com/pulumi/pulumi/sdk/go/pulumi?tab=doc#ResourceOption"
link := d.GetDocLinkForPulumiType(pkg, "ResourceOption")
assert.Equal(t, expected, link)
pkg.Language["go"] = nil
})
t.Run("Generate_ResourceOptionsLink_Specified", func(t *testing.T) {
t.Parallel()
pkg.Language["go"] = GoPackageInfo{PulumiSDKVersion: 2}
expected := "https://pkg.go.dev/github.com/pulumi/pulumi/sdk/v2/go/pulumi?tab=doc#ResourceOption"
link := d.GetDocLinkForPulumiType(pkg, "ResourceOption")
assert.Equal(t, expected, link)
pkg.Language["go"] = nil
})
t.Run("Generate_ResourceOptionsLink_Unspecified", func(t *testing.T) {
t.Parallel()
expected := fmt.Sprintf("https://pkg.go.dev/github.com/pulumi/pulumi/sdk/%s/go/pulumi?tab=doc#ResourceOption", pulumiSDKVersion)
link := d.GetDocLinkForPulumiType(pkg, "ResourceOption")
assert.Equal(t, expected, link)
})
}
func TestGetDocLinkForResourceType(t *testing.T) {
t.Parallel()
pkg := getTestPackage(t)
d := DocLanguageHelper{}
expected := "https://pkg.go.dev/github.com/pulumi/pulumi-aws/sdk/go/aws/s3?tab=doc#Bucket"
link := d.GetDocLinkForResourceType(pkg, "s3", "Bucket")
assert.Equal(t, expected, link)
}