From 63336312dbce6a4fc7a905d215214087e1eea3d2 Mon Sep 17 00:00:00 2001 From: Venelin Date: Tue, 10 Dec 2024 14:35:01 +0000 Subject: [PATCH] Expose ProviderServerFromInfo for use in GRPC tests --- .../tests/cross-tests/upgrade_state_check.go | 2 +- pkg/tests/pulcheck/pulcheck.go | 15 +++++++++++---- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/pkg/internal/tests/cross-tests/upgrade_state_check.go b/pkg/internal/tests/cross-tests/upgrade_state_check.go index 4a7bf1bed6..f20b966342 100644 --- a/pkg/internal/tests/cross-tests/upgrade_state_check.go +++ b/pkg/internal/tests/cross-tests/upgrade_state_check.go @@ -96,7 +96,7 @@ func runPulumiUpgrade(t T, res1, res2 *schema.Resource, config1, config2 cty.Val err := os.WriteFile(p, yamlProgram, 0o600) require.NoErrorf(t, err, "writing Pulumi.yaml") - handle, err := pulcheck.StartPulumiProvider(context.Background(), defProviderShortName, defProviderVer, prov2) + handle, err := pulcheck.StartPulumiProvider(context.Background(), prov2) require.NoError(t, err) pt.CurrentStack().Workspace().SetEnvVar("PULUMI_DEBUG_PROVIDERS", fmt.Sprintf("%s:%d", defProviderShortName, handle.Port)) pt.Up(t) diff --git a/pkg/tests/pulcheck/pulcheck.go b/pkg/tests/pulcheck/pulcheck.go index 7cb6b45b8c..ffe6b09c4f 100644 --- a/pkg/tests/pulcheck/pulcheck.go +++ b/pkg/tests/pulcheck/pulcheck.go @@ -86,8 +86,7 @@ func EnsureProviderValid(t T, tfp *schema.Provider) { require.NoError(t, tfp.InternalValidate()) } -// This is an experimental API. -func StartPulumiProvider(ctx context.Context, name, version string, providerInfo tfbridge.ProviderInfo) (*rpcutil.ServeHandle, error) { +func ProviderServerFromInfo(ctx context.Context, providerInfo tfbridge.ProviderInfo) (pulumirpc.ResourceProviderServer, error) { sink := pulumidiag.DefaultSink(io.Discard, io.Discard, pulumidiag.FormatOptions{ Color: colors.Never, }) @@ -102,7 +101,15 @@ func StartPulumiProvider(ctx context.Context, name, version string, providerInfo return nil, fmt.Errorf("json.MarshalIndent(schema, ..) failed: %w", err) } - prov := tfbridge.NewProvider(ctx, nil, name, version, providerInfo.P, providerInfo, schemaBytes) + return tfbridge.NewProvider(ctx, nil, providerInfo.Name, providerInfo.Version, providerInfo.P, providerInfo, schemaBytes), nil +} + +// This is an experimental API. +func StartPulumiProvider(ctx context.Context, providerInfo tfbridge.ProviderInfo) (*rpcutil.ServeHandle, error) { + prov, err := ProviderServerFromInfo(ctx, providerInfo) + if err != nil { + return nil, fmt.Errorf("ProviderServerFromInfo failed: %w", err) + } handle, err := rpcutil.ServeWithOptions(rpcutil.ServeOptions{ Init: func(srv *grpc.Server) error { @@ -227,7 +234,7 @@ func PulCheck(t T, bridgedProvider info.Provider, program string, opts ...opttes opttest.AttachProvider( bridgedProvider.Name, func(ctx context.Context, pt providers.PulumiTest) (providers.Port, error) { - handle, err := StartPulumiProvider(ctx, bridgedProvider.Name, bridgedProvider.Version, bridgedProvider) + handle, err := StartPulumiProvider(ctx, bridgedProvider) require.NoError(t, err) return providers.Port(handle.Port), nil },