mirror of https://github.com/pulumi/pulumi.git
150 lines
4.0 KiB
Cheetah
150 lines
4.0 KiB
Cheetah
// Copyright 2016-{{ .Year }}, 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.
|
|
|
|
// Code generated by gen-pux-applyn; DO NOT EDIT.
|
|
|
|
//nolint:lll
|
|
package pulumix_test
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"reflect"
|
|
"strconv"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/internal"
|
|
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
|
|
"github.com/pulumi/pulumi/sdk/v3/go/pulumix"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
{{ range seq .Start .Stop -}}
|
|
{{ template "applyn_test" . }}
|
|
{{- end }}
|
|
|
|
{{/* applyn_test(int):
|
|
Generates tests for ApplyN functions with N parameters.
|
|
*/}}
|
|
{{ define "applyn_test" }}
|
|
{{ $name := printf "Apply%d" . -}}
|
|
{{ if eq . 1 -}}
|
|
{{ $name = "Apply" -}}
|
|
{{ end -}}
|
|
|
|
func Test{{ $name }}_simpleSuccess(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
out := pulumix.{{ $name }}[{{ range seq 1 . }}int,{{ end }}](
|
|
{{ range seq 1 . -}}
|
|
pulumix.Val[int]({{ . }}),
|
|
{{ end -}}
|
|
func({{ range seq 1 . }}i{{ . }} int,{{ end }}) []string {
|
|
return []string{
|
|
{{ range seq 1 . -}}
|
|
strconv.Itoa(i{{ . }}),
|
|
{{ end }}
|
|
}
|
|
},
|
|
)
|
|
|
|
val, known, secret, deps, err := internal.AwaitOutput(context.Background(), out)
|
|
require.NoError(t, err)
|
|
assert.True(t, known)
|
|
assert.False(t, secret)
|
|
assert.Empty(t, deps)
|
|
assert.Equal(t, []string{ {{- range seq 1 . -}}"{{ . }}",{{ end -}} }, val)
|
|
}
|
|
|
|
{{/* A single secret value turns the whole output into a secret. */}}
|
|
func Test{{ $name }}_secretValue(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
out := pulumix.{{ $name }}[{{ range seq 1 . }}int,{{ end }}](
|
|
{{ range seq 1 . -}}
|
|
{{ if eq . $ -}}
|
|
pulumix.Output[int]{
|
|
OutputState: internal.GetOutputState(pulumi.ToSecret({{ . }})),
|
|
},
|
|
{{ else -}}
|
|
pulumix.Val[int]({{ . }}),
|
|
{{ end -}}
|
|
{{ end -}}
|
|
func({{ range seq 1 . }}i{{ . }} int,{{ end }}) []string {
|
|
return []string{
|
|
{{ range seq 1 . -}}
|
|
strconv.Itoa(i{{ . }}),
|
|
{{ end }}
|
|
}
|
|
},
|
|
)
|
|
|
|
_, _, secret, _, err := internal.AwaitOutput(context.Background(), out)
|
|
require.NoError(t, err)
|
|
assert.True(t, secret)
|
|
}
|
|
|
|
func Test{{ $name }}Err_applyError(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
giveErr := errors.New("great sadness")
|
|
out := pulumix.{{ $name }}Err[{{ range seq 1 . }}int,{{ end }}](
|
|
{{ range seq 1 . -}}
|
|
pulumix.Val[int]({{ . }}),
|
|
{{ end -}}
|
|
func({{ range seq 1 . }}int,{{ end }}) (string, error) {
|
|
return "", giveErr
|
|
},
|
|
)
|
|
|
|
_, _, _, _, err := internal.AwaitOutput(context.Background(), out)
|
|
assert.ErrorIs(t, err, giveErr)
|
|
}
|
|
|
|
{{/* If an output fails, none of the consecutive outputs are waited on.
|
|
and the function is not called. */}}
|
|
func Test{{ $name }}_failedOutput(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
intType := reflect.TypeOf(0)
|
|
{{ range seq 1 . -}}
|
|
o{{ . }} := pulumix.Output[int]{OutputState: internal.NewOutputState(nil, intType)}
|
|
{{ end }}
|
|
|
|
{{ if gt . 1 }}// Reject the first output. Don't fill the others.{{ end }}
|
|
giveErr := errors.New("great sadness")
|
|
internal.RejectOutput(o1, giveErr)
|
|
|
|
out := pulumix.{{ $name }}[{{ range seq 1 . }}int,{{ end }}](
|
|
{{ range seq 1 . -}}o{{ . }},{{ end }}
|
|
func({{ range seq 1 . }}int,{{ end }}) string {
|
|
t.Errorf("applied function must not be called")
|
|
return ""
|
|
},
|
|
)
|
|
|
|
{{/* Because the outputs past the first are not filled,
|
|
awaiting on them will hang forever if the test fails.
|
|
Prevent that with a timeout. */}}
|
|
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
|
|
defer cancel()
|
|
|
|
_, _, _, _, err := internal.AwaitOutput(ctx, out)
|
|
assert.ErrorIs(t, err, giveErr)
|
|
}
|
|
|
|
{{ end }}
|