Commit Graph

11934 Commits

Author SHA1 Message Date
Will Jones cb81c738db Hack in /dev/shm temporarily 2024-07-18 13:51:38 +01:00
Will Jones 09accbf68a Use a file backend for NodeJS Automation API tests
The majority of our NodeJS Automation API tests are currently configured
to use the (default) option of a Pulumi Cloud backend. This is
undesirable for several reasons:

* Using Pulumi Cloud introduces a network into the mix, meaning there is
  a greater chance of tests flaking.
* Pulumi Cloud is essentially a massive shared global state, so if
  multiple tests run concurrently, we need to ensure that they don't
  interfere with each other. We thus have code to generate random stack
  names, projects, etc. to avoid these sorts of clashes. If we don't, we
  again run the risk of having flaky tests.
* It's slower than not using Pulumi Cloud/the network and instead using
  e.g. a local file-backed state.

This commit reworks as many tests as possible to use local file-backed
state. In doing so, we optimistically re-enable some previously skipped
tests that were marked as flaky. For hygiene, and in case there is a
chance we'll run multiple instances of the suite on a single instance in
CI, we use temporary directories for state where possible which are
aggressively cleaned up on test suite exit (see the `tmp` NPM package
which we already use elsewhere). For tests that use `Pulumi.yaml` files
(and thus must have a fixed `backend.url`), we use `file://~`, which is
already used in one test and seems to work just fine.

As a result of these changes, the tests run significantly faster (from
the order of tens of minutes to just a few, if that) and should in
theory be less (never, 🙏) flaky. Moreover, it's likely that we
could later remove some more of the code in our tests that e.g.
generates random names, since there should be no need for this any more.

Fixes 
Part of 
2024-07-18 13:50:55 +01:00
Thomas Gummerer 6215d96730
implement invoke transforms for NodeJS ()
Similar to what we recently did for Go in
https://github.com/pulumi/pulumi/pull/16617, also implement invoke
transforms for NodeJS
2024-07-18 08:41:39 +00:00
Fraser Waters d81bab2181
Refactor MissingError handling ()
While looking at https://github.com/pulumi/pulumi/issues/16469, I
noticed a lot of the missing errors were a bit repetitive for the
not-a-missing-error case and disable-plugin-acquisition case. So this
rejigs the if statements a bit to make them all a bit more standard of
"if not a missing error, or if disable plugin acquisition is set, then
just err immediately, else retry".
2024-07-18 08:33:09 +00:00
Justin Van Patten 584ff1c2f0
Prepare for v3.125.0 release ()
Will include https://github.com/pulumi/pulumi/pull/16691

Tentative changelog:

### Features

- [sdk/go] Add support for invoke stack transforms
  [](https://github.com/pulumi/pulumi/pull/16617)

- [sdk/{go,nodejs,python}] Support `--remove` for `destroy` in the Go,
NodeJS and Python Automation API SDKs
  [](https://github.com/pulumi/pulumi/pull/16674)

- [sdkgen/go] Default importBasePath to a pulumi github base path
  [](https://github.com/pulumi/pulumi/pull/16664)


### Bug Fixes

- [cli/new] Fix incorrect caching of git auth method in error cases
  [](https://github.com/pulumi/pulumi/pull/16652)

- [cli/state] Fix panic in state move when either the source or
destination stack are empty
  [](https://github.com/pulumi/pulumi/pull/16676)

- [cli/state] Fix resources to be moved not being shown in `pulumi state
move`
  [](https://github.com/pulumi/pulumi/pull/16672)

- [cli/state] Warn when an argument matches no URN in the source
snapshot and error out when no resources are being moved in `pulumi
state move`
  [](https://github.com/pulumi/pulumi/pull/16673)

- [pkg/testing] Clean up PULUMI_HOME after program test
  [](https://github.com/pulumi/pulumi/pull/16663)

- [sdk/nodejs] Fix lookup for pulumi run script when using Volta to
manage nodejs
  [](https://github.com/pulumi/pulumi/pull/16649)

- [sdk/python] Fix YAML serialization of project settings in the Python
Automation API
  [](https://github.com/pulumi/pulumi/pull/16660)

- [sdk/python] Use python names for dictionary literals when inside a
typed dictionary input
  [](https://github.com/pulumi/pulumi/pull/16658)

- [sdk/python] Don't use indentation in converted pyproject.toml files
  [](https://github.com/pulumi/pulumi/pull/16678)

- [sdk/python] Fix a RecursionError with deeply nested
ComponentResources
  [](https://github.com/pulumi/pulumi/pull/16669)
2024-07-18 08:23:03 +00:00
Julien d03d966ce1
Validate that we have Poetry >= 1.8.0 ()
The pyproject.toml files we generated when using the Poetry toolchain
require Poetry >= 1.8.0. Validate that we have at least this version,
and report a descriptive error if not.

Fixes https://github.com/pulumi/pulumi/issues/16656

Doc update: https://github.com/pulumi/docs/pull/12293
2024-07-18 08:14:16 +00:00
Thomas Gummerer de26122fdf
name invoke transforms RegisterInvokeTransform in the Go SDK ()
This is more consistent with `RegisterResourceTransform`. The
`RegisterStackInvokeTransform` version has not been released yet, so we
still have the option of making this consistent.
2024-07-18 07:37:16 +00:00
Fraser Waters a8cd9b9435
Remove unused PropertySet type ()
Doesn't look like anything uses this, and chances are we'll want to add
_actual_ sets of property values at some point which clashes with this
name.
2024-07-17 21:51:54 +00:00
Fraser Waters 977ea57247
Enable the l1-empty test for Go ()
Enable the l1-empty test for Go.

This required some changes in reporting versions from the Go language
host (replaced dependencies don't really have a version anymore, because
they've been replaced by a local artefact and that doesn't contain any
version info itself). This then cascaded that the conformance test had
to be less strict about checking versions from GetDependencies because
Go now returns empty versions for these local deps.
2024-07-17 13:15:07 +00:00
Fraser Waters 40227d99ab
Change Go dependency tests to use real dependencies ()
For conformance testing we want "replace" directives to be respected
since they change the version of the dependency. These tests were all
written using replace directives instead of just normal real
dependencies and so fixing the Go host to respect "replace" broke these
tests.
This rewrites the tests to use real dependencies pulled from a separate
repo at https://github.com/pulumi/go-dependency-testdata.
2024-07-17 10:48:53 +00:00
Will Jones 01dc95a173
Support `--remove` for `destroy` in the Go, NodeJS and Python Automation API SDKs ()
By default, `pulumi destroy` removes all resources within a stack but
leaves the stack and its configuration intact. If one passes the
`--remove` option to `destroy`, however, the stack and its configuration
will also be removed once the resources within the stack have been
deleted. This commit updates the work of @Moon1706 in  to add
`remove` as an option to the Go, NodeJS and Python Automation API SDKs'
`destroy` methods, which then perform an analogous clean-up.

Closes 

---------

Co-authored-by: Nikita Sharaev <n.p.sharaev@tinkoff.ru>
2024-07-17 09:07:30 +00:00
Thomas Gummerer 62e28ebf29
state_move: warn no resources are matched/error out when no resources move ()
Currently when no resources are moved, we just show no resources being
moved, but let the command continue. This can be quite confusing to the
user. Error out in that case instead. Also when an argument doesn't
match any resources in the source snapshot, we now warn the user about
that.
2024-07-17 09:03:59 +00:00
Fraser Waters e0da9cb39a
Adding conformance tests for Go ()
This adds the framework for running conformance tests for Go. Currently
_all_ the tests are skipped, but I'll raise small PRs on top of this one
to start fixing some of the issues.
2024-07-17 09:00:08 +00:00
Julien e763f1a5fd
Use python names for dictionary literals when inside a typed dictionary input ()
When generating literals for inputs that have TypedDict types, we want
to use the pythonic names (snake_case) for keys.

We also have to take care of tracking the fact that we’re inisde a
TypedDict for nested dicts.

Fixes https://github.com/pulumi/pulumi/issues/16646
2024-07-17 08:11:49 +00:00
Julien d1a401fbcd
Don't use indentation in converted pyproject.toml files ()
When converting from a requirements.txt to a pyproject.toml, we were
previously indenting each logical level in the file. Disable the
indentation to match the style of pyproject.toml files as generated
directly by Poetry.

Fixes https://github.com/pulumi/pulumi/issues/16657
2024-07-17 07:28:56 +00:00
Julien ff5fe13fe2
Fix incorrect caching of git auth method in error cases ()
urlAuthParser.Parse caches auth methods. To avoid caching the auth
method when running into an error, we first checked that the auth method
is not nil. However we ran into a classic Go issue where a nil value of
a concrete type is assigned to a variable of an interface type, making 
it not equal to nil.

https://go.dev/doc/faq#nil_error

https://go.dev/play/p/AOSdCWd3XC1

Fixes https://github.com/pulumi/pulumi/issues/16637

---------

Co-authored-by: Thomas Gummerer <t.gummerer@gmail.com>
2024-07-16 14:53:32 +00:00
Thomas Gummerer dd4254c653
state_move: handle empty stacks correctly ()
Currently when we have stacks with no snapshot, `pulumi state move`
fails because it tries to use a nil pointer. Handle this scenario
correctly by:
- erroring out if there is no snapshot in the source stack. In this case
there are no resources that can be moved, so there's nothing more that
we can do other than showing the error.
- creating a snapshot in the destination stack if necessary. It's valid
to move a resource to a currently empty stack, so we'll make this work.
2024-07-16 14:40:33 +00:00
Will Jones f789d5e59c
Fix an incorrect error check in NodeJS integration tests ()
This commit fixes a small error in one of our integration tests that
happened to be spotted in , but was never addressed separately/has
not been addressed since that PR has not yet been merged.

Co-authored-by: Sam Eiderman <sameid@gmail.com>
2024-07-16 14:07:02 +00:00
Thomas Gummerer 1e77ed263d
state_move: show resources to be moved correctly ()
At some point while moving the code around we lost the output for the
resources to be moved. We would look for them in the source snapshot for
correct ordering, but the code happened after the URN renaming, so the
resources would not match the ones in the source snapshot anymore.

Fix this by using the resourcesToMoveOrdered list to print the
resources, and also moving this code a bit earlier, as we want to show
the resource URNs from the source snapshot, instead of the rewritten
ones.
2024-07-16 13:27:15 +00:00
Fraser Waters 0a83daaa08
Fix CopyFile to copy symlink directories ()
Noticed while working on https://github.com/pulumi/pulumi/pull/16662.
CopyFile couldn't handle a symlink'd directory.
2024-07-16 11:57:14 +00:00
Thomas Gummerer 3a1c2f0ab9
sdk/python: avoid maximum recursion depth error ()
CPython doesn't optimize tail recursion, and because of that has a
fairly low recursion limit set to avoid stack overflows. This also means
that where we rely on recursion we are prone to raising
`RecursionError`s. In this particular case, `_add_dependency` relies on
recursion for finding all the child dependencies.

When deeply nested trees of `ComponentResources` are used,
`_add_dependencies` can end up raising such an error.

Rewrite the function to be iterative instead of recursive to avoid that.

Fixes https://github.com/pulumi/pulumi/issues/16328

(I didn't manage to reproduce the exact stacktrace of the above issue,
so there might be another thing hidden there. But this should help with
it either way)
2024-07-16 11:21:03 +00:00
Fraser Waters a9947b4e4e
Python parameterized provider test ()
This adds support for replacement parameterised providers to Python and
a small integration test to check it works e2e.

When using parameterised providers we need to use the new (currently
unstable) RegisterPackage system, instead of sending
Version/DownloadURL/etc via RegisterResourceRequest. Once
RegisterPackage is stable the intention is to change _all_ packages to
use it and for normal packages to fall back to the
RegisterResourceRequest options, while parameterised packages will
error.

The actual parameter value is embedded in the python SDK as a base64
string that we decode before sending to the gRPC endpoint as bytes.
2024-07-16 10:55:38 +00:00
Will Jones a158b300b9
Fix YAML serialization of project settings in the Python Automation API ()
The Python Automation API SDK serializes project settings (the contents
of `Pulumi.yaml` files) using Python's `pyyaml` package. Project
settings in the Python Automation API SDK are represented as instances
of the `ProjectSettings` class. By default, `pyyaml` will serialize
class instances as YAML objects "tagged" with a string that indicates
their class. This is so that, upon deserialization, it can construct
objects of the appropriate class (as opposed to, just dictionaries). As
an example, the following Python program:

```python
class Person:
  def __init(self, name: str, age: int) -> None:
    self.name = name
    self.age = age

will = Person("will", 37)
yaml.dump(will)
```

will produce the following YAML:

```yaml
!!python/object:__main__.Person
age: 37
name: will
```

The string `!!python/object:__main__.Person` is the _tag_ indicating the
class that Python will need to instantiate if e.g. this YAML is
deserialized with `yaml.load` or similar.

Outside of the various Automation APIs, `Pulumi.yaml` files are
"plain-old YAML files" -- language- or library-specific concepts such as
class tags are nowhere to be seen. We thus don't really want this
behaviour when we serialize project settings to YAML. Fortunately, there
is a relatively simple workaround -- instead of passing instances of
`ProjectSettings` to `yaml.dump`, we can just pass vanilla dictionaries
containing the same data. These will be rendered as YAML objects with no
tags, which is what we want.

<em>Un</em>fortunately, we must turn _all_ objects in a hierarchy into
plain dictionaries, or tags will appear at some point. Presently, this
is not the case in the Python SDK, which just uses
`ProjectSettings.__dict__` to get the dictionary for the top-level
object. If there are nested objects in this dictionary (such as e.g.
`ProjectBackend` or `ProjectRuntimeInfo` objects), these are _not_
converted into dictionaries and `pyyaml` writes them as tagged objects,
which will later fail to deserialize.

This commit fixes this issue, adding explicit `to_dict` and `from_dict`
methods to settings classes for the purposes of recursively converting
objects to and from dictionaries. It also:
* adds a test that confirms serialization/deserialization of
configurations containing nested objects now works.
* in order to write this test, exports some types (`ProjectTemplate` and
friends) that appear to be part of the public API but have until now not
been exported.
2024-07-16 10:00:05 +00:00
Fraser Waters 4ffb11376a
Default the import base path to something sensible ()
This fixes go package generation so users don't _have_ to set the import
base path explicitly in the go info part of the schema. This only really
helps our packages (because we assume the path is "github.com/pulumi")
but it fixes some of the generated test data and should also work for
local SDKs, where they aren't _really_ at "github.com/pulumi" but also
that it doesn't matter what URL is used as long as it's a valid one.

Fixes https://github.com/pulumi/pulumi/issues/13756

---------

Co-authored-by: Thomas Gummerer <t.gummerer@gmail.com>
2024-07-15 17:34:02 +00:00
Florian Stadler 06e288d7b5
Clean up PULUMI_HOME after program test ()
Clean up the temporary `PULUMI_HOME` directory we create during a
program test.
This is necessary to reclaim the disk space of the plugins that were
downloaded
during the test.

In pulumi-aws we started seeing test failures because the CI runners
started running out of disk space due to plugins in `PULUMI_HOME` not
being cleaned up.
2024-07-15 13:03:27 +00:00
Fraser Waters 4ae41f0fc3
Use modfile to generate the go.mod in GenerateProgram ()
Rather than writing a go.mod with string lerping, this uses the
"golang.org/x/mod/modfile" to construct and render the go.mod files we
generate for programs.

---------

Co-authored-by: Will Jones <will@sacharissa.co.uk>
2024-07-15 12:08:52 +00:00
Will Jones 26ff81961b
Improve TypeDocs for `sdk/nodejs/runtime` ()
This commit improves the TypeScript TypeDocs for `runtime` modules in
the NodeJS SDK. Specifically:

* It adds documentation to interfaces, properties, etc. that are missing
it.

* It transforms would-be TypeDoc comments erroneously written using
either `/*` (a single asterisk) or `//` (a normal line comment) to
actual TypeDoc comments.

* It standardises on TypeDoc's `{@link Name}` syntax for linking
identifiers, as opposed to the mixture of backticks and square brackets
we have today.

* It fixes typos and generally cleans up the formatting here and there,
as well as introducing more consistency where the same concepts crop up
in multiple places.
2024-07-15 11:27:47 +00:00
Thomas Gummerer 1c3061dd67
try to further reduce the pulumi bot token usage ()
There's a few instances where I *think* we can use the GITHUB_TOKEN we
get from actions, so we can try to avoid ratelimits.

All of these jobs should be running during PRs, so it should be
relatively safe if the CI tests pass.
2024-07-15 10:38:44 +00:00
Will Jones 47fa329ad3
Improve TypeDocs for `sdk/nodejs` ()
This commit improves the TypeScript TypeDocs for the remaining modules
in the NodeJS SDK. Specifically:

* It adds documentation to interfaces, properties, etc. that are missing
it.

* It transforms would-be TypeDoc comments erroneously written using
either `/*` (a single asterisk) or `//` (a normal line comment) to
actual TypeDoc comments.

* It standardises on TypeDoc's `{@link Name}` syntax for linking
identifiers, as opposed to the mixture of backticks and square brackets
we have today.

* It fixes typos and generally cleans up the formatting here and there,
as well as introducing more consistency where the same concepts crop up
in multiple places.

---------

Co-authored-by: Thomas Gummerer <t.gummerer@gmail.com>
2024-07-15 09:05:28 +00:00
Fraser Waters 5cbf4cf728
Extend the TestReplacementParameterizedProvider test ()
The test now checks that destroy works, and also that the parameterized
provider state is what we expect.

This required flipping around some of the state managment around reading
and writing provider inputs.
2024-07-15 08:33:36 +00:00
Thomas Gummerer 2034f7e2ae
add Go support for invoke transforms ()
Add support to the Go SDK for invoke transforms. This only adds support
for setting transforms globally, not yet via a resource option, which
resource transforms allow.

---------

Co-authored-by: Will Jones <will@sacharissa.co.uk>
2024-07-15 08:28:11 +00:00
Germán Lena 5ae05fefc2
Unify user prompts + cleanups + previous feedback ()
This PR unifies and standardizes user prompting
Also applies feedback from https://github.com/pulumi/pulumi/pull/16564
2024-07-12 16:01:13 +00:00
Julien 8db3d6dbd9
Fix lookup for pulumi run script when using Volta to manage nodejs ()
We run a short script with nodejs to find the path to the nodejs SDK
entrypoint. In https://github.com/pulumi/pulumi/pull/16160 this script
was changed and used newlines.

This broke when using the Volta package manager to manage different
nodejs versions. Volta adds shim programs into the user's path that
routes to the correct nodejs executable. Seemingly Volta does not handle
the newlines in the arguments.

To fix this, we ensure that the script is on a single line.

Fixes https://github.com/pulumi/pulumi/issues/16393
2024-07-12 15:31:43 +00:00
Pulumi Bot f6bdf034be
Changelog and go.mod updates for v3.124.0 ()
Co-authored-by: github-actions <github-actions@github.com>
2024-07-12 14:57:28 +00:00
Will Jones fc69816291
Test provider `Delete` parameter marshalling ()
This commit adds a test to ensure that provider `Delete`s are passed
with the correct set of parameters. This is a regression test for
, as part of the follow-up to  in . Assuming we are
happy with this level/style of test, we should consider adding tests for
the other provider methods also.

Fixes 
2024-07-12 11:19:32 +00:00
Thomas Gummerer cffba79f0b
Freeze 3.124.1 ()
To be merged after https://github.com/pulumi/pulumi/pull/16642 and
https://github.com/pulumi/pulumi/pull/16639 are merged.

Also depends on https://github.com/pulumi/pulumi/pull/16640 being merged
first.
2024-07-12 11:12:34 +00:00
Will Jones 100470d2e7
Revert "Implement `dependsOn` for invokes in the NodeJS SDK ()" ()
From SDKs, we call invokes in one of two ways:

* In a "non-output" context (e.g. `getX`), which has a result dependent
on the language (e.g. a `Promise` in NodeJS) that _does not_ track
dependencies.
* In an "output" context (e.g. `getXOutput`), which has an `Output` type
and does track dependencies.

In the non-output case, `dependsOn` really doesn't make sense, since
this style of invoke is inherently ignoring dependency tracking/outputs.
This commit thus reverts 492c57c7dd so
that we can rethink the design before people's programs are subtly
broken in this case.
2024-07-12 10:16:55 +00:00
Thomas Gummerer 34b0409d07
continue-on-error: respect all dependency relationships ()
When running `pulumi up --continue-on-error`, we can't bring up new
resources that have dependencies that have failed, or have been skipped.
Since the resource would have a failed dependency, that dependency would
not be in the snapshot, resulting in a snapshot integrity failure. Also
it simply does not make sense to `up` a resource that has a failed
dependency.

We took care of that for the regular dependency relationship, however at
the time we missed doing the same for other types of dependencies,
namely parent-child relationships, deleted with relationships and
property dependencies.

This can result in snapshot integrity failures for example when a parent
fails to be created, but we still do the resource creation of the child,
such as what happened in https://github.com/pulumi/pulumi/issues/16638.

Fix this by skipping the step when a resource with any type of
dependency relationship fails or is skipped beforehand.

Fixes https://github.com/pulumi/pulumi/issues/16638
2024-07-12 09:42:57 +00:00
Julien 72b75d2035
Install policy or project dependencies based on nearest configuration file ()
When a policy pack is nested within a project, or vice-versa, install
the appropriate dependencies, based on where the command is run from.

If there are both policy pack and project files in the parent
directories of the current working directory, pick the one that is
closest.

Fixes https://github.com/pulumi/pulumi/issues/16605
2024-07-12 08:56:18 +00:00
Thomas Gummerer 63cef47eb7
state_move: improve usage text ()
Correct the usage text, and mark the command not as non-experimental.
The command should be ready for regular usage, so I think the
"EXPERIMENTAL" comment can be dropped now.
2024-07-12 08:53:33 +00:00
Thomas Gummerer 22a4258383
Prepare for 3.124.0 release ()
We might want to get a new version with
https://github.com/pulumi/pulumi/pull/16639 included out soon. However
we already merged at least one change that warrants bumping the minor
version (https://github.com/pulumi/pulumi/pull/16630).

Bump the minor version so we can be quicker to decide whether we do want
to do a release.
2024-07-12 08:49:19 +00:00
Aaron Friel 7f8e7174a1
Update Pulumi YAML to 1.9.1 ()
Fixes 

See:
- https://github.com/pulumi/pulumi/pull/16625
- https://github.com/pulumi/pulumi-yaml/pull/600
2024-07-11 22:33:05 +00:00
Thomas Gummerer b8226b7058
implement engine support for invoke transforms ()
We've recently introduced resource transforms, which allow users to
update any resource options and properties for the duration of a program
using a callback. We want to introduce similar functionality for Invokes
(and eventually also StreamInvokes, Read and Calls). This can help users
e.g. set default providers through transforms consistently for all
components.

While this PR only implements the engine parts of invoke transforms, the
API for this will look very similar to what the API for resource
transforms looks like. For example in TypeScript:

```
pulumi.runtime.registerInvokeTransform(args => {
[...]
});
```

---------

Co-authored-by: Will Jones <will@sacharissa.co.uk>
2024-07-11 16:01:44 +00:00
Julien f251d3142c
Don't count plugins from a nested policy pack in GetRequiredPlugins ()
For nodejs we look at the node_modules of all child directories of the
root path to find the required plugins. When a policy pack is nested
within a pulumi project, we were including its dependencies in the list
of required plugins. To avoid this, we stop recursing once we see a
directory that has a PulumiPolicy.yaml.

Fixes https://github.com/pulumi/pulumi/issues/16604
2024-07-11 16:01:31 +00:00
Aaron Friel ac80164670
Fix incorrect YAML type checking of StackReference outputs ()
Part of .

Pulumi YAML uses the schema defined here to type check outputs from the
`pulumi:pulumi:StackReference` resource. This changes the type of
`outputs` from `map[string]string` to `map[string]any`, permitting list,
map, and numeric outputs to be used as inputs to other resources.

To release this fix, we will need to release Pulumi twice and YAML once
if we are to use our ordinary release process:

1. Merge this PR.
2. Release sdk and pkg dependencies with this update applied.
3. Merge https://github.com/pulumi/pulumi-yaml/pull/600
4. Create and merge a PR to update Pulumi YAML's dependency on
`github.com/pulumi/pkg/v3`, as YAML links to the schema loader and will
read the updated schema here:

7f48ca370d/pkg/codegen/schema/loader.go (L136-L140)
 
5. Release Pulumi YAML
6. Create and merge a PR to update the YAML language plugin shipped with
Pulumi
7. Release Pulumi
2024-07-11 14:17:41 +00:00
Germán Lena 956428f690
Update deployment settings git configuration to support directories that are not a git repo ()
Change how the deployment settings configures git repos to support
directories that are not git repositories

Fix https://github.com/pulumi/pulumi-service/issues/20675

---------

Co-authored-by: Levi Blackstone <levi@pulumi.com>
2024-07-11 14:14:18 +00:00
Thomas Gummerer 3242403d57
state_move: add --include-parents flag ()
When moving state it can be useful to also include all the parents. Add
a flag to give users that option.

Using this flag, all parents of all the resources being moved will be
included in the move.
2024-07-11 12:59:20 +00:00
Thomas Gummerer f251e39ae7
state_move: mark command as non-hidden ()
Now that we implemented all the features for this command we can remove
the hidden flag, and actually start letting users use it.
2024-07-11 11:58:11 +00:00
Thomas Gummerer 7e47833ae6
error out on duplicate providers/resources ()
When the user tries to move a resource that would end up being a
duplicate in the destination stack, we need to prevent that, to avoid a
broken state file.

Error out in this case.

Depends on: https://github.com/pulumi/pulumi/pull/16543
2024-07-11 09:32:31 +00:00
Pulumi Bot 2a25c7ff13
Changelog and go.mod updates for v3.123.0 ()
Co-authored-by: github-actions <github-actions@github.com>
2024-07-10 22:57:33 +00:00