/ cloudformation-templates / node_modules / aws-cdk / test / api / stack-activity-monitor.test.js
stack-activity-monitor.test.js
  1  "use strict";
  2  Object.defineProperty(exports, "__esModule", { value: true });
  3  const safe_1 = require("colors/safe");
  4  const stack_activity_monitor_1 = require("../../lib/api/util/cloudformation/stack-activity-monitor");
  5  const console_listener_1 = require("./console-listener");
  6  let TIMESTAMP;
  7  let HUMAN_TIME;
  8  beforeAll(() => {
  9      TIMESTAMP = new Date().getTime();
 10      HUMAN_TIME = new Date(TIMESTAMP).toLocaleTimeString();
 11  });
 12  test('prints 0/4 progress report, when addActivity is called with an "IN_PROGRESS" ResourceStatus', () => {
 13      const historyActivityPrinter = new stack_activity_monitor_1.HistoryActivityPrinter({
 14          resourceTypeColumnWidth: 23,
 15          resourcesTotal: 3,
 16          stream: process.stderr,
 17      });
 18      const output = console_listener_1.stderr.inspectSync(() => {
 19          historyActivityPrinter.addActivity({
 20              event: {
 21                  LogicalResourceId: 'stack1',
 22                  ResourceStatus: 'IN_PROGRESS',
 23                  Timestamp: new Date(TIMESTAMP),
 24                  ResourceType: 'AWS::CloudFormation::Stack',
 25                  StackId: '',
 26                  EventId: '',
 27                  StackName: '',
 28              },
 29          });
 30      });
 31      expect(output[0].trim()).toStrictEqual(`0/4 |${HUMAN_TIME} | ${safe_1.reset('IN_PROGRESS         ')} | AWS::CloudFormation::Stack | ${safe_1.reset(safe_1.bold('stack1'))}`);
 32  });
 33  test('prints 1/4 progress report, when addActivity is called with an "UPDATE_COMPLETE" ResourceStatus', () => {
 34      const historyActivityPrinter = new stack_activity_monitor_1.HistoryActivityPrinter({
 35          resourceTypeColumnWidth: 23,
 36          resourcesTotal: 3,
 37          stream: process.stderr,
 38      });
 39      const output = console_listener_1.stderr.inspectSync(() => {
 40          historyActivityPrinter.addActivity({
 41              event: {
 42                  LogicalResourceId: 'stack1',
 43                  ResourceStatus: 'UPDATE_COMPLETE',
 44                  Timestamp: new Date(TIMESTAMP),
 45                  ResourceType: 'AWS::CloudFormation::Stack',
 46                  StackId: '',
 47                  EventId: '',
 48                  StackName: '',
 49              },
 50          });
 51      });
 52      expect(output[0].trim()).toStrictEqual(`1/4 |${HUMAN_TIME} | ${safe_1.green('UPDATE_COMPLETE     ')} | AWS::CloudFormation::Stack | ${safe_1.green(safe_1.bold('stack1'))}`);
 53  });
 54  test('prints 1/4 progress report, when addActivity is called with an "UPDATE_COMPLETE_CLEAN_IN_PROGRESS" ResourceStatus', () => {
 55      const historyActivityPrinter = new stack_activity_monitor_1.HistoryActivityPrinter({
 56          resourceTypeColumnWidth: 23,
 57          resourcesTotal: 3,
 58          stream: process.stderr,
 59      });
 60      const output = console_listener_1.stderr.inspectSync(() => {
 61          historyActivityPrinter.addActivity({
 62              event: {
 63                  LogicalResourceId: 'stack1',
 64                  ResourceStatus: 'UPDATE_COMPLETE_CLEANUP_IN_PROGRESS',
 65                  Timestamp: new Date(TIMESTAMP),
 66                  ResourceType: 'AWS::CloudFormation::Stack',
 67                  StackId: '',
 68                  EventId: '',
 69                  StackName: '',
 70              },
 71          });
 72      });
 73      expect(output[0].trim()).toStrictEqual(`1/4 |${HUMAN_TIME} | ${safe_1.green('UPDATE_COMPLETE_CLEA')} | AWS::CloudFormation::Stack | ${safe_1.green(safe_1.bold('stack1'))}`);
 74  });
 75  test('prints 1/4 progress report, when addActivity is called with an "ROLLBACK_COMPLETE_CLEAN_IN_PROGRESS" ResourceStatus', () => {
 76      const historyActivityPrinter = new stack_activity_monitor_1.HistoryActivityPrinter({
 77          resourceTypeColumnWidth: 23,
 78          resourcesTotal: 3,
 79          stream: process.stderr,
 80      });
 81      const output = console_listener_1.stderr.inspectSync(() => {
 82          historyActivityPrinter.addActivity({
 83              event: {
 84                  LogicalResourceId: 'stack1',
 85                  ResourceStatus: 'ROLLBACK_COMPLETE_CLEANUP_IN_PROGRESS',
 86                  Timestamp: new Date(TIMESTAMP),
 87                  ResourceType: 'AWS::CloudFormation::Stack',
 88                  StackId: '',
 89                  EventId: '',
 90                  StackName: '',
 91              },
 92          });
 93      });
 94      expect(output[0].trim()).toStrictEqual(`1/4 |${HUMAN_TIME} | ${safe_1.yellow('ROLLBACK_COMPLETE_CL')} | AWS::CloudFormation::Stack | ${safe_1.yellow(safe_1.bold('stack1'))}`);
 95  });
 96  test('prints 0/4 progress report, when addActivity is called with an "UPDATE_FAILED" ResourceStatus', () => {
 97      const historyActivityPrinter = new stack_activity_monitor_1.HistoryActivityPrinter({
 98          resourceTypeColumnWidth: 23,
 99          resourcesTotal: 3,
100          stream: process.stderr,
101      });
102      const output = console_listener_1.stderr.inspectSync(() => {
103          historyActivityPrinter.addActivity({
104              event: {
105                  LogicalResourceId: 'stack1',
106                  ResourceStatus: 'UPDATE_FAILED',
107                  Timestamp: new Date(TIMESTAMP),
108                  ResourceType: 'AWS::CloudFormation::Stack',
109                  StackId: '',
110                  EventId: '',
111                  StackName: '',
112              },
113          });
114      });
115      expect(output[0].trim()).toStrictEqual(`0/4 |${HUMAN_TIME} | ${safe_1.red('UPDATE_FAILED       ')} | AWS::CloudFormation::Stack | ${safe_1.red(safe_1.bold('stack1'))}`);
116  });
117  test('does not print "Failed Resources:" list, when all deployments are successful', () => {
118      const historyActivityPrinter = new stack_activity_monitor_1.HistoryActivityPrinter({
119          resourceTypeColumnWidth: 23,
120          resourcesTotal: 1,
121          stream: process.stderr,
122      });
123      const output = console_listener_1.stderr.inspectSync(() => {
124          historyActivityPrinter.addActivity({
125              event: {
126                  LogicalResourceId: 'stack1',
127                  ResourceStatus: 'IN_PROGRESS',
128                  Timestamp: new Date(TIMESTAMP),
129                  ResourceType: 'AWS::CloudFormation::Stack',
130                  StackId: '',
131                  EventId: '',
132                  StackName: '',
133              },
134          });
135          historyActivityPrinter.addActivity({
136              event: {
137                  LogicalResourceId: 'stack1',
138                  ResourceStatus: 'UPDATE_COMPLETE',
139                  Timestamp: new Date(TIMESTAMP),
140                  ResourceType: 'AWS::CloudFormation::Stack',
141                  StackId: '',
142                  EventId: '',
143                  StackName: '',
144              },
145          });
146          historyActivityPrinter.addActivity({
147              event: {
148                  LogicalResourceId: 'stack2',
149                  ResourceStatus: 'UPDATE_COMPLETE',
150                  Timestamp: new Date(TIMESTAMP),
151                  ResourceType: 'AWS::CloudFormation::Stack',
152                  StackId: '',
153                  EventId: '',
154                  StackName: '',
155              },
156          });
157          historyActivityPrinter.stop();
158      });
159      expect(output.length).toStrictEqual(3);
160      expect(output[0].trim()).toStrictEqual(`0/2 |${HUMAN_TIME} | ${safe_1.reset('IN_PROGRESS         ')} | AWS::CloudFormation::Stack | ${safe_1.reset(safe_1.bold('stack1'))}`);
161      expect(output[1].trim()).toStrictEqual(`1/2 |${HUMAN_TIME} | ${safe_1.green('UPDATE_COMPLETE     ')} | AWS::CloudFormation::Stack | ${safe_1.green(safe_1.bold('stack1'))}`);
162      expect(output[2].trim()).toStrictEqual(`2/2 |${HUMAN_TIME} | ${safe_1.green('UPDATE_COMPLETE     ')} | AWS::CloudFormation::Stack | ${safe_1.green(safe_1.bold('stack2'))}`);
163  });
164  test('prints "Failed Resources:" list, when at least one deployment fails', () => {
165      const historyActivityPrinter = new stack_activity_monitor_1.HistoryActivityPrinter({
166          resourceTypeColumnWidth: 23,
167          resourcesTotal: 1,
168          stream: process.stderr,
169      });
170      const output = console_listener_1.stderr.inspectSync(() => {
171          historyActivityPrinter.addActivity({
172              event: {
173                  LogicalResourceId: 'stack1',
174                  ResourceStatus: 'IN_PROGRESS',
175                  Timestamp: new Date(TIMESTAMP),
176                  ResourceType: 'AWS::CloudFormation::Stack',
177                  StackId: '',
178                  EventId: '',
179                  StackName: '',
180              },
181          });
182          historyActivityPrinter.addActivity({
183              event: {
184                  LogicalResourceId: 'stack1',
185                  ResourceStatus: 'UPDATE_FAILED',
186                  Timestamp: new Date(TIMESTAMP),
187                  ResourceType: 'AWS::CloudFormation::Stack',
188                  StackId: '',
189                  EventId: '',
190                  StackName: '',
191              },
192          });
193          historyActivityPrinter.stop();
194      });
195      expect(output.length).toStrictEqual(4);
196      expect(output[0].trim()).toStrictEqual(`0/2 |${HUMAN_TIME} | ${safe_1.reset('IN_PROGRESS         ')} | AWS::CloudFormation::Stack | ${safe_1.reset(safe_1.bold('stack1'))}`);
197      expect(output[1].trim()).toStrictEqual(`0/2 |${HUMAN_TIME} | ${safe_1.red('UPDATE_FAILED       ')} | AWS::CloudFormation::Stack | ${safe_1.red(safe_1.bold('stack1'))}`);
198      expect(output[2].trim()).toStrictEqual('Failed resources:');
199      expect(output[3].trim()).toStrictEqual(`${HUMAN_TIME} | ${safe_1.red('UPDATE_FAILED       ')} | AWS::CloudFormation::Stack | ${safe_1.red(safe_1.bold('stack1'))}`);
200  });
201  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-activity-monitor.test.js","sourceRoot":"","sources":["stack-activity-monitor.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { bold, reset, green, yellow, red } from 'colors/safe';\nimport { HistoryActivityPrinter } from '../../lib/api/util/cloudformation/stack-activity-monitor';\nimport { stderr } from './console-listener';\n\nlet TIMESTAMP: number;\nlet HUMAN_TIME: string;\n\nbeforeAll(() => {\n  TIMESTAMP = new Date().getTime();\n  HUMAN_TIME = new Date(TIMESTAMP).toLocaleTimeString();\n});\n\n\ntest('prints 0/4 progress report, when addActivity is called with an \"IN_PROGRESS\" ResourceStatus', () => {\n  const historyActivityPrinter = new HistoryActivityPrinter({\n    resourceTypeColumnWidth: 23,\n    resourcesTotal: 3,\n    stream: process.stderr,\n  });\n\n  const output = stderr.inspectSync(() => {\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'IN_PROGRESS',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n  });\n\n  expect(output[0].trim()).toStrictEqual(`0/4 |${HUMAN_TIME} | ${reset('IN_PROGRESS         ')} | AWS::CloudFormation::Stack | ${reset(bold('stack1'))}`);\n});\n\ntest('prints 1/4 progress report, when addActivity is called with an \"UPDATE_COMPLETE\" ResourceStatus', () => {\n  const historyActivityPrinter = new HistoryActivityPrinter({\n    resourceTypeColumnWidth: 23,\n    resourcesTotal: 3,\n    stream: process.stderr,\n  });\n\n  const output = stderr.inspectSync(() => {\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'UPDATE_COMPLETE',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n  });\n\n  expect(output[0].trim()).toStrictEqual(`1/4 |${HUMAN_TIME} | ${green('UPDATE_COMPLETE     ')} | AWS::CloudFormation::Stack | ${green(bold('stack1'))}`);\n});\n\ntest('prints 1/4 progress report, when addActivity is called with an \"UPDATE_COMPLETE_CLEAN_IN_PROGRESS\" ResourceStatus', () => {\n  const historyActivityPrinter = new HistoryActivityPrinter({\n    resourceTypeColumnWidth: 23,\n    resourcesTotal: 3,\n    stream: process.stderr,\n  });\n\n  const output = stderr.inspectSync(() => {\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'UPDATE_COMPLETE_CLEANUP_IN_PROGRESS',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n  });\n\n  expect(output[0].trim()).toStrictEqual(`1/4 |${HUMAN_TIME} | ${green('UPDATE_COMPLETE_CLEA')} | AWS::CloudFormation::Stack | ${green(bold('stack1'))}`);\n});\n\n\ntest('prints 1/4 progress report, when addActivity is called with an \"ROLLBACK_COMPLETE_CLEAN_IN_PROGRESS\" ResourceStatus', () => {\n  const historyActivityPrinter = new HistoryActivityPrinter({\n    resourceTypeColumnWidth: 23,\n    resourcesTotal: 3,\n    stream: process.stderr,\n  });\n\n  const output = stderr.inspectSync(() => {\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'ROLLBACK_COMPLETE_CLEANUP_IN_PROGRESS',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n  });\n\n  expect(output[0].trim()).toStrictEqual(`1/4 |${HUMAN_TIME} | ${yellow('ROLLBACK_COMPLETE_CL')} | AWS::CloudFormation::Stack | ${yellow(bold('stack1'))}`);\n});\n\ntest('prints 0/4 progress report, when addActivity is called with an \"UPDATE_FAILED\" ResourceStatus', () => {\n  const historyActivityPrinter = new HistoryActivityPrinter({\n    resourceTypeColumnWidth: 23,\n    resourcesTotal: 3,\n    stream: process.stderr,\n  });\n\n  const output = stderr.inspectSync(() => {\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'UPDATE_FAILED',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n  });\n\n  expect(output[0].trim()).toStrictEqual(`0/4 |${HUMAN_TIME} | ${red('UPDATE_FAILED       ')} | AWS::CloudFormation::Stack | ${red(bold('stack1'))}`);\n});\n\n\ntest('does not print \"Failed Resources:\" list, when all deployments are successful', () => {\n  const historyActivityPrinter = new HistoryActivityPrinter({\n    resourceTypeColumnWidth: 23,\n    resourcesTotal: 1,\n    stream: process.stderr,\n  });\n\n  const output = stderr.inspectSync(() => {\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'IN_PROGRESS',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'UPDATE_COMPLETE',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack2',\n        ResourceStatus: 'UPDATE_COMPLETE',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n    historyActivityPrinter.stop();\n  });\n\n  expect(output.length).toStrictEqual(3);\n  expect(output[0].trim()).toStrictEqual(`0/2 |${HUMAN_TIME} | ${reset('IN_PROGRESS         ')} | AWS::CloudFormation::Stack | ${reset(bold('stack1'))}`);\n  expect(output[1].trim()).toStrictEqual(`1/2 |${HUMAN_TIME} | ${green('UPDATE_COMPLETE     ')} | AWS::CloudFormation::Stack | ${green(bold('stack1'))}`);\n  expect(output[2].trim()).toStrictEqual(`2/2 |${HUMAN_TIME} | ${green('UPDATE_COMPLETE     ')} | AWS::CloudFormation::Stack | ${green(bold('stack2'))}`);\n});\n\ntest('prints \"Failed Resources:\" list, when at least one deployment fails', () => {\n  const historyActivityPrinter = new HistoryActivityPrinter({\n    resourceTypeColumnWidth: 23,\n    resourcesTotal: 1,\n    stream: process.stderr,\n  });\n\n  const output = stderr.inspectSync(() => {\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'IN_PROGRESS',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n    historyActivityPrinter.addActivity({\n      event: {\n        LogicalResourceId: 'stack1',\n        ResourceStatus: 'UPDATE_FAILED',\n        Timestamp: new Date(TIMESTAMP),\n        ResourceType: 'AWS::CloudFormation::Stack',\n        StackId: '',\n        EventId: '',\n        StackName: '',\n      },\n    });\n    historyActivityPrinter.stop();\n  });\n\n  expect(output.length).toStrictEqual(4);\n  expect(output[0].trim()).toStrictEqual(`0/2 |${HUMAN_TIME} | ${reset('IN_PROGRESS         ')} | AWS::CloudFormation::Stack | ${reset(bold('stack1'))}`);\n  expect(output[1].trim()).toStrictEqual(`0/2 |${HUMAN_TIME} | ${red('UPDATE_FAILED       ')} | AWS::CloudFormation::Stack | ${red(bold('stack1'))}`);\n  expect(output[2].trim()).toStrictEqual('Failed resources:');\n  expect(output[3].trim()).toStrictEqual(`${HUMAN_TIME} | ${red('UPDATE_FAILED       ')} | AWS::CloudFormation::Stack | ${red(bold('stack1'))}`);\n});\n"]}