2020-03-26 17:30:04 +00:00
|
|
|
// 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.
|
|
|
|
|
|
|
|
package codegen
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2020-06-17 21:02:45 +00:00
|
|
|
const codeFence = "```"
|
2020-03-26 17:30:04 +00:00
|
|
|
|
2020-06-18 19:32:15 +00:00
|
|
|
func TestFilterExamples(t *testing.T) {
|
2022-03-04 08:17:41 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2020-03-26 17:30:04 +00:00
|
|
|
tsCodeSnippet := `### Example 1
|
|
|
|
` + codeFence + `typescript
|
|
|
|
import * as path from path;
|
|
|
|
|
|
|
|
console.log("I am a console log statement in ts.");
|
|
|
|
` + codeFence
|
|
|
|
|
|
|
|
goCodeSnippet := `\n` + codeFence + `go
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
func fakeFunc() {
|
|
|
|
fmt.Print("Hi, I am a fake func!")
|
|
|
|
}
|
|
|
|
` + codeFence
|
|
|
|
|
|
|
|
leadingDescription := "This is a leading description for this resource."
|
|
|
|
exampleShortCode := `{{% example %}}` + tsCodeSnippet + "\n" + goCodeSnippet + `{{% /example %}}`
|
|
|
|
description := leadingDescription + `
|
|
|
|
{{% examples %}}` + exampleShortCode + `
|
|
|
|
{{% /examples %}}`
|
|
|
|
|
|
|
|
t.Run("ContainsRelevantCodeSnippet", func(t *testing.T) {
|
2022-03-04 08:17:41 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2020-06-18 19:32:15 +00:00
|
|
|
strippedDescription := FilterExamples(description, "typescript")
|
2020-03-26 17:30:04 +00:00
|
|
|
assert.NotEmpty(t, strippedDescription, "content could not be extracted")
|
|
|
|
assert.Contains(t, strippedDescription, leadingDescription, "expected to at least find the leading description")
|
|
|
|
})
|
|
|
|
|
|
|
|
// The above description does not contain a Python code snippet and because
|
|
|
|
// the description contains only one Example without any Python code snippet,
|
|
|
|
// we should expect an empty string in this test.
|
|
|
|
t.Run("DoesNotContainRelevantSnippet", func(t *testing.T) {
|
2022-03-04 08:17:41 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2020-06-18 19:32:15 +00:00
|
|
|
strippedDescription := FilterExamples(description, "python")
|
2020-03-26 17:30:04 +00:00
|
|
|
assert.Contains(t, strippedDescription, leadingDescription, "expected to at least find the leading description")
|
|
|
|
// Should not contain any examples sections.
|
|
|
|
assert.NotContains(t, strippedDescription, "### ", "expected to not have any examples but found at least one")
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2020-06-18 19:32:15 +00:00
|
|
|
func TestTestFilterExamplesFromMultipleExampleSections(t *testing.T) {
|
2022-03-04 08:17:41 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2020-03-26 17:30:04 +00:00
|
|
|
tsCodeSnippet := codeFence + `typescript
|
|
|
|
import * as path from path;
|
|
|
|
|
|
|
|
console.log("I am a console log statement in ts.");
|
|
|
|
` + codeFence
|
|
|
|
|
|
|
|
goCodeSnippet := codeFence + `go
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
func fakeFunc() {
|
|
|
|
fmt.Print("Hi, I am a fake func!")
|
|
|
|
}
|
|
|
|
` + codeFence
|
|
|
|
|
|
|
|
example1 := `### Example 1
|
2020-06-17 21:02:45 +00:00
|
|
|
` + tsCodeSnippet + "\n" + goCodeSnippet
|
2020-03-26 17:30:04 +00:00
|
|
|
|
|
|
|
example2 := `### Example 2
|
2020-06-17 21:02:45 +00:00
|
|
|
` + tsCodeSnippet
|
2020-03-26 17:30:04 +00:00
|
|
|
|
|
|
|
example1ShortCode := `{{% example %}}` + "\n" + example1 + "\n" + `{{% /example %}}`
|
|
|
|
example2ShortCode := `{{% example %}}` + "\n" + example2 + "\n" + `{{% /example %}}`
|
|
|
|
description := `{{% examples %}}` + "\n" + example1ShortCode + "\n" + example2ShortCode + "\n" + `{{% /examples %}}`
|
|
|
|
|
|
|
|
t.Run("EveryExampleHasRelevantCodeSnippet", func(t *testing.T) {
|
2022-03-04 08:17:41 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2020-06-18 19:32:15 +00:00
|
|
|
strippedDescription := FilterExamples(description, "typescript")
|
2020-03-26 17:30:04 +00:00
|
|
|
assert.NotEmpty(t, strippedDescription, "content could not be extracted")
|
|
|
|
assert.Contains(t, strippedDescription, "Example 1", "expected Example 1 section")
|
|
|
|
assert.Contains(t, strippedDescription, "Example 2", "expected Example 2 section")
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("SomeExamplesHaveRelevantCodeSnippet", func(t *testing.T) {
|
2022-03-04 08:17:41 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2020-06-18 19:32:15 +00:00
|
|
|
strippedDescription := FilterExamples(description, "go")
|
2020-03-26 17:30:04 +00:00
|
|
|
assert.NotEmpty(t, strippedDescription, "content could not be extracted")
|
|
|
|
assert.Contains(t, strippedDescription, "Example 1", "expected Example 1 section")
|
|
|
|
assert.NotContains(t, strippedDescription, "Example 2",
|
|
|
|
"unexpected Example 2 section. section should have been excluded")
|
|
|
|
})
|
|
|
|
}
|