pulumi/sdk/python/lib/test/langhost/outputs_future
Pat Gavlin 63eb7abb59
Make `pulumi.runtime.invoke` synchronous. (#3019)
These changes make the `pulumi.runtime.invoke` function invokable in a
synchronous manner. Because this function still needs to perform
asynchronous work under the covers--namely awaiting a provider URN and
ID if a provider instance is present in the `InvokeOptions`--this
requires some creativity. This creativity comes in the form of a helper
function, `_sync_await`, that performs a logical yield from the
currently running event, manually runs the event loop until the given
future completes, performs a logical resume back to the
currently executing event, and returns the result of the future.

The code in `_sync_await` is a bit scary, as it relies upon knowledge of
(and functions in) the internals of the `asyncio` package. The necessary
work performed in this function was derived from the implementations of
`task_step` (which pointed out the need to call `_{enter,leave}_task`)
and `BaseEventLoop.run_forever` (which illustrated how the event loop is
pumped). In addition to potential breaking changes to these internals,
the code may not work if a user has provided an alternative implementation
for `EventLoop`. That said, the code is a close enough copy of
`BaseEventLoop.run_forever` that it should be a reasonable solution.
2019-08-02 14:19:56 -07:00
..
__init__.py Add a test for exporting Futures (#2447) 2019-02-13 14:05:29 -08:00
__main__.py Make `pulumi.runtime.invoke` synchronous. (#3019) 2019-08-02 14:19:56 -07:00
test_outputs_future.py Plumb provider version through language hosts to engine (#2656) 2019-04-23 11:02:51 -07:00