pulumi/pkg
Paul C. Roberts d864cce061
Decouple persist and display events ()
<!--- 
Thanks so much for your contribution! If this is your first time
contributing, please ensure that you have read the
[CONTRIBUTING](https://github.com/pulumi/pulumi/blob/master/CONTRIBUTING.md)
documentation.
-->

# Description

Retry  with fix for the issue that required the revert in  

This removes a scenario where events could not be persisted to the cloud
because they were waiting on the same event being displayed

Instead of rendering the tree every time a row is updated, instead, this
renders when the display actually happens in the the `frame` call. The
renderer instead simply marks itself as dirty in the `rowUpdated`,
`tick`, `systemMessage` and `done` methods and relies on the frame being
redrawn on a 60Hz timer (the `done` method calls `frame` explicitly).
This makes the rowUpdated call exceedingly cheap (it simply marks the
treeRenderer as dirty) which allows the ProgressDisplay instance to
service the display events faster, which prevents it from blocking the
persist events.

This requires a minor refactor to ensure that the display object is
available in the frame method

Because the treeRenderer is calling back into the ProgressDisplay object
in a goroutine, the ProgressDisplay object needs to be thread safe, so a
read-write mutex is added to protect the `eventUrnToResourceRow` map.
The unused `urnToID` map was removed in passing.

## Impact

There are scenarios where the total time taken for an operation was
dominated by servicing the events.

This reduces the time for a complex (~2000 resources) `pulumi preview`
from 1m45s to 45s

For a `pulumi up` with `-v=11` on a the same stack, where all the
register resource spans were completing in 1h6m and the
postEngineEventBatch events were taking 3h45m, this PR removes the time
impact of reporting the events (greatly inflated by the high verbosity
setting) and the operation takes the anticipated 1h6m


<!--- Please include a summary of the change and which issue is fixed.
Please also include relevant motivation and context. -->

Fixes  

This was happening because the renderer was being marked dirty once per
second in a tick event, which caused frame to redraw. There is a check
in the render method that `display.headerRow` is not nil that was
previously used to prevent rendering when no events had been added. This
check is now part of the `markDirty` logic

Some of the tests needed to be updated to make this work and have also
been refactored

## Checklist

- [X] I have run `make tidy` to update any new dependencies
- [X] I have run `make lint` to verify my code passes the lint check
  - [ ] I have formatted my code using `gofumpt`

<!--- Please provide details if the checkbox below is to be left
unchecked. -->
- [X] I have added tests that prove my fix is effective or that my
feature works
<!--- 
User-facing changes require a CHANGELOG entry.
-->
- [ ] I have run `make changelog` and committed the
`changelog/pending/<file>` documenting my change
<!--
If the change(s) in this PR is a modification of an existing call to the
Pulumi Cloud,
then the service should honor older versions of the CLI where this
change would not exist.
You must then bump the API version in
/pkg/backend/httpstate/client/api.go, as well as add
it to the service.
-->
- [ ] Yes, there are changes in this PR that warrants bumping the Pulumi
Cloud API version
<!-- @Pulumi employees: If yes, you must submit corresponding changes in
the service repo. -->

---------

Co-authored-by: Paul Roberts <proberts@pulumi.com>
2024-03-18 16:53:13 +00:00
..
asset Move some asset code to pkg () 2024-01-17 11:30:37 +00:00
authhelpers Add tests for gcpauth pkg () 2023-09-13 11:27:03 +00:00
backend Decouple persist and display events () 2024-03-18 16:53:13 +00:00
cmd/pulumi [auto/go] Support for remote deployment executor image () 2024-03-15 06:43:06 +00:00
codegen [program-gen] Fix enum resolution from types of the form Union[string, Enum] and emit fully qualified enum cases () 2024-03-15 17:49:12 +00:00
display Move sdk/go/common/display to /pkg/display () 2023-09-18 11:01:28 +00:00
engine Use sets for dependencies inside the engine () 2024-03-15 13:01:45 +00:00
graph Adds a flag to graph command to insert fragment () 2024-01-08 22:03:08 +00:00
importer Enable perfsprint linter () 2023-12-12 12:19:42 +00:00
operations Move resource.URN to urn.URN () 2024-03-14 15:28:32 +00:00
resource Use sets for dependencies inside the engine () 2024-03-15 13:01:45 +00:00
secrets Fix azure secret manager tests () 2024-02-14 08:14:58 +00:00
testing/integration set PULUMI_HOME in ProgramTests () 2024-03-04 09:06:56 +00:00
util Remove deprecated Protobufs imports () 2024-01-17 09:35:20 +00:00
version duplicate version to ensure linking is properly handled 2020-03-19 12:49:34 -07:00
workspace Clean up uses of .Error() () 2023-12-20 15:54:06 +00:00
README.md export codegen tests for internal use () 2022-02-07 12:10:04 +01:00
go.mod Bump the go_modules group across 1 directory with 1 update () 2024-03-18 14:57:43 +00:00
go.sum Bump the go_modules group across 1 directory with 1 update () 2024-03-18 14:57:43 +00:00

README.md

pulumi/pkg

While pulumi/sdk maintains strict backwards compatibility guarantees, code under pkg/ is handled more informally: while breaking changes are still discouraged they may happen when they make sense.