@aws-cdk/toolkit-lib 0.3.0 → 0.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,14 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.StackAssembly = void 0;
4
+ require("../../../private/dispose-polyfill");
4
5
  const semver_1 = require("semver");
5
6
  const shared_private_1 = require("../../shared-private");
6
7
  const shared_public_1 = require("../../shared-public");
7
8
  const stack_selector_1 = require("../stack-selector");
8
- if (!Symbol.asyncDispose) {
9
- // eslint-disable-next-line @cdklabs/no-throw-default-error
10
- throw new Error('Symbol.asyncDispose is not defined on the current JavaScript platform!');
11
- }
12
9
  /**
13
10
  * A single Cloud Assembly wrapped to provide additional stack operations.
14
11
  */
@@ -109,4 +106,4 @@ function expandToExtendEnum(extend) {
109
106
  return undefined;
110
107
  }
111
108
  }
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-assembly.js","sourceRoot":"","sources":["stack-assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import { major } from 'semver';\nimport type { IoHelper } from '../../shared-private';\nimport { BaseStackAssembly, StackCollection, ExtendedStackSelection as CliExtendedStackSelection } from '../../shared-private';\nimport { ToolkitError } from '../../shared-public';\nimport type { StackSelector } from '../stack-selector';\nimport { ExpandStackSelection, StackSelectionStrategy } from '../stack-selector';\nimport type { IReadableCloudAssembly } from '../types';\n\nif (!Symbol.asyncDispose) {\n  // eslint-disable-next-line @cdklabs/no-throw-default-error\n  throw new Error('Symbol.asyncDispose is not defined on the current JavaScript platform!');\n}\n\n/**\n * A single Cloud Assembly wrapped to provide additional stack operations.\n */\nexport class StackAssembly extends BaseStackAssembly implements IReadableCloudAssembly {\n  constructor(private readonly _asm: IReadableCloudAssembly, ioHelper: IoHelper) {\n    super(_asm.cloudAssembly, ioHelper);\n  }\n\n  public get cloudAssembly() {\n    return this._asm.cloudAssembly;\n  }\n\n  public async _unlock() {\n    return this._asm._unlock();\n  }\n\n  public async dispose() {\n    return this._asm.dispose();\n  }\n\n  public async [Symbol.asyncDispose]() {\n    return this.dispose();\n  }\n\n  /**\n   * Improved stack selection interface with a single selector\n   * @throws when the assembly does not contain any stacks, unless `selector.failOnEmpty` is `false`\n   * @throws when individual selection strategies are not satisfied\n   */\n  public async selectStacksV2(selector: StackSelector): Promise<StackCollection> {\n    const asm = this.assembly;\n    const topLevelStacks = asm.stacks;\n    const allStacks = major(asm.version) < 10 ? asm.stacks : asm.stacksRecursively;\n\n    if (allStacks.length === 0 && (selector.failOnEmpty ?? true)) {\n      throw new ToolkitError('This app contains no stacks');\n    }\n\n    const extend = expandToExtendEnum(selector.expand);\n    const patterns = StackAssembly.sanitizePatterns(selector.patterns ?? []);\n\n    switch (selector.strategy) {\n      case StackSelectionStrategy.ALL_STACKS:\n        return new StackCollection(this, allStacks);\n      case StackSelectionStrategy.MAIN_ASSEMBLY:\n        if (topLevelStacks.length < 1) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError('No stack found in the main cloud assembly. Use \"list\" to print manifest');\n        }\n        return this.extendStacks(topLevelStacks, allStacks, extend);\n      case StackSelectionStrategy.ONLY_SINGLE:\n        if (topLevelStacks.length !== 1) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError('Since this app includes more than a single stack, specify which stacks to use (wildcards are supported) or specify `--all`\\n' +\n          `Stacks: ${allStacks.map(x => x.hierarchicalId).join(' · ')}`);\n        }\n        return new StackCollection(this, topLevelStacks);\n      default:\n        const matched = await this.selectMatchingStacks(allStacks, patterns, extend);\n        if (\n          selector.strategy === StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE\n          && matched.stackCount !== 1\n        ) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError(\n            `Stack selection is ambiguous, please choose a specific stack for import [${allStacks.map(x => x.hierarchicalId).join(',')}]`,\n          );\n        }\n        if (\n          selector.strategy === StackSelectionStrategy.PATTERN_MUST_MATCH\n          && matched.stackCount < 1\n        ) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError(\n            `Stack selection is ambiguous, please choose a specific stack for import [${allStacks.map(x => x.hierarchicalId).join(',')}]`,\n          );\n        }\n\n        return matched;\n    }\n  }\n\n  /**\n   * Select all stacks.\n   *\n   * This method never throws and can safely be used as a basis for other calculations.\n   *\n   * @returns a `StackCollection` of all stacks\n   */\n  public selectAllStacks() {\n    const allStacks = major(this.assembly.version) < 10 ? this.assembly.stacks : this.assembly.stacksRecursively;\n    return new StackCollection(this, allStacks);\n  }\n\n  /**\n   * Select all stacks that have the validateOnSynth flag et.\n   *\n   * @returns a `StackCollection` of all stacks that needs to be validated\n   */\n  public selectStacksForValidation() {\n    const allStacks = this.selectAllStacks();\n    return allStacks.filter((art) => art.validateOnSynth ?? false);\n  }\n}\n\nfunction expandToExtendEnum(extend?: ExpandStackSelection): CliExtendedStackSelection | undefined {\n  switch (extend) {\n    case ExpandStackSelection.DOWNSTREAM:\n      return CliExtendedStackSelection.Downstream;\n    case ExpandStackSelection.UPSTREAM:\n      return CliExtendedStackSelection.Upstream;\n    case ExpandStackSelection.NONE:\n      return CliExtendedStackSelection.None;\n    default:\n      return undefined;\n  }\n}\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-assembly.js","sourceRoot":"","sources":["stack-assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import '../../../private/dispose-polyfill';\nimport { major } from 'semver';\nimport type { IoHelper } from '../../shared-private';\nimport { BaseStackAssembly, StackCollection, ExtendedStackSelection as CliExtendedStackSelection } from '../../shared-private';\nimport { ToolkitError } from '../../shared-public';\nimport type { StackSelector } from '../stack-selector';\nimport { ExpandStackSelection, StackSelectionStrategy } from '../stack-selector';\nimport type { IReadableCloudAssembly } from '../types';\n\n/**\n * A single Cloud Assembly wrapped to provide additional stack operations.\n */\nexport class StackAssembly extends BaseStackAssembly implements IReadableCloudAssembly {\n  constructor(private readonly _asm: IReadableCloudAssembly, ioHelper: IoHelper) {\n    super(_asm.cloudAssembly, ioHelper);\n  }\n\n  public get cloudAssembly() {\n    return this._asm.cloudAssembly;\n  }\n\n  public async _unlock() {\n    return this._asm._unlock();\n  }\n\n  public async dispose() {\n    return this._asm.dispose();\n  }\n\n  public async [Symbol.asyncDispose]() {\n    return this.dispose();\n  }\n\n  /**\n   * Improved stack selection interface with a single selector\n   * @throws when the assembly does not contain any stacks, unless `selector.failOnEmpty` is `false`\n   * @throws when individual selection strategies are not satisfied\n   */\n  public async selectStacksV2(selector: StackSelector): Promise<StackCollection> {\n    const asm = this.assembly;\n    const topLevelStacks = asm.stacks;\n    const allStacks = major(asm.version) < 10 ? asm.stacks : asm.stacksRecursively;\n\n    if (allStacks.length === 0 && (selector.failOnEmpty ?? true)) {\n      throw new ToolkitError('This app contains no stacks');\n    }\n\n    const extend = expandToExtendEnum(selector.expand);\n    const patterns = StackAssembly.sanitizePatterns(selector.patterns ?? []);\n\n    switch (selector.strategy) {\n      case StackSelectionStrategy.ALL_STACKS:\n        return new StackCollection(this, allStacks);\n      case StackSelectionStrategy.MAIN_ASSEMBLY:\n        if (topLevelStacks.length < 1) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError('No stack found in the main cloud assembly. Use \"list\" to print manifest');\n        }\n        return this.extendStacks(topLevelStacks, allStacks, extend);\n      case StackSelectionStrategy.ONLY_SINGLE:\n        if (topLevelStacks.length !== 1) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError('Since this app includes more than a single stack, specify which stacks to use (wildcards are supported) or specify `--all`\\n' +\n          `Stacks: ${allStacks.map(x => x.hierarchicalId).join(' · ')}`);\n        }\n        return new StackCollection(this, topLevelStacks);\n      default:\n        const matched = await this.selectMatchingStacks(allStacks, patterns, extend);\n        if (\n          selector.strategy === StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE\n          && matched.stackCount !== 1\n        ) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError(\n            `Stack selection is ambiguous, please choose a specific stack for import [${allStacks.map(x => x.hierarchicalId).join(',')}]`,\n          );\n        }\n        if (\n          selector.strategy === StackSelectionStrategy.PATTERN_MUST_MATCH\n          && matched.stackCount < 1\n        ) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError(\n            `Stack selection is ambiguous, please choose a specific stack for import [${allStacks.map(x => x.hierarchicalId).join(',')}]`,\n          );\n        }\n\n        return matched;\n    }\n  }\n\n  /**\n   * Select all stacks.\n   *\n   * This method never throws and can safely be used as a basis for other calculations.\n   *\n   * @returns a `StackCollection` of all stacks\n   */\n  public selectAllStacks() {\n    const allStacks = major(this.assembly.version) < 10 ? this.assembly.stacks : this.assembly.stacksRecursively;\n    return new StackCollection(this, allStacks);\n  }\n\n  /**\n   * Select all stacks that have the validateOnSynth flag et.\n   *\n   * @returns a `StackCollection` of all stacks that needs to be validated\n   */\n  public selectStacksForValidation() {\n    const allStacks = this.selectAllStacks();\n    return allStacks.filter((art) => art.validateOnSynth ?? false);\n  }\n}\n\nfunction expandToExtendEnum(extend?: ExpandStackSelection): CliExtendedStackSelection | undefined {\n  switch (extend) {\n    case ExpandStackSelection.DOWNSTREAM:\n      return CliExtendedStackSelection.Downstream;\n    case ExpandStackSelection.UPSTREAM:\n      return CliExtendedStackSelection.Upstream;\n    case ExpandStackSelection.NONE:\n      return CliExtendedStackSelection.None;\n    default:\n      return undefined;\n  }\n}\n"]}
@@ -2,4 +2,5 @@ export * from '../../../tmp-toolkit-helpers/src/api/io/private';
2
2
  export * from '../../../tmp-toolkit-helpers/src/private';
3
3
  export * from '../../../tmp-toolkit-helpers/src/api';
4
4
  export * as cfnApi from '../../../tmp-toolkit-helpers/src/api/deployments/cfn-api';
5
+ export { makeRequestHandler } from '../../../tmp-toolkit-helpers/src/api/aws-auth/awscli-compatible';
5
6
  export * as contextproviders from '../../../tmp-toolkit-helpers/src/context-providers';
@@ -156,6 +156,7 @@ __export(shared_private_exports, {
156
156
  loadTree: () => loadTree,
157
157
  loadTreeFromDir: () => loadTreeFromDir,
158
158
  makeBodyParameter: () => makeBodyParameter,
159
+ makeRequestHandler: () => makeRequestHandler,
159
160
  markTesting: () => markTesting,
160
161
  nonHotswappableChange: () => nonHotswappableChange,
161
162
  nonHotswappableResource: () => nonHotswappableResource,
@@ -2468,8 +2469,20 @@ var DEFAULT_CONNECTION_TIMEOUT = 1e4;
2468
2469
  var DEFAULT_TIMEOUT = 3e5;
2469
2470
  var AwsCliCompatible = class {
2470
2471
  ioHelper;
2471
- constructor(ioHelper) {
2472
+ requestHandler;
2473
+ logger;
2474
+ constructor(ioHelper, requestHandler, logger) {
2472
2475
  this.ioHelper = ioHelper;
2476
+ this.requestHandler = requestHandler;
2477
+ this.logger = logger;
2478
+ }
2479
+ async baseConfig(profile) {
2480
+ const credentialProvider = await this.credentialChainBuilder({
2481
+ profile,
2482
+ logger: this.logger
2483
+ });
2484
+ const defaultRegion = await this.region(profile);
2485
+ return { credentialProvider, defaultRegion };
2473
2486
  }
2474
2487
  /**
2475
2488
  * Build an AWS CLI-compatible credential chain provider
@@ -2478,7 +2491,7 @@ var AwsCliCompatible = class {
2478
2491
  */
2479
2492
  async credentialChainBuilder(options = {}) {
2480
2493
  const clientConfig = {
2481
- requestHandler: await this.requestHandlerBuilder(options.httpOptions),
2494
+ requestHandler: this.requestHandler,
2482
2495
  customUserAgent: "aws-cdk",
2483
2496
  logger: options.logger
2484
2497
  };
@@ -2506,15 +2519,6 @@ var AwsCliCompatible = class {
2506
2519
  });
2507
2520
  return shouldPrioritizeEnv() ? (0, import_credential_providers.createCredentialChain)((0, import_credential_providers.fromEnv)(), nodeProviderChain).expireAfter(60 * 6e4) : nodeProviderChain;
2508
2521
  }
2509
- async requestHandlerBuilder(options = {}) {
2510
- const agent = await new ProxyAgentProvider(this.ioHelper).create(options);
2511
- return {
2512
- connectionTimeout: DEFAULT_CONNECTION_TIMEOUT,
2513
- requestTimeout: DEFAULT_TIMEOUT,
2514
- httpsAgent: agent,
2515
- httpAgent: agent
2516
- };
2517
- }
2518
2522
  /**
2519
2523
  * Attempts to get the region from a number of sources and falls back to us-east-1 if no region can be found,
2520
2524
  * as is done in the AWS CLI.
@@ -2614,17 +2618,24 @@ function shouldPrioritizeEnv() {
2614
2618
  }
2615
2619
  return false;
2616
2620
  }
2621
+ async function makeRequestHandler(ioHelper, options = {}) {
2622
+ const agent = await new ProxyAgentProvider(ioHelper).create(options);
2623
+ return {
2624
+ connectionTimeout: DEFAULT_CONNECTION_TIMEOUT,
2625
+ requestTimeout: DEFAULT_TIMEOUT,
2626
+ httpsAgent: agent,
2627
+ httpAgent: agent
2628
+ };
2629
+ }
2617
2630
 
2618
2631
  // ../tmp-toolkit-helpers/src/api/aws-auth/credential-plugins.ts
2619
2632
  var import_util9 = require("util");
2620
2633
  var CredentialPlugins = class {
2621
- cache = {};
2622
- host;
2623
- ioHelper;
2624
2634
  constructor(host, ioHelper) {
2625
2635
  this.host = host;
2626
2636
  this.ioHelper = ioHelper;
2627
2637
  }
2638
+ cache = {};
2628
2639
  async fetchCredentialsFor(awsAccountId, mode) {
2629
2640
  const key = `${awsAccountId}-${mode}`;
2630
2641
  if (!(key in this.cache)) {
@@ -2731,35 +2742,56 @@ var TESTING = false;
2731
2742
  function markTesting() {
2732
2743
  TESTING = true;
2733
2744
  }
2734
- var PluginHost = class _PluginHost {
2735
- static instance = new _PluginHost();
2745
+ var PluginHost = class {
2736
2746
  /**
2737
2747
  * Access the currently registered CredentialProviderSources. New sources can
2738
2748
  * be registered using the +registerCredentialProviderSource+ method.
2739
2749
  */
2740
2750
  credentialProviderSources = new Array();
2741
2751
  contextProviderPlugins = {};
2742
- constructor() {
2743
- if (!TESTING && _PluginHost.instance && _PluginHost.instance !== this) {
2744
- throw new ToolkitError("New instances of PluginHost must not be built. Use PluginHost.instance instead!");
2745
- }
2746
- }
2752
+ ioHost;
2753
+ alreadyLoaded = /* @__PURE__ */ new Set();
2747
2754
  /**
2748
2755
  * Loads a plug-in into this PluginHost.
2749
2756
  *
2757
+ * Will use `require.resolve()` to get the most accurate representation of what
2758
+ * code will get loaded in error messages. As such, it will not work in
2759
+ * unit tests with Jest virtual modules becauase of <https://github.com/jestjs/jest/issues/9543>.
2760
+ *
2750
2761
  * @param moduleSpec the specification (path or name) of the plug-in module to be loaded.
2762
+ * @param ioHost the I/O host to use for printing progress information
2763
+ */
2764
+ load(moduleSpec, ioHost) {
2765
+ try {
2766
+ const resolved = require.resolve(moduleSpec);
2767
+ if (ioHost) {
2768
+ new IoDefaultMessages(IoHelper.fromIoHost(ioHost, "init")).debug(`Loading plug-in: ${resolved} from ${moduleSpec}`);
2769
+ }
2770
+ return this._doLoad(resolved);
2771
+ } catch (e) {
2772
+ throw new ToolkitError(`Unable to resolve plug-in: Cannot find module '${moduleSpec}': ${e}`);
2773
+ }
2774
+ }
2775
+ /**
2776
+ * Do the loading given an already-resolved module name
2777
+ *
2778
+ * @internal
2751
2779
  */
2752
- load(moduleSpec) {
2780
+ _doLoad(resolved) {
2753
2781
  try {
2754
- const plugin = require(moduleSpec);
2782
+ if (this.alreadyLoaded.has(resolved)) {
2783
+ return;
2784
+ }
2785
+ const plugin = require(resolved);
2755
2786
  if (!isPlugin(plugin)) {
2756
- throw new ToolkitError(`Module ${moduleSpec} is not a valid plug-in, or has an unsupported version.`);
2787
+ throw new ToolkitError(`Module ${resolved} is not a valid plug-in, or has an unsupported version.`);
2757
2788
  }
2758
2789
  if (plugin.init) {
2759
2790
  plugin.init(this);
2760
2791
  }
2792
+ this.alreadyLoaded.add(resolved);
2761
2793
  } catch (e) {
2762
- throw ToolkitError.withCause(`Unable to load plug-in '${moduleSpec}'`, e);
2794
+ throw ToolkitError.withCause(`Unable to load plug-in '${resolved}'`, e);
2763
2795
  }
2764
2796
  function isPlugin(x) {
2765
2797
  return x != null && x.version === "1";
@@ -2823,14 +2855,6 @@ var Mode = /* @__PURE__ */ ((Mode2) => {
2823
2855
  // ../tmp-toolkit-helpers/src/api/aws-auth/sdk-provider.ts
2824
2856
  var CACHED_ACCOUNT = Symbol("cached_account");
2825
2857
  var SdkProvider = class {
2826
- constructor(defaultCredentialProvider, defaultRegion, requestHandler = {}, ioHelper, logger) {
2827
- this.defaultCredentialProvider = defaultCredentialProvider;
2828
- this.defaultRegion = defaultRegion;
2829
- this.requestHandler = requestHandler;
2830
- this.ioHelper = ioHelper;
2831
- this.logger = logger;
2832
- this.plugins = new CredentialPlugins(PluginHost.instance, ioHelper);
2833
- }
2834
2858
  /**
2835
2859
  * Create a new SdkProvider which gets its defaults in a way that behaves like the AWS CLI does
2836
2860
  *
@@ -2838,18 +2862,24 @@ var SdkProvider = class {
2838
2862
  * class `AwsCliCompatible` for the details.
2839
2863
  */
2840
2864
  static async withAwsCliCompatibleDefaults(options) {
2841
- const builder = new AwsCliCompatible(options.ioHelper);
2842
2865
  callTrace(SdkProvider.withAwsCliCompatibleDefaults.name, SdkProvider.constructor.name, options.logger);
2843
- const credentialProvider = await builder.credentialChainBuilder({
2844
- profile: options.profile,
2845
- httpOptions: options.httpOptions,
2846
- logger: options.logger
2847
- });
2848
- const region = await builder.region(options.profile);
2849
- const requestHandler = await builder.requestHandlerBuilder(options.httpOptions);
2850
- return new SdkProvider(credentialProvider, region, requestHandler, options.ioHelper, options.logger);
2866
+ const config = await new AwsCliCompatible(options.ioHelper, options.requestHandler ?? {}, options.logger).baseConfig(options.profile);
2867
+ return new SdkProvider(config.credentialProvider, config.defaultRegion, options);
2851
2868
  }
2869
+ defaultRegion;
2870
+ defaultCredentialProvider;
2852
2871
  plugins;
2872
+ requestHandler;
2873
+ ioHelper;
2874
+ logger;
2875
+ constructor(defaultCredentialProvider, defaultRegion, services) {
2876
+ this.defaultCredentialProvider = defaultCredentialProvider;
2877
+ this.defaultRegion = defaultRegion ?? "us-east-1";
2878
+ this.requestHandler = services.requestHandler ?? {};
2879
+ this.ioHelper = services.ioHelper;
2880
+ this.logger = services.logger;
2881
+ this.plugins = new CredentialPlugins(services.pluginHost ?? new PluginHost(), this.ioHelper);
2882
+ }
2853
2883
  /**
2854
2884
  * Return an SDK which can do operations in the given environment
2855
2885
  *
@@ -2865,7 +2895,7 @@ var SdkProvider = class {
2865
2895
  if (baseCreds.source === "incorrectDefault") {
2866
2896
  throw new AuthenticationError(fmtObtainCredentialsError(env.account, baseCreds));
2867
2897
  }
2868
- const sdk = new SDK(baseCreds.credentials, env.region, this.requestHandler, this.ioHelper, this.logger);
2898
+ const sdk = this._makeSdk(baseCreds.credentials, env.region);
2869
2899
  await sdk.validateCredentials();
2870
2900
  return { sdk, didAssumeRole: false };
2871
2901
  }
@@ -2889,7 +2919,7 @@ var SdkProvider = class {
2889
2919
  `${fmtObtainedCredentials(baseCreds)} could not be used to assume '${options.assumeRoleArn}', but are for the right account. Proceeding anyway.`
2890
2920
  ));
2891
2921
  return {
2892
- sdk: new SDK(baseCreds.credentials, env.region, this.requestHandler, this.ioHelper, this.logger),
2922
+ sdk: this._makeSdk(baseCreds.credentials, env.region),
2893
2923
  didAssumeRole: false
2894
2924
  };
2895
2925
  }
@@ -2907,7 +2937,7 @@ var SdkProvider = class {
2907
2937
  if (baseCreds.source === "none") {
2908
2938
  return void 0;
2909
2939
  }
2910
- return (await new SDK(baseCreds.credentials, env.region, this.requestHandler, this.ioHelper, this.logger).currentAccount()).partition;
2940
+ return (await this._makeSdk(baseCreds.credentials, env.region).currentAccount()).partition;
2911
2941
  }
2912
2942
  /**
2913
2943
  * Resolve the environment for a stack
@@ -2949,7 +2979,7 @@ var SdkProvider = class {
2949
2979
  async defaultAccount() {
2950
2980
  return cached(this, CACHED_ACCOUNT, async () => {
2951
2981
  try {
2952
- return await new SDK(this.defaultCredentialProvider, this.defaultRegion, this.requestHandler, this.ioHelper, this.logger).currentAccount();
2982
+ return await this._makeSdk(this.defaultCredentialProvider, this.defaultRegion).currentAccount();
2953
2983
  } catch (e) {
2954
2984
  if (e.name === "ExpiredToken") {
2955
2985
  await this.ioHelper.notify(IO.DEFAULT_SDK_WARN.msg(
@@ -3026,7 +3056,7 @@ var SdkProvider = class {
3026
3056
  logger: this.logger
3027
3057
  }));
3028
3058
  await credentials();
3029
- return new SDK(credentials, region, this.requestHandler, this.ioHelper, this.logger);
3059
+ return this._makeSdk(credentials, region);
3030
3060
  } catch (err) {
3031
3061
  if (err.name === "ExpiredToken") {
3032
3062
  throw err;
@@ -3042,6 +3072,25 @@ var SdkProvider = class {
3042
3072
  );
3043
3073
  }
3044
3074
  }
3075
+ /**
3076
+ * Factory function that creates a new SDK instance
3077
+ *
3078
+ * This is a function here, instead of all the places where this is used creating a `new SDK`
3079
+ * instance, so that it is trivial to mock from tests.
3080
+ *
3081
+ * Use like this:
3082
+ *
3083
+ * ```ts
3084
+ * const mockSdk = jest.spyOn(SdkProvider.prototype, '_makeSdk').mockReturnValue(new MockSdk());
3085
+ * // ...
3086
+ * mockSdk.mockRestore();
3087
+ * ```
3088
+ *
3089
+ * @internal
3090
+ */
3091
+ _makeSdk(credProvider, region) {
3092
+ return new SDK(credProvider, region, this.requestHandler, this.ioHelper, this.logger);
3093
+ }
3045
3094
  };
3046
3095
  SdkProvider = __decorateClass([
3047
3096
  traceMemberMethods
@@ -12315,13 +12364,13 @@ var ContextProviderMessages = class {
12315
12364
  }));
12316
12365
  }
12317
12366
  };
12318
- async function provideContextValues(missingValues, context, sdk, ioHelper) {
12367
+ async function provideContextValues(missingValues, context, sdk, pluginHost, ioHelper) {
12319
12368
  for (const missingContext of missingValues) {
12320
12369
  const key = missingContext.key;
12321
12370
  const providerName = missingContext.provider === cxschema4.ContextProvider.PLUGIN ? `${PLUGIN_PROVIDER_PREFIX}:${missingContext.props.pluginName}` : missingContext.provider;
12322
12371
  let factory;
12323
12372
  if (providerName.startsWith(`${PLUGIN_PROVIDER_PREFIX}:`)) {
12324
- const plugin = PluginHost.instance.contextProviderPlugins[providerName.substring(PLUGIN_PROVIDER_PREFIX.length + 1)];
12373
+ const plugin = pluginHost.contextProviderPlugins[providerName.substring(PLUGIN_PROVIDER_PREFIX.length + 1)];
12325
12374
  if (!plugin) {
12326
12375
  throw new ContextProviderError(`Unrecognized plugin context provider name: ${missingContext.provider}.`);
12327
12376
  }
@@ -12490,6 +12539,7 @@ var availableContextProviders = {
12490
12539
  loadTree,
12491
12540
  loadTreeFromDir,
12492
12541
  makeBodyParameter,
12542
+ makeRequestHandler,
12493
12543
  markTesting,
12494
12544
  nonHotswappableChange,
12495
12545
  nonHotswappableResource,