pulumi/changelog
Abhinav Gupta ef6036a336
sdk/go: Don't use Provider for type if package doesn't match
In #12296, we started correctly interpreting the Provider argument
per other SDKs. but this introduced a regression:
the Provider field is now set for resources with mismatched types.

This results in a scenario where a provider foo for package X
is passed to a resource bar with package Y,
with the intent of plumbing it to bar's descendants,
but bar attempts to incorrectly use the provider directly.

    foo := NewXProvider()
    bar := NewYThing("bar", Provider(foo))
    // ...
    baz := NewXThing("baz", Parent(bar)) // should use foo

This worked previously, but with #12296, this fails
because NewYThing attempts to use Provider foo directly.

To fix this, we need to prevent NewYThing from using a provider
that does not match the package that it belongs to.
We had to make a similar change to the Python SDK in #12292.

477e0c9766/sdk/python/lib/pulumi/resource.py (L925-L927)

The regression test is specific to remote component resources
per #12430, but the issue would be caused even for normal component
resources before this.

Resolves #12430
2023-03-14 16:27:06 -07:00
..
pending sdk/go: Don't use Provider for type if package doesn't match 2023-03-14 16:27:06 -07:00
config.yaml Reorder scopes to be alphabetically ordered. 2022-11-10 16:54:37 -05:00