@byaga/cdk-patterns 0.9.3 → 0.10.0
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/.fleet/run.json +11 -0
- package/LICENSE.md +21 -0
- package/README.md +37 -0
- package/lib/DeployStack.d.ts +3 -7
- package/lib/DeployStack.js +7 -8
- package/lib/NodeJsLambda.d.ts +22 -0
- package/lib/NodeJsLambda.js +18 -2
- package/lib/NodeJsLambdaLayer.d.ts +13 -0
- package/lib/NodeJsLambdaLayer.js +13 -2
- package/lib/StaticWebSite.d.ts +20 -4
- package/lib/StaticWebSite.js +29 -15
- package/lib/methods/BuildOptions.d.ts +3 -0
- package/lib/methods/BuildOptions.js +2 -0
- package/lib/methods/build-ecmascript.d.ts +9 -0
- package/lib/methods/build-ecmascript.js +20 -0
- package/lib/methods/build-node-source.d.ts +10 -13
- package/lib/methods/build-node-source.js +30 -96
- package/lib/methods/build-typescript.d.ts +8 -0
- package/lib/methods/build-typescript.js +33 -0
- package/lib/methods/copy-files.d.ts +8 -0
- package/lib/methods/{empty-directory.js → copy-files.js} +21 -14
- package/lib/methods/duration.d.ts +8 -6
- package/lib/methods/duration.js +17 -11
- package/lib/methods/generate-hash.d.ts +7 -15
- package/lib/methods/generate-hash.js +25 -53
- package/lib/methods/get-files.d.ts +9 -0
- package/lib/methods/get-files.js +38 -0
- package/lib/methods/get-source-directory.d.ts +16 -2
- package/lib/methods/get-source-directory.js +31 -30
- package/lib/methods/hash-file.d.ts +18 -0
- package/lib/methods/hash-file.js +45 -0
- package/lib/methods/install-node-modules.d.ts +12 -0
- package/lib/methods/install-node-modules.js +30 -0
- package/package.json +25 -11
- package/jest.config.js +0 -16
- package/lib/IDeployStack.d.ts +0 -20
- package/lib/IDeployStack.js +0 -48
- package/lib/methods/apply-honeycomb-to-lambda.spec.d.ts +0 -1
- package/lib/methods/apply-honeycomb-to-lambda.spec.js +0 -61
- package/lib/methods/empty-directory.d.ts +0 -2
- package/lib/methods/walk-directory.d.ts +0 -14
- package/lib/methods/walk-directory.js +0 -48
- package/test-results/html/index.html +0 -1
- package/test-results/html/jest-html-reporters-attach/index/index.js +0 -3
- package/test-results/html/jest-html-reporters-attach/index/result.js +0 -1
- package/test-results/junit/junit.xml +0 -13
@@ -1,61 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
const ts_mockito_1 = require("ts-mockito");
|
4
|
-
const DeployStack_1 = require("../DeployStack");
|
5
|
-
const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
|
6
|
-
const apply_honeycomb_to_lambda_1 = require("./apply-honeycomb-to-lambda");
|
7
|
-
let mockStack;
|
8
|
-
let mockLayer;
|
9
|
-
let fromLayerVersionArn;
|
10
|
-
jest.mock('../SsmParameter', () => {
|
11
|
-
const { SsmParameter } = jest.requireActual('../SsmParameter');
|
12
|
-
class MockSsmParameter extends SsmParameter {
|
13
|
-
static mocks = {
|
14
|
-
stringValue: jest.fn()
|
15
|
-
};
|
16
|
-
get stringValue() {
|
17
|
-
return MockSsmParameter.mocks.stringValue();
|
18
|
-
}
|
19
|
-
}
|
20
|
-
MockSsmParameter.mocks.stringValue.mockReturnValue('test-value');
|
21
|
-
return { SsmParameter: MockSsmParameter };
|
22
|
-
});
|
23
|
-
const existingLayer = (0, ts_mockito_1.instance)((0, ts_mockito_1.mock)(aws_lambda_1.LayerVersion));
|
24
|
-
const props = {
|
25
|
-
runtime: aws_lambda_1.Runtime.NODEJS_18_X,
|
26
|
-
handler: 'index.handler',
|
27
|
-
code: aws_lambda_1.Code.fromInline('exports.handler = function(event, ctx, cb) { return cb(null, "hi"); }'),
|
28
|
-
environment: { existingVar: 'existingValue' },
|
29
|
-
layers: [existingLayer]
|
30
|
-
};
|
31
|
-
// Mock the wrapper object instead of the LayerVersion class
|
32
|
-
beforeEach(() => {
|
33
|
-
mockStack = (0, ts_mockito_1.mock)(DeployStack_1.DeployStack);
|
34
|
-
mockLayer = (0, ts_mockito_1.mock)(aws_lambda_1.LayerVersion);
|
35
|
-
fromLayerVersionArn = jest.spyOn(aws_lambda_1.LayerVersion, 'fromLayerVersionArn').mockReturnValue(mockLayer);
|
36
|
-
});
|
37
|
-
afterEach(() => {
|
38
|
-
fromLayerVersionArn.mockRestore();
|
39
|
-
});
|
40
|
-
it('should add honeycomb layer to function props', () => {
|
41
|
-
const result = (0, apply_honeycomb_to_lambda_1.applyHoneycombToLambda)((0, ts_mockito_1.instance)(mockStack), props);
|
42
|
-
expect(result.layers).toContain(mockLayer);
|
43
|
-
});
|
44
|
-
it('should add honeycomb environment variables to function props', () => {
|
45
|
-
const result = (0, apply_honeycomb_to_lambda_1.applyHoneycombToLambda)((0, ts_mockito_1.instance)(mockStack), props);
|
46
|
-
expect(result.environment).toEqual(expect.objectContaining({
|
47
|
-
LIBHONEY_API_KEY: 'test-value',
|
48
|
-
LIBHONEY_DATASET: 'test-value',
|
49
|
-
LOGS_API_DISABLE_PLATFORM_MSGS: 'true'
|
50
|
-
}));
|
51
|
-
});
|
52
|
-
it('should not overwrite existing layers in function props', () => {
|
53
|
-
const result = (0, apply_honeycomb_to_lambda_1.applyHoneycombToLambda)((0, ts_mockito_1.instance)(mockStack), props);
|
54
|
-
expect(result.layers).toContain(existingLayer);
|
55
|
-
});
|
56
|
-
it('should not overwrite existing environment variables in function props', () => {
|
57
|
-
const result = (0, apply_honeycomb_to_lambda_1.applyHoneycombToLambda)((0, ts_mockito_1.instance)(mockStack), props);
|
58
|
-
expect(result.environment).toEqual(expect.objectContaining({
|
59
|
-
existingVar: 'existingValue'
|
60
|
-
}));
|
61
|
-
});
|
@@ -1,14 +0,0 @@
|
|
1
|
-
/// <reference types="node" />
|
2
|
-
import * as fs from 'fs';
|
3
|
-
export interface IIgnoreOptions {
|
4
|
-
excluded?: (stat: fs.Dirent) => boolean;
|
5
|
-
included?: (stat: fs.Dirent) => boolean;
|
6
|
-
childrenExcluded?: (stat: fs.Dirent) => boolean;
|
7
|
-
childrenIncluded?: (stat: fs.Dirent) => boolean;
|
8
|
-
}
|
9
|
-
export declare const yes: () => boolean;
|
10
|
-
export declare const no: () => boolean;
|
11
|
-
export default function walkDirectory(directory: string, options: IIgnoreOptions, filepaths?: DirentExtended[]): DirentExtended[];
|
12
|
-
export interface DirentExtended extends fs.Dirent {
|
13
|
-
fullpath: () => string;
|
14
|
-
}
|
@@ -1,48 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
-
if (k2 === undefined) k2 = k;
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
-
}
|
8
|
-
Object.defineProperty(o, k2, desc);
|
9
|
-
}) : (function(o, m, k, k2) {
|
10
|
-
if (k2 === undefined) k2 = k;
|
11
|
-
o[k2] = m[k];
|
12
|
-
}));
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
-
}) : function(o, v) {
|
16
|
-
o["default"] = v;
|
17
|
-
});
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
-
if (mod && mod.__esModule) return mod;
|
20
|
-
var result = {};
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
-
__setModuleDefault(result, mod);
|
23
|
-
return result;
|
24
|
-
};
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
26
|
-
exports.no = exports.yes = void 0;
|
27
|
-
const path = __importStar(require("path"));
|
28
|
-
const fs = __importStar(require("fs"));
|
29
|
-
const yes = () => true;
|
30
|
-
exports.yes = yes;
|
31
|
-
const no = () => false;
|
32
|
-
exports.no = no;
|
33
|
-
function walkDirectory(directory, options, filepaths = []) {
|
34
|
-
const { excluded = exports.no, included = exports.yes, childrenExcluded = exports.no, childrenIncluded = exports.yes } = options;
|
35
|
-
const files = fs.readdirSync(directory, { withFileTypes: true });
|
36
|
-
for (let stats of files) {
|
37
|
-
const filepath = path.join(directory, stats.name);
|
38
|
-
stats.fullpath = () => filepath;
|
39
|
-
if (stats.isDirectory() && !childrenExcluded(stats) && childrenIncluded(stats)) {
|
40
|
-
walkDirectory(filepath, options, filepaths);
|
41
|
-
}
|
42
|
-
else if (stats.isFile() && !excluded(stats) && included(stats)) {
|
43
|
-
filepaths.push(stats);
|
44
|
-
}
|
45
|
-
}
|
46
|
-
return filepaths;
|
47
|
-
}
|
48
|
-
exports.default = walkDirectory;
|
@@ -1 +0,0 @@
|
|
1
|
-
<!doctype html><html><head><meta charset="utf-8"><meta http-equiv="Content-Type" content="text/html;charset=utf-8"><meta name="keywords" contect="jest, reporters"><meta name="author" contect="hazyzh"><meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=0,minimum-scale=1,maximum-scale=1"><link rel="shortcut icon" href=""></head><title>Report</title><body><div id="app"></div><script defer="defer" src="./jest-html-reporters-attach/index/index.js"></script></body></html>
|