@aws-cdk-testing/cli-integ 3.3.2 → 3.3.3

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.
package/lib/with-sam.js CHANGED
@@ -125,6 +125,8 @@ class SamIntegrationTestFixture extends with_cdk_app_1.TestFixture {
125
125
  const args = isBuilt ? [] : ['--template', templatePath.toString()];
126
126
  args.push('--port');
127
127
  args.push(port.toString());
128
+ // https://github.com/aws/aws-sam-cli/pull/7892
129
+ args.push('--no-memory-limit');
128
130
  // "Press Ctrl+C to quit" looks to be printed by a Flask server built into SAM CLI.
129
131
  return this.samShell(['sam', 'local', 'start-api', ...args], 'Press CTRL+C to quit', () => {
130
132
  return new Promise((resolve, reject) => {
@@ -261,4 +263,4 @@ function killSubProcess(child, command) {
261
263
  child.kill('SIGINT');
262
264
  child_process.exec(`for pid in $(ps -ef | grep "${command}" | awk '{print $2}'); do kill -2 $pid; done`);
263
265
  }
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-sam.js","sourceRoot":"","sources":["with-sam.ts"],"names":[],"mappings":"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","sourcesContent":["import * as child_process from 'child_process';\nimport * as os from 'os';\nimport * as path from 'path';\nimport axios from 'axios';\nimport { TestContext } from './integ-test';\nimport { RESOURCES_DIR } from './resources';\nimport { ShellOptions, rimraf } from './shell';\nimport { AwsContext, withAws } from './with-aws';\nimport { cloneDirectory, installNpmPackages, TestFixture, DEFAULT_TEST_TIMEOUT_S } from './with-cdk-app';\nimport { withTimeout } from './with-timeout';\n\nexport interface ActionOutput {\n  actionSucceeded?: boolean;\n  actionOutput?: any;\n  shellOutput?: string;\n}\n\n/**\n * Higher order function to execute a block with a SAM Integration CDK app fixture\n */\nexport function withSamIntegrationCdkApp<A extends TestContext & AwsContext>(block: (context: SamIntegrationTestFixture) => Promise<void>) {\n  return async (context: A) => {\n    const randy = context.randomString;\n    const stackNamePrefix = `cdktest-${randy}`;\n    const integTestDir = path.join(os.tmpdir(), `cdk-integ-${randy}`);\n\n    context.log(` Stack prefix:   ${stackNamePrefix}\\n`);\n    context.log(` Test directory: ${integTestDir}\\n`);\n    context.log(` Region:         ${context.aws.region}\\n`);\n\n    await cloneDirectory(path.join(RESOURCES_DIR, 'cdk-apps', 'sam_cdk_integ_app'), integTestDir, context.output);\n    const fixture = new SamIntegrationTestFixture(\n      integTestDir,\n      stackNamePrefix,\n      context.output,\n      context.aws,\n      context.randomString);\n\n    let success = true;\n    try {\n      const installationVersion = fixture.packages.requestedFrameworkVersion();\n\n      if (fixture.packages.majorVersion() === '1') {\n        await installNpmPackages(fixture, {\n          '@aws-cdk/aws-iam': installationVersion,\n          '@aws-cdk/aws-apigateway': installationVersion,\n          '@aws-cdk/aws-lambda': installationVersion,\n          '@aws-cdk/aws-lambda-go': installationVersion,\n          '@aws-cdk/aws-lambda-nodejs': installationVersion,\n          '@aws-cdk/aws-lambda-python': installationVersion,\n          '@aws-cdk/aws-logs': installationVersion,\n          '@aws-cdk/core': installationVersion,\n          'constructs': '^3',\n        });\n      } else {\n        const alphaInstallationVersion = fixture.packages.requestedAlphaVersion();\n        await installNpmPackages(fixture, {\n          'aws-cdk-lib': installationVersion,\n          '@aws-cdk/aws-lambda-go-alpha': alphaInstallationVersion,\n          '@aws-cdk/aws-lambda-python-alpha': alphaInstallationVersion,\n          'constructs': '^10',\n        });\n      }\n      await block(fixture);\n    } catch (e: any) {\n      // We survive certain cases involving gopkg.in\n      if (errorCausedByGoPkg(e.message)) {\n        return;\n      }\n      success = false;\n      throw e;\n    } finally {\n      if (process.env.INTEG_NO_CLEAN) {\n        context.log(`Left test directory in '${integTestDir}' ($INTEG_NO_CLEAN)\\n`);\n      } else {\n        await fixture.dispose(success);\n      }\n    }\n  };\n}\n\n/**\n * Return whether or not the error is being caused by gopkg.in being down\n *\n * Our Go build depends on https://gopkg.in/, which has errors pretty often\n * (every couple of days). It is run by a single volunteer.\n */\nfunction errorCausedByGoPkg(error: string) {\n  // The error is different depending on what request fails. Messages recognized:\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git ls-remote -q origin in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        remote: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  //        fatal: unable to access 'https://gopkg.in/yaml.v3/': The requested URL returned error: 502\n  ////////////////////////////////////////////////////////////////////\n  //    go: downloading github.com/aws/aws-lambda-go v1.28.0\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: unrecognized import path \"gopkg.in/yaml.v3\": reading https://gopkg.in/yaml.v3?go-get=1: 502 Bad Gateway\n  //        server response: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git fetch -f origin refs/heads/*:refs/heads/* refs/tags/*:refs/tags/* in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        error: RPC failed; HTTP 502 curl 22 The requested URL returned error: 502\n  //        fatal: the remote end hung up unexpectedly\n  ////////////////////////////////////////////////////////////////////\n\n  return (error.includes('gopkg\\.in.*invalid version.*exit status 128')\n    || error.match(/unrecognized import path[^\\n]gopkg\\.in/));\n}\n\n/**\n * SAM Integration test fixture for CDK - SAM integration test cases\n */\nexport function withSamIntegrationFixture(block: (context: SamIntegrationTestFixture) => Promise<void>) {\n  return withAws(withTimeout(DEFAULT_TEST_TIMEOUT_S, withSamIntegrationCdkApp(block)));\n}\n\nexport class SamIntegrationTestFixture extends TestFixture {\n  public async samShell(command: string[], filter?: string, action?: () => any, options: Omit<ShellOptions, 'cwd' | 'output'> = {}): Promise<ActionOutput> {\n    return shellWithAction(command, filter, action, {\n      outputs: [this.output],\n      cwd: path.join(this.integTestDir, 'cdk.out').toString(),\n      ...options,\n    });\n  }\n\n  public async samBuild(stackName: string) {\n    const fullStackName = this.fullStackName(stackName);\n    const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);\n    const args = ['--template', templatePath.toString()];\n    return this.samShell(['sam', 'build', ...args]);\n  }\n\n  public async samLocalStartApi(stackName: string, isBuilt: boolean, port: number, apiPath: string): Promise<ActionOutput> {\n    const fullStackName = this.fullStackName(stackName);\n    const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);\n    const args = isBuilt? [] : ['--template', templatePath.toString()];\n    args.push('--port');\n    args.push(port.toString());\n\n    // \"Press Ctrl+C to quit\" looks to be printed by a Flask server built into SAM CLI.\n    return this.samShell(['sam', 'local', 'start-api', ...args], 'Press CTRL+C to quit', ()=>{\n      return new Promise<ActionOutput>((resolve, reject) => {\n        axios.get(`http://127.0.0.1:${port}${apiPath}`).then( resp => {\n          resolve(resp.data);\n        }).catch( error => {\n          reject(new Error(`Failed to invoke api path ${apiPath} on port ${port} with error ${error}`));\n        });\n      });\n    });\n  }\n\n  /**\n   * Cleanup leftover stacks and buckets\n   */\n  public async dispose(success: boolean) {\n    // If the tests completed successfully, happily delete the fixture\n    // (otherwise leave it for humans to inspect)\n    if (success) {\n      const cleaned = rimraf(this.integTestDir);\n      if (!cleaned) {\n        // eslint-disable-next-line no-console\n        console.error(`Failed to clean up ${this.integTestDir} due to permissions issues (Docker running as root?)`);\n      }\n    }\n  }\n}\n\nexport function randomInteger(min: number, max: number) {\n  return Math.floor(Math.random() * (max - min) + min);\n}\n\n/**\n * A shell command that does what you want\n *\n * Is platform-aware, handles errors nicely.\n */\nexport async function shellWithAction(\n  command: string[],\n  filter?: string,\n  action?: () => Promise<any>,\n  options: ShellOptions = {},\n  actionTimeoutSeconds: number = 600,\n): Promise<ActionOutput> {\n  if (options.modEnv && options.env) {\n    throw new Error('Use either env or modEnv but not both');\n  }\n\n  const writeToOutputs = (x: string) => {\n    for (const output of options.outputs ?? []) {\n      output.write(x);\n    }\n  };\n  writeToOutputs(`💻 ${command.join(' ')}\\n`);\n\n  const env = options.env ?? (options.modEnv ? { ...process.env, ...options.modEnv } : undefined);\n\n  const child = child_process.spawn(command[0], command.slice(1), {\n    ...options,\n    env,\n    // Need this for Windows where we want .cmd and .bat to be found as well.\n    shell: true,\n    stdio: ['ignore', 'pipe', 'pipe'],\n  });\n\n  return new Promise<ActionOutput>((resolve, reject) => {\n    const out = new Array<Buffer>();\n    const stdout = new Array<Buffer>();\n    const stderr = new Array<Buffer>();\n    let actionSucceeded = false;\n    let actionOutput: any;\n    let actionExecuted = false;\n\n    async function maybeExecuteAction(chunk: any) {\n      out.push(Buffer.from(chunk));\n      if (!actionExecuted && typeof filter === 'string' && Buffer.concat(out).toString('utf-8').includes(filter) && typeof action === 'function') {\n        actionExecuted = true;\n        writeToOutputs('before executing action\\n');\n        try {\n          const output = await action();\n          writeToOutputs(`action output is ${JSON.stringify(output)}\\n`);\n          actionOutput = output;\n          actionSucceeded = true;\n        } catch (error: any) {\n          writeToOutputs(`action error is ${error}\\n`);\n          actionSucceeded = false;\n          actionOutput = error;\n        } finally {\n          writeToOutputs('terminate sam sub process\\n');\n          killSubProcess(child, command.join(' '));\n        }\n      }\n    }\n\n    if (typeof filter === 'string' && typeof action === 'function') {\n      // Reject with an error if an action is configured, but the filter failed\n      // to show up in the output before the timeout occurred.\n      setTimeout(\n        () => {\n          if (!actionExecuted) {\n            reject(new Error(`Timed out waiting for filter ${JSON.stringify(filter)} to appear in command output after ${actionTimeoutSeconds} seconds\\nOutput so far:\\n${Buffer.concat(out).toString('utf-8')}`));\n            killSubProcess(child, command.join(' '));\n          }\n        }, actionTimeoutSeconds * 1_000,\n      ).unref();\n    }\n\n    child.stdout!.on('data', chunk => {\n      writeToOutputs(chunk);\n      stdout.push(chunk);\n      void maybeExecuteAction(chunk);\n    });\n\n    child.stderr!.on('data', chunk => {\n      writeToOutputs(chunk);\n      if (options.captureStderr ?? true) {\n        stderr.push(chunk);\n      }\n      void maybeExecuteAction(chunk);\n    });\n\n    child.once('error', reject);\n\n    // Wait for 'exit' instead of close, don't care about reading the streams all the way to the end\n    child.once('exit', (code, signal) => {\n      writeToOutputs(`Subprocess has exited with code ${code}, signal ${signal}\\n`);\n      const output = (Buffer.concat(stdout).toString('utf-8') + Buffer.concat(stderr).toString('utf-8')).trim();\n      if (code == null || code === 0 || options.allowErrExit) {\n        let result = new Array<string>();\n        result.push(actionOutput);\n        result.push(output);\n        resolve({\n          actionSucceeded: actionSucceeded,\n          actionOutput: actionOutput,\n          shellOutput: output,\n        });\n      } else {\n        reject(new Error(`'${command.join(' ')}' exited with error code ${code}. Output: \\n${output}`));\n      }\n    });\n  });\n}\n\nfunction killSubProcess(child: child_process.ChildProcess, command: string) {\n  /**\n   * Check if the sub process is running in container, so child_process.spawn will\n   * create multiple processes, and to kill all of them we need to run different logic\n   */\n  child.kill('SIGINT');\n  child_process.exec(`for pid in $(ps -ef | grep \"${command}\" | awk '{print $2}'); do kill -2 $pid; done`);\n}\n"]}
266
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-sam.js","sourceRoot":"","sources":["with-sam.ts"],"names":[],"mappings":"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","sourcesContent":["import * as child_process from 'child_process';\nimport * as os from 'os';\nimport * as path from 'path';\nimport axios from 'axios';\nimport { TestContext } from './integ-test';\nimport { RESOURCES_DIR } from './resources';\nimport { ShellOptions, rimraf } from './shell';\nimport { AwsContext, withAws } from './with-aws';\nimport { cloneDirectory, installNpmPackages, TestFixture, DEFAULT_TEST_TIMEOUT_S } from './with-cdk-app';\nimport { withTimeout } from './with-timeout';\n\nexport interface ActionOutput {\n  actionSucceeded?: boolean;\n  actionOutput?: any;\n  shellOutput?: string;\n}\n\n/**\n * Higher order function to execute a block with a SAM Integration CDK app fixture\n */\nexport function withSamIntegrationCdkApp<A extends TestContext & AwsContext>(block: (context: SamIntegrationTestFixture) => Promise<void>) {\n  return async (context: A) => {\n    const randy = context.randomString;\n    const stackNamePrefix = `cdktest-${randy}`;\n    const integTestDir = path.join(os.tmpdir(), `cdk-integ-${randy}`);\n\n    context.log(` Stack prefix:   ${stackNamePrefix}\\n`);\n    context.log(` Test directory: ${integTestDir}\\n`);\n    context.log(` Region:         ${context.aws.region}\\n`);\n\n    await cloneDirectory(path.join(RESOURCES_DIR, 'cdk-apps', 'sam_cdk_integ_app'), integTestDir, context.output);\n    const fixture = new SamIntegrationTestFixture(\n      integTestDir,\n      stackNamePrefix,\n      context.output,\n      context.aws,\n      context.randomString);\n\n    let success = true;\n    try {\n      const installationVersion = fixture.packages.requestedFrameworkVersion();\n\n      if (fixture.packages.majorVersion() === '1') {\n        await installNpmPackages(fixture, {\n          '@aws-cdk/aws-iam': installationVersion,\n          '@aws-cdk/aws-apigateway': installationVersion,\n          '@aws-cdk/aws-lambda': installationVersion,\n          '@aws-cdk/aws-lambda-go': installationVersion,\n          '@aws-cdk/aws-lambda-nodejs': installationVersion,\n          '@aws-cdk/aws-lambda-python': installationVersion,\n          '@aws-cdk/aws-logs': installationVersion,\n          '@aws-cdk/core': installationVersion,\n          'constructs': '^3',\n        });\n      } else {\n        const alphaInstallationVersion = fixture.packages.requestedAlphaVersion();\n        await installNpmPackages(fixture, {\n          'aws-cdk-lib': installationVersion,\n          '@aws-cdk/aws-lambda-go-alpha': alphaInstallationVersion,\n          '@aws-cdk/aws-lambda-python-alpha': alphaInstallationVersion,\n          'constructs': '^10',\n        });\n      }\n      await block(fixture);\n    } catch (e: any) {\n      // We survive certain cases involving gopkg.in\n      if (errorCausedByGoPkg(e.message)) {\n        return;\n      }\n      success = false;\n      throw e;\n    } finally {\n      if (process.env.INTEG_NO_CLEAN) {\n        context.log(`Left test directory in '${integTestDir}' ($INTEG_NO_CLEAN)\\n`);\n      } else {\n        await fixture.dispose(success);\n      }\n    }\n  };\n}\n\n/**\n * Return whether or not the error is being caused by gopkg.in being down\n *\n * Our Go build depends on https://gopkg.in/, which has errors pretty often\n * (every couple of days). It is run by a single volunteer.\n */\nfunction errorCausedByGoPkg(error: string) {\n  // The error is different depending on what request fails. Messages recognized:\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git ls-remote -q origin in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        remote: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  //        fatal: unable to access 'https://gopkg.in/yaml.v3/': The requested URL returned error: 502\n  ////////////////////////////////////////////////////////////////////\n  //    go: downloading github.com/aws/aws-lambda-go v1.28.0\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: unrecognized import path \"gopkg.in/yaml.v3\": reading https://gopkg.in/yaml.v3?go-get=1: 502 Bad Gateway\n  //        server response: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git fetch -f origin refs/heads/*:refs/heads/* refs/tags/*:refs/tags/* in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        error: RPC failed; HTTP 502 curl 22 The requested URL returned error: 502\n  //        fatal: the remote end hung up unexpectedly\n  ////////////////////////////////////////////////////////////////////\n\n  return (error.includes('gopkg\\.in.*invalid version.*exit status 128')\n    || error.match(/unrecognized import path[^\\n]gopkg\\.in/));\n}\n\n/**\n * SAM Integration test fixture for CDK - SAM integration test cases\n */\nexport function withSamIntegrationFixture(block: (context: SamIntegrationTestFixture) => Promise<void>) {\n  return withAws(withTimeout(DEFAULT_TEST_TIMEOUT_S, withSamIntegrationCdkApp(block)));\n}\n\nexport class SamIntegrationTestFixture extends TestFixture {\n  public async samShell(command: string[], filter?: string, action?: () => any, options: Omit<ShellOptions, 'cwd' | 'output'> = {}): Promise<ActionOutput> {\n    return shellWithAction(command, filter, action, {\n      outputs: [this.output],\n      cwd: path.join(this.integTestDir, 'cdk.out').toString(),\n      ...options,\n    });\n  }\n\n  public async samBuild(stackName: string) {\n    const fullStackName = this.fullStackName(stackName);\n    const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);\n    const args = ['--template', templatePath.toString()];\n    return this.samShell(['sam', 'build', ...args]);\n  }\n\n  public async samLocalStartApi(stackName: string, isBuilt: boolean, port: number, apiPath: string): Promise<ActionOutput> {\n    const fullStackName = this.fullStackName(stackName);\n    const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);\n    const args = isBuilt? [] : ['--template', templatePath.toString()];\n    args.push('--port');\n    args.push(port.toString());\n\n    // https://github.com/aws/aws-sam-cli/pull/7892\n    args.push('--no-memory-limit')\n\n    // \"Press Ctrl+C to quit\" looks to be printed by a Flask server built into SAM CLI.\n    return this.samShell(['sam', 'local', 'start-api', ...args], 'Press CTRL+C to quit', ()=>{\n      return new Promise<ActionOutput>((resolve, reject) => {\n        axios.get(`http://127.0.0.1:${port}${apiPath}`).then( resp => {\n          resolve(resp.data);\n        }).catch( error => {\n          reject(new Error(`Failed to invoke api path ${apiPath} on port ${port} with error ${error}`));\n        });\n      });\n    });\n  }\n\n  /**\n   * Cleanup leftover stacks and buckets\n   */\n  public async dispose(success: boolean) {\n    // If the tests completed successfully, happily delete the fixture\n    // (otherwise leave it for humans to inspect)\n    if (success) {\n      const cleaned = rimraf(this.integTestDir);\n      if (!cleaned) {\n        // eslint-disable-next-line no-console\n        console.error(`Failed to clean up ${this.integTestDir} due to permissions issues (Docker running as root?)`);\n      }\n    }\n  }\n}\n\nexport function randomInteger(min: number, max: number) {\n  return Math.floor(Math.random() * (max - min) + min);\n}\n\n/**\n * A shell command that does what you want\n *\n * Is platform-aware, handles errors nicely.\n */\nexport async function shellWithAction(\n  command: string[],\n  filter?: string,\n  action?: () => Promise<any>,\n  options: ShellOptions = {},\n  actionTimeoutSeconds: number = 600,\n): Promise<ActionOutput> {\n  if (options.modEnv && options.env) {\n    throw new Error('Use either env or modEnv but not both');\n  }\n\n  const writeToOutputs = (x: string) => {\n    for (const output of options.outputs ?? []) {\n      output.write(x);\n    }\n  };\n  writeToOutputs(`💻 ${command.join(' ')}\\n`);\n\n  const env = options.env ?? (options.modEnv ? { ...process.env, ...options.modEnv } : undefined);\n\n  const child = child_process.spawn(command[0], command.slice(1), {\n    ...options,\n    env,\n    // Need this for Windows where we want .cmd and .bat to be found as well.\n    shell: true,\n    stdio: ['ignore', 'pipe', 'pipe'],\n  });\n\n  return new Promise<ActionOutput>((resolve, reject) => {\n    const out = new Array<Buffer>();\n    const stdout = new Array<Buffer>();\n    const stderr = new Array<Buffer>();\n    let actionSucceeded = false;\n    let actionOutput: any;\n    let actionExecuted = false;\n\n    async function maybeExecuteAction(chunk: any) {\n      out.push(Buffer.from(chunk));\n      if (!actionExecuted && typeof filter === 'string' && Buffer.concat(out).toString('utf-8').includes(filter) && typeof action === 'function') {\n        actionExecuted = true;\n        writeToOutputs('before executing action\\n');\n        try {\n          const output = await action();\n          writeToOutputs(`action output is ${JSON.stringify(output)}\\n`);\n          actionOutput = output;\n          actionSucceeded = true;\n        } catch (error: any) {\n          writeToOutputs(`action error is ${error}\\n`);\n          actionSucceeded = false;\n          actionOutput = error;\n        } finally {\n          writeToOutputs('terminate sam sub process\\n');\n          killSubProcess(child, command.join(' '));\n        }\n      }\n    }\n\n    if (typeof filter === 'string' && typeof action === 'function') {\n      // Reject with an error if an action is configured, but the filter failed\n      // to show up in the output before the timeout occurred.\n      setTimeout(\n        () => {\n          if (!actionExecuted) {\n            reject(new Error(`Timed out waiting for filter ${JSON.stringify(filter)} to appear in command output after ${actionTimeoutSeconds} seconds\\nOutput so far:\\n${Buffer.concat(out).toString('utf-8')}`));\n            killSubProcess(child, command.join(' '));\n          }\n        }, actionTimeoutSeconds * 1_000,\n      ).unref();\n    }\n\n    child.stdout!.on('data', chunk => {\n      writeToOutputs(chunk);\n      stdout.push(chunk);\n      void maybeExecuteAction(chunk);\n    });\n\n    child.stderr!.on('data', chunk => {\n      writeToOutputs(chunk);\n      if (options.captureStderr ?? true) {\n        stderr.push(chunk);\n      }\n      void maybeExecuteAction(chunk);\n    });\n\n    child.once('error', reject);\n\n    // Wait for 'exit' instead of close, don't care about reading the streams all the way to the end\n    child.once('exit', (code, signal) => {\n      writeToOutputs(`Subprocess has exited with code ${code}, signal ${signal}\\n`);\n      const output = (Buffer.concat(stdout).toString('utf-8') + Buffer.concat(stderr).toString('utf-8')).trim();\n      if (code == null || code === 0 || options.allowErrExit) {\n        let result = new Array<string>();\n        result.push(actionOutput);\n        result.push(output);\n        resolve({\n          actionSucceeded: actionSucceeded,\n          actionOutput: actionOutput,\n          shellOutput: output,\n        });\n      } else {\n        reject(new Error(`'${command.join(' ')}' exited with error code ${code}. Output: \\n${output}`));\n      }\n    });\n  });\n}\n\nfunction killSubProcess(child: child_process.ChildProcess, command: string) {\n  /**\n   * Check if the sub process is running in container, so child_process.spawn will\n   * create multiple processes, and to kill all of them we need to run different logic\n   */\n  child.kill('SIGINT');\n  child_process.exec(`for pid in $(ps -ef | grep \"${command}\" | awk '{print $2}'); do kill -2 $pid; done`);\n}\n"]}
package/lib/with-sam.ts CHANGED
@@ -138,6 +138,9 @@ export class SamIntegrationTestFixture extends TestFixture {
138
138
  args.push('--port');
139
139
  args.push(port.toString());
140
140
 
141
+ // https://github.com/aws/aws-sam-cli/pull/7892
142
+ args.push('--no-memory-limit')
143
+
141
144
  // "Press Ctrl+C to quit" looks to be printed by a Flask server built into SAM CLI.
142
145
  return this.samShell(['sam', 'local', 'start-api', ...args], 'Press CTRL+C to quit', ()=>{
143
146
  return new Promise<ActionOutput>((resolve, reject) => {
package/package.json CHANGED
@@ -109,7 +109,7 @@
109
109
  "publishConfig": {
110
110
  "access": "public"
111
111
  },
112
- "version": "3.3.2",
112
+ "version": "3.3.3",
113
113
  "types": "lib/index.d.ts",
114
114
  "//": "~~ Generated by projen. To modify, edit .projenrc.js and run \"npx projen\"."
115
115
  }
@@ -47,7 +47,11 @@ async function mutateAmplifyDepOnCdk(context, cliVersion, libVersion) {
47
47
  // Be extra paranoid about the types here, since we don't fully control them
48
48
  assertIsObject(amplifyDepJson);
49
49
  assertIsStringArray(amplifyDepJson.defaultDevPackages);
50
- replacePackageVersionIn('aws-cdk', cliVersion, amplifyDepJson.defaultDevPackages);
50
+ // Amplify is removing the dependency on aws-cdk, since Amplify is now using the toolkit-lib
51
+ // To prepare for this change, we need allow both situations: aws-cdk being listed and not being listed
52
+ // Fix is to simply allow the replace operation to also NOT replace the version
53
+ // @see https://github.com/aws-amplify/amplify-backend/pull/2614
54
+ replacePackageVersionIn('aws-cdk', cliVersion, amplifyDepJson.defaultDevPackages, false);
51
55
  replacePackageVersionIn('aws-cdk-lib', libVersion, amplifyDepJson.defaultDevPackages);
52
56
  await fs_1.promises.writeFile(amplifyDepFile, JSON.stringify(amplifyDepJson, undefined, 2), { encoding: 'utf-8' });
53
57
  const packageJsonFile = path.join(context.integTestDir, 'package.json');
@@ -67,9 +71,9 @@ async function mutateAmplifyDepOnCdk(context, cliVersion, libVersion) {
67
71
  * ["package@version", "package@version", ...]
68
72
  * ```
69
73
  *
70
- * It's a failure if we don't find an entry to update.
74
+ * It's a failure if we don't find an entry to update, unless we explicitly pass an option to say that's okay.
71
75
  */
72
- function replacePackageVersionIn(packName, version, xs) {
76
+ function replacePackageVersionIn(packName, version, xs, failIfMissing = true) {
73
77
  let didUpdate = false;
74
78
  for (let i = 0; i < xs.length; i++) {
75
79
  if (xs[i].startsWith(`${packName}@`)) {
@@ -77,7 +81,7 @@ function replacePackageVersionIn(packName, version, xs) {
77
81
  didUpdate = true;
78
82
  }
79
83
  }
80
- if (!didUpdate) {
84
+ if (failIfMissing && !didUpdate) {
81
85
  throw new Error(`Did not find a package version to update for ${packName} in ${JSON.stringify(xs)}`);
82
86
  }
83
87
  }
@@ -91,4 +95,4 @@ function assertIsStringArray(xs) {
91
95
  throw new Error(`Expected list of strings, got ${JSON.stringify(xs)}`);
92
96
  }
93
97
  }
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify.integtest.js","sourceRoot":"","sources":["amplify.integtest.ts"],"names":[],"mappings":"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","sourcesContent":["import { promises as fs } from 'fs';\nimport * as path from 'path';\nimport { withToolContext } from './with-tool-context';\nimport { integTest, ShellHelper, TemporaryDirectoryContext } from '../../lib';\n\nconst TIMEOUT = 1800_000;\n\nintegTest('amplify integration', withToolContext(async (context) => {\n  const shell = ShellHelper.fromContext(context);\n\n  ////////////////////////////////////////////////////////////////////////\n  //  Make sure that create-amplify installs the right versions of the CLI and framework\n  //\n\n  // Install `create-amplify` without running it, then hack the json file with the\n  // package versions in it before we execute.\n  await shell.shell(['npm', 'init', '-y']);\n  await shell.shell(['npm', 'install', '--save-dev', 'create-amplify@latest']);\n  // This will create 'package.json' implicating a certain version of the CDK\n  await shell.shell(['npm', 'config', 'set', 'save-exact', 'true']);\n  await mutateAmplifyDepOnCdk(context, context.packages.requestedCliVersion(), context.packages.requestedFrameworkVersion());\n\n  ////////////////////////////////////////////////////////////////////////\n  //  Run the `npm create` workflow\n  //\n\n  // I tested to confirm that this will use the locally installed `create-amplify`\n  await shell.shell(['npm', 'create', '-y', 'amplify']);\n  await shell.shell(['npx', 'ampx', 'configure', 'telemetry', 'disable']);\n\n  await shell.shell(['npx', 'ampx', 'sandbox', '--once'], {\n    modEnv: {\n      AWS_REGION: context.aws.region,\n    },\n  });\n  try {\n\n    // Future code goes here, putting the try/finally here already so it doesn't\n    // get forgotten.\n\n  } finally {\n    await shell.shell(['npx', 'ampx', 'sandbox', 'delete', '--yes'], {\n      modEnv: {\n        AWS_REGION: context.aws.region,\n      },\n    });\n  }\n}), TIMEOUT);\n\nasync function mutateAmplifyDepOnCdk(context: TemporaryDirectoryContext, cliVersion: string, libVersion: string) {\n  // default_packages.json is where create-amplify reads when installing npm dependencies\n  const amplifyDepFile = path.join(context.integTestDir, 'node_modules', 'create-amplify', 'lib', 'default_packages.json');\n  const amplifyDepJson: unknown = JSON.parse(await fs.readFile(amplifyDepFile, { encoding: 'utf-8' }));\n\n  // Be extra paranoid about the types here, since we don't fully control them\n  assertIsObject(amplifyDepJson);\n  assertIsStringArray(amplifyDepJson.defaultDevPackages);\n\n  replacePackageVersionIn('aws-cdk', cliVersion, amplifyDepJson.defaultDevPackages);\n  replacePackageVersionIn('aws-cdk-lib', libVersion, amplifyDepJson.defaultDevPackages);\n\n  await fs.writeFile(amplifyDepFile, JSON.stringify(amplifyDepJson, undefined, 2), { encoding: 'utf-8' });\n\n  const packageJsonFile = path.join(context.integTestDir, 'package.json');\n  const packageJson: unknown = JSON.parse(await fs.readFile(packageJsonFile, { encoding: 'utf-8' }));\n\n  assertIsObject(packageJson);\n  packageJson.overrides = {\n    \"aws-cdk-lib\": libVersion,\n  };\n  await fs.writeFile(packageJsonFile, JSON.stringify(packageJson, undefined, 2), { encoding: 'utf-8' })\n}\n\n/**\n * Mutably update the given string array, replacing the version of packages with the given name\n *\n * We assume the list of packages is a string array of the form\n *\n * ```\n * [\"package@version\", \"package@version\", ...]\n * ```\n *\n * It's a failure if we don't find an entry to update.\n */\nfunction replacePackageVersionIn(packName: string, version: string, xs: string[]) {\n  let didUpdate = false;\n  for (let i = 0; i < xs.length; i++) {\n    if (xs[i].startsWith(`${packName}@`)) {\n      xs[i] = `${packName}@${version}`;\n      didUpdate = true;\n    }\n  }\n\n  if (!didUpdate) {\n    throw new Error(`Did not find a package version to update for ${packName} in ${JSON.stringify(xs)}`);\n  }\n}\n\nfunction assertIsObject(xs: unknown): asserts xs is Record<string, unknown> {\n  if (typeof xs !== 'object' || xs === null) {\n    throw new Error(`Expected object, got ${JSON.stringify(xs)}`);\n  }\n}\n\nfunction assertIsStringArray(xs: unknown): asserts xs is string[] {\n  if (!Array.isArray(xs) || xs.length === 0 || typeof xs[0] !== 'string') {\n    throw new Error(`Expected list of strings, got ${JSON.stringify(xs)}`);\n  }\n}\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify.integtest.js","sourceRoot":"","sources":["amplify.integtest.ts"],"names":[],"mappings":"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","sourcesContent":["import { promises as fs } from 'fs';\nimport * as path from 'path';\nimport { withToolContext } from './with-tool-context';\nimport { integTest, ShellHelper, TemporaryDirectoryContext } from '../../lib';\n\nconst TIMEOUT = 1800_000;\n\nintegTest('amplify integration', withToolContext(async (context) => {\n  const shell = ShellHelper.fromContext(context);\n\n  ////////////////////////////////////////////////////////////////////////\n  //  Make sure that create-amplify installs the right versions of the CLI and framework\n  //\n\n  // Install `create-amplify` without running it, then hack the json file with the\n  // package versions in it before we execute.\n  await shell.shell(['npm', 'init', '-y']);\n  await shell.shell(['npm', 'install', '--save-dev', 'create-amplify@latest']);\n  // This will create 'package.json' implicating a certain version of the CDK\n  await shell.shell(['npm', 'config', 'set', 'save-exact', 'true']);\n  await mutateAmplifyDepOnCdk(context, context.packages.requestedCliVersion(), context.packages.requestedFrameworkVersion());\n\n  ////////////////////////////////////////////////////////////////////////\n  //  Run the `npm create` workflow\n  //\n\n  // I tested to confirm that this will use the locally installed `create-amplify`\n  await shell.shell(['npm', 'create', '-y', 'amplify']);\n  await shell.shell(['npx', 'ampx', 'configure', 'telemetry', 'disable']);\n\n  await shell.shell(['npx', 'ampx', 'sandbox', '--once'], {\n    modEnv: {\n      AWS_REGION: context.aws.region,\n    },\n  });\n  try {\n\n    // Future code goes here, putting the try/finally here already so it doesn't\n    // get forgotten.\n\n  } finally {\n    await shell.shell(['npx', 'ampx', 'sandbox', 'delete', '--yes'], {\n      modEnv: {\n        AWS_REGION: context.aws.region,\n      },\n    });\n  }\n}), TIMEOUT);\n\nasync function mutateAmplifyDepOnCdk(context: TemporaryDirectoryContext, cliVersion: string, libVersion: string) {\n  // default_packages.json is where create-amplify reads when installing npm dependencies\n  const amplifyDepFile = path.join(context.integTestDir, 'node_modules', 'create-amplify', 'lib', 'default_packages.json');\n  const amplifyDepJson: unknown = JSON.parse(await fs.readFile(amplifyDepFile, { encoding: 'utf-8' }));\n\n  // Be extra paranoid about the types here, since we don't fully control them\n  assertIsObject(amplifyDepJson);\n  assertIsStringArray(amplifyDepJson.defaultDevPackages);\n\n  // Amplify is removing the dependency on aws-cdk, since Amplify is now using the toolkit-lib\n  // To prepare for this change, we need allow both situations: aws-cdk being listed and not being listed\n  // Fix is to simply allow the replace operation to also NOT replace the version\n  // @see https://github.com/aws-amplify/amplify-backend/pull/2614\n  replacePackageVersionIn('aws-cdk', cliVersion, amplifyDepJson.defaultDevPackages, false);\n  replacePackageVersionIn('aws-cdk-lib', libVersion, amplifyDepJson.defaultDevPackages);\n\n  await fs.writeFile(amplifyDepFile, JSON.stringify(amplifyDepJson, undefined, 2), { encoding: 'utf-8' });\n\n  const packageJsonFile = path.join(context.integTestDir, 'package.json');\n  const packageJson: unknown = JSON.parse(await fs.readFile(packageJsonFile, { encoding: 'utf-8' }));\n\n  assertIsObject(packageJson);\n  packageJson.overrides = {\n    \"aws-cdk-lib\": libVersion,\n  };\n  await fs.writeFile(packageJsonFile, JSON.stringify(packageJson, undefined, 2), { encoding: 'utf-8' })\n}\n\n/**\n * Mutably update the given string array, replacing the version of packages with the given name\n *\n * We assume the list of packages is a string array of the form\n *\n * ```\n * [\"package@version\", \"package@version\", ...]\n * ```\n *\n * It's a failure if we don't find an entry to update, unless we explicitly pass an option to say that's okay.\n */\nfunction replacePackageVersionIn(packName: string, version: string, xs: string[], failIfMissing = true) {\n  let didUpdate = false;\n  for (let i = 0; i < xs.length; i++) {\n    if (xs[i].startsWith(`${packName}@`)) {\n      xs[i] = `${packName}@${version}`;\n      didUpdate = true;\n    }\n  }\n\n  if (failIfMissing && !didUpdate) {\n    throw new Error(`Did not find a package version to update for ${packName} in ${JSON.stringify(xs)}`);\n  }\n}\n\nfunction assertIsObject(xs: unknown): asserts xs is Record<string, unknown> {\n  if (typeof xs !== 'object' || xs === null) {\n    throw new Error(`Expected object, got ${JSON.stringify(xs)}`);\n  }\n}\n\nfunction assertIsStringArray(xs: unknown): asserts xs is string[] {\n  if (!Array.isArray(xs) || xs.length === 0 || typeof xs[0] !== 'string') {\n    throw new Error(`Expected list of strings, got ${JSON.stringify(xs)}`);\n  }\n}\n"]}
@@ -56,7 +56,11 @@ async function mutateAmplifyDepOnCdk(context: TemporaryDirectoryContext, cliVers
56
56
  assertIsObject(amplifyDepJson);
57
57
  assertIsStringArray(amplifyDepJson.defaultDevPackages);
58
58
 
59
- replacePackageVersionIn('aws-cdk', cliVersion, amplifyDepJson.defaultDevPackages);
59
+ // Amplify is removing the dependency on aws-cdk, since Amplify is now using the toolkit-lib
60
+ // To prepare for this change, we need allow both situations: aws-cdk being listed and not being listed
61
+ // Fix is to simply allow the replace operation to also NOT replace the version
62
+ // @see https://github.com/aws-amplify/amplify-backend/pull/2614
63
+ replacePackageVersionIn('aws-cdk', cliVersion, amplifyDepJson.defaultDevPackages, false);
60
64
  replacePackageVersionIn('aws-cdk-lib', libVersion, amplifyDepJson.defaultDevPackages);
61
65
 
62
66
  await fs.writeFile(amplifyDepFile, JSON.stringify(amplifyDepJson, undefined, 2), { encoding: 'utf-8' });
@@ -80,9 +84,9 @@ async function mutateAmplifyDepOnCdk(context: TemporaryDirectoryContext, cliVers
80
84
  * ["package@version", "package@version", ...]
81
85
  * ```
82
86
  *
83
- * It's a failure if we don't find an entry to update.
87
+ * It's a failure if we don't find an entry to update, unless we explicitly pass an option to say that's okay.
84
88
  */
85
- function replacePackageVersionIn(packName: string, version: string, xs: string[]) {
89
+ function replacePackageVersionIn(packName: string, version: string, xs: string[], failIfMissing = true) {
86
90
  let didUpdate = false;
87
91
  for (let i = 0; i < xs.length; i++) {
88
92
  if (xs[i].startsWith(`${packName}@`)) {
@@ -91,7 +95,7 @@ function replacePackageVersionIn(packName: string, version: string, xs: string[]
91
95
  }
92
96
  }
93
97
 
94
- if (!didUpdate) {
98
+ if (failIfMissing && !didUpdate) {
95
99
  throw new Error(`Did not find a package version to update for ${packName} in ${JSON.stringify(xs)}`);
96
100
  }
97
101
  }