skuba 4.2.0-beta.6 → 4.2.1
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/README.md +1 -1
- package/lib/api/buildkite/annotate.js +8 -19
- package/lib/api/buildkite/annotate.js.map +1 -1
- package/lib/api/git/commit.js +6 -17
- package/lib/api/git/commit.js.map +1 -1
- package/lib/api/git/commitAllChanges.js +4 -13
- package/lib/api/git/commitAllChanges.js.map +1 -1
- package/lib/api/git/currentBranch.js +5 -14
- package/lib/api/git/currentBranch.js.map +1 -1
- package/lib/api/git/getChangedFiles.js +3 -12
- package/lib/api/git/getChangedFiles.js.map +1 -1
- package/lib/api/git/log.js +7 -17
- package/lib/api/git/log.js.map +1 -1
- package/lib/api/git/push.js +7 -19
- package/lib/api/git/push.js.map +1 -1
- package/lib/api/git/remote.js +5 -14
- package/lib/api/git/remote.js.map +1 -1
- package/lib/api/git/reset.js +6 -15
- package/lib/api/git/reset.js.map +1 -1
- package/lib/api/github/checkRun.js +4 -13
- package/lib/api/github/checkRun.js.map +1 -1
- package/lib/api/github/environment.js +2 -3
- package/lib/api/github/environment.js.map +1 -1
- package/lib/api/github/issueComment.js +15 -28
- package/lib/api/github/issueComment.js.map +1 -1
- package/lib/api/github/pullRequest.js +8 -17
- package/lib/api/github/pullRequest.js.map +1 -1
- package/lib/api/jest/index.d.ts +26 -11
- package/lib/api/net/compose.js +3 -12
- package/lib/api/net/compose.js.map +1 -1
- package/lib/api/net/socket.js +30 -43
- package/lib/api/net/socket.js.map +1 -1
- package/lib/api/net/waitFor.js +4 -13
- package/lib/api/net/waitFor.js.map +1 -1
- package/lib/cli/adapter/eslint.d.ts +2 -1
- package/lib/cli/adapter/eslint.js +10 -15
- package/lib/cli/adapter/eslint.js.map +1 -1
- package/lib/cli/adapter/prettier.js +12 -24
- package/lib/cli/adapter/prettier.js.map +1 -1
- package/lib/cli/build/tsc.js +2 -11
- package/lib/cli/build/tsc.js.map +1 -1
- package/lib/cli/configure/analyseConfiguration.js +7 -16
- package/lib/cli/configure/analyseConfiguration.js.map +1 -1
- package/lib/cli/configure/analyseDependencies.js +22 -28
- package/lib/cli/configure/analyseDependencies.js.map +1 -1
- package/lib/cli/configure/analysis/files.js +3 -12
- package/lib/cli/configure/analysis/files.js.map +1 -1
- package/lib/cli/configure/analysis/git.js +4 -13
- package/lib/cli/configure/analysis/git.js.map +1 -1
- package/lib/cli/configure/analysis/package.js +7 -13
- package/lib/cli/configure/analysis/package.js.map +1 -1
- package/lib/cli/configure/analysis/project.js +13 -23
- package/lib/cli/configure/analysis/project.js.map +1 -1
- package/lib/cli/configure/ensureTemplateCompletion.js +6 -15
- package/lib/cli/configure/ensureTemplateCompletion.js.map +1 -1
- package/lib/cli/configure/getEntryPoint.js +3 -12
- package/lib/cli/configure/getEntryPoint.js.map +1 -1
- package/lib/cli/configure/getProjectType.js +3 -13
- package/lib/cli/configure/getProjectType.js.map +1 -1
- package/lib/cli/configure/index.js +21 -30
- package/lib/cli/configure/index.js.map +1 -1
- package/lib/cli/configure/modules/eslint.js +10 -29
- package/lib/cli/configure/modules/eslint.js.map +1 -1
- package/lib/cli/configure/modules/ignore.js +3 -12
- package/lib/cli/configure/modules/ignore.js.map +1 -1
- package/lib/cli/configure/modules/jest.js +14 -33
- package/lib/cli/configure/modules/jest.js.map +1 -1
- package/lib/cli/configure/modules/package.js +21 -21
- package/lib/cli/configure/modules/package.js.map +1 -1
- package/lib/cli/configure/modules/prettier.js +9 -28
- package/lib/cli/configure/modules/prettier.js.map +1 -1
- package/lib/cli/configure/modules/renovate.js +13 -30
- package/lib/cli/configure/modules/renovate.js.map +1 -1
- package/lib/cli/configure/modules/skubaDive.js +7 -5
- package/lib/cli/configure/modules/skubaDive.js.map +1 -1
- package/lib/cli/configure/modules/tsconfig.js +12 -18
- package/lib/cli/configure/modules/tsconfig.js.map +1 -1
- package/lib/cli/configure/processing/json.js +1 -1
- package/lib/cli/configure/processing/json.js.map +1 -1
- package/lib/cli/configure/processing/package.js +5 -5
- package/lib/cli/configure/processing/package.js.map +1 -1
- package/lib/cli/configure/processing/prettier.js +4 -1
- package/lib/cli/configure/processing/prettier.js.map +1 -1
- package/lib/cli/configure/processing/typescript.js +4 -7
- package/lib/cli/configure/processing/typescript.js.map +1 -1
- package/lib/cli/configure/refreshIgnoreFiles.js +13 -21
- package/lib/cli/configure/refreshIgnoreFiles.js.map +1 -1
- package/lib/cli/format.js +5 -14
- package/lib/cli/format.js.map +1 -1
- package/lib/cli/help.js +3 -12
- package/lib/cli/help.js.map +1 -1
- package/lib/cli/init/getConfig.js +63 -56
- package/lib/cli/init/getConfig.js.map +1 -1
- package/lib/cli/init/git.js +9 -18
- package/lib/cli/init/git.js.map +1 -1
- package/lib/cli/init/index.js +14 -23
- package/lib/cli/init/index.js.map +1 -1
- package/lib/cli/init/prompts.js +3 -12
- package/lib/cli/init/prompts.js.map +1 -1
- package/lib/cli/init/types.js +7 -2
- package/lib/cli/init/types.js.map +1 -1
- package/lib/cli/init/writePackageJson.js +5 -14
- package/lib/cli/init/writePackageJson.js.map +1 -1
- package/lib/cli/lint/annotate/buildkite/index.js +3 -12
- package/lib/cli/lint/annotate/buildkite/index.js.map +1 -1
- package/lib/cli/lint/annotate/github/eslint.js +10 -2
- package/lib/cli/lint/annotate/github/eslint.js.map +1 -1
- package/lib/cli/lint/annotate/github/index.js +3 -12
- package/lib/cli/lint/annotate/github/index.js.map +1 -1
- package/lib/cli/lint/annotate/github/tsc.js +1 -1
- package/lib/cli/lint/annotate/github/tsc.js.map +1 -1
- package/lib/cli/lint/annotate/index.js +3 -12
- package/lib/cli/lint/annotate/index.js.map +1 -1
- package/lib/cli/lint/autofix.d.ts +7 -1
- package/lib/cli/lint/autofix.js +26 -27
- package/lib/cli/lint/autofix.js.map +1 -1
- package/lib/cli/lint/external.js +37 -59
- package/lib/cli/lint/external.js.map +1 -1
- package/lib/cli/lint/index.js +5 -14
- package/lib/cli/lint/index.js.map +1 -1
- package/lib/cli/lint/internal.js +7 -16
- package/lib/cli/lint/internal.js.map +1 -1
- package/lib/cli/lint/tsc.js +4 -13
- package/lib/cli/lint/tsc.js.map +1 -1
- package/lib/cli/node.js +3 -12
- package/lib/cli/node.js.map +1 -1
- package/lib/cli/release.js +3 -12
- package/lib/cli/release.js.map +1 -1
- package/lib/cli/start.js +4 -14
- package/lib/cli/start.js.map +1 -1
- package/lib/cli/test/index.js +1 -2
- package/lib/cli/test/index.js.map +1 -1
- package/lib/cli/test/reporters/github/annotations.js +7 -7
- package/lib/cli/test/reporters/github/annotations.js.map +1 -1
- package/lib/cli/test/reporters/github/index.d.ts +2 -2
- package/lib/cli/test/reporters/github/index.js +37 -37
- package/lib/cli/test/reporters/github/index.js.map +1 -1
- package/lib/cli/version.js +3 -12
- package/lib/cli/version.js.map +1 -1
- package/lib/skuba.js +3 -12
- package/lib/skuba.js.map +1 -1
- package/lib/utils/args.d.ts +1 -1
- package/lib/utils/args.js +7 -11
- package/lib/utils/args.js.map +1 -1
- package/lib/utils/command.d.ts +1 -1
- package/lib/utils/command.js +0 -1
- package/lib/utils/command.js.map +1 -1
- package/lib/utils/copy.js +11 -20
- package/lib/utils/copy.js.map +1 -1
- package/lib/utils/dir.js +9 -18
- package/lib/utils/dir.js.map +1 -1
- package/lib/utils/error.d.ts +14 -0
- package/lib/utils/error.js +16 -2
- package/lib/utils/error.js.map +1 -1
- package/lib/utils/exec.js +25 -29
- package/lib/utils/exec.js.map +1 -1
- package/lib/utils/logo.js +4 -14
- package/lib/utils/logo.js.map +1 -1
- package/lib/utils/manifest.js +6 -15
- package/lib/utils/manifest.js.map +1 -1
- package/lib/utils/version.js +12 -22
- package/lib/utils/version.js.map +1 -1
- package/lib/utils/wait.d.ts +17 -0
- package/lib/utils/wait.js +32 -0
- package/lib/utils/wait.js.map +1 -0
- package/lib/utils/worker.js +4 -12
- package/lib/utils/worker.js.map +1 -1
- package/lib/wrapper/functionHandler.js +2 -11
- package/lib/wrapper/functionHandler.js.map +1 -1
- package/lib/wrapper/http.js +6 -15
- package/lib/wrapper/http.js.map +1 -1
- package/lib/wrapper/main.js +2 -11
- package/lib/wrapper/main.js.map +1 -1
- package/lib/wrapper/requestListener.js +3 -13
- package/lib/wrapper/requestListener.js.map +1 -1
- package/package.json +19 -29
- package/template/base/tsconfig.json +2 -1
- package/template/express-rest-api/.buildkite/pipeline.yml +5 -4
- package/template/express-rest-api/Dockerfile +3 -3
- package/template/greeter/.buildkite/pipeline.yml +2 -1
- package/template/koa-rest-api/.buildkite/pipeline.yml +5 -4
- package/template/koa-rest-api/Dockerfile +3 -3
- package/template/koa-rest-api/package.json +5 -5
- package/template/koa-rest-api/src/api/jobs/getJobs.ts +2 -2
- package/template/koa-rest-api/src/api/jobs/postJob.ts +2 -2
- package/template/koa-rest-api/src/framework/logging.ts +8 -5
- package/template/koa-rest-api/src/framework/metrics.ts +2 -2
- package/template/koa-rest-api/src/framework/server.test.ts +21 -21
- package/template/koa-rest-api/src/framework/server.ts +4 -3
- package/template/koa-rest-api/src/listen.ts +2 -2
- package/template/koa-rest-api/src/testing/logging.ts +5 -20
- package/template/lambda-sqs-worker/.buildkite/pipeline.yml +2 -1
- package/template/lambda-sqs-worker/.nvmrc +1 -1
- package/template/lambda-sqs-worker/Dockerfile +1 -1
- package/template/lambda-sqs-worker/package.json +4 -4
- package/template/lambda-sqs-worker/serverless.yml +2 -2
- package/template/lambda-sqs-worker/src/app.test.ts +9 -9
- package/template/lambda-sqs-worker/src/app.ts +2 -1
- package/template/lambda-sqs-worker/src/framework/handler.test.ts +10 -10
- package/template/lambda-sqs-worker/src/framework/handler.ts +14 -17
- package/template/lambda-sqs-worker/src/framework/logging.ts +11 -6
- package/template/lambda-sqs-worker/src/testing/logging.ts +7 -5
- package/template/lambda-sqs-worker-cdk/.buildkite/pipeline.yml +2 -1
- package/template/lambda-sqs-worker-cdk/.nvmrc +1 -1
- package/template/lambda-sqs-worker-cdk/Dockerfile +1 -1
- package/template/lambda-sqs-worker-cdk/infra/__snapshots__/appStack.test.ts.snap +2 -2
- package/template/lambda-sqs-worker-cdk/infra/appStack.ts +1 -1
- package/template/lambda-sqs-worker-cdk/package.json +9 -11
- package/template/oss-npm-package/tsconfig.json +2 -1
- package/template/private-npm-package/.buildkite/pipeline.yml +1 -1
- package/template/private-npm-package/tsconfig.json +2 -1
- package/lib/cli/changesets/coreAdapter.d.ts +0 -9
- package/lib/cli/changesets/coreAdapter.js +0 -19
- package/lib/cli/changesets/coreAdapter.js.map +0 -1
- package/lib/cli/changesets/gitUtils.d.ts +0 -17
- package/lib/cli/changesets/gitUtils.js +0 -128
- package/lib/cli/changesets/gitUtils.js.map +0 -1
- package/lib/cli/changesets/githubAdapter.d.ts +0 -3
- package/lib/cli/changesets/githubAdapter.js +0 -8
- package/lib/cli/changesets/githubAdapter.js.map +0 -1
- package/lib/cli/changesets/index.d.ts +0 -1
- package/lib/cli/changesets/index.js +0 -94
- package/lib/cli/changesets/index.js.map +0 -1
- package/lib/cli/changesets/readChangesetState.d.ts +0 -6
- package/lib/cli/changesets/readChangesetState.js +0 -34
- package/lib/cli/changesets/readChangesetState.js.map +0 -1
- package/lib/cli/changesets/run.d.ts +0 -22
- package/lib/cli/changesets/run.js +0 -196
- package/lib/cli/changesets/run.js.map +0 -1
- package/lib/cli/changesets/utils.d.ts +0 -30
- package/lib/cli/changesets/utils.js +0 -130
- package/lib/cli/changesets/utils.js.map +0 -1
|
@@ -1,13 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
exports.runRequestListener = void 0;
|
|
13
4
|
const validation_1 = require("../utils/validation");
|
|
@@ -18,8 +9,7 @@ const isConfig = (data) => (0, validation_1.isFunction)(data) || (0, validation_
|
|
|
18
9
|
*
|
|
19
10
|
* This supports Express and Koa applications out of the box.
|
|
20
11
|
*/
|
|
21
|
-
const runRequestListener = ({ availablePort, entryPoint, }) =>
|
|
22
|
-
var _a, _b;
|
|
12
|
+
const runRequestListener = async ({ availablePort, entryPoint, }) => {
|
|
23
13
|
if (!isConfig(entryPoint)) {
|
|
24
14
|
// Assume an executable script with weird exports
|
|
25
15
|
return;
|
|
@@ -35,13 +25,13 @@ const runRequestListener = ({ availablePort, entryPoint, }) => __awaiter(void 0,
|
|
|
35
25
|
}
|
|
36
26
|
const requestListener = typeof config === 'function'
|
|
37
27
|
? config
|
|
38
|
-
:
|
|
28
|
+
: config.requestListener ?? config.callback?.();
|
|
39
29
|
if (typeof requestListener !== 'function') {
|
|
40
30
|
// Assume an executable script with non-request listener exports
|
|
41
31
|
return;
|
|
42
32
|
}
|
|
43
33
|
const port = (0, validation_1.isIpPort)(config.port) ? config.port : availablePort;
|
|
44
34
|
return (0, http_1.serveRequestListener)(requestListener, port);
|
|
45
|
-
}
|
|
35
|
+
};
|
|
46
36
|
exports.runRequestListener = runRequestListener;
|
|
47
37
|
//# sourceMappingURL=requestListener.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"requestListener.js","sourceRoot":"","sources":["../../src/wrapper/requestListener.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"requestListener.js","sourceRoot":"","sources":["../../src/wrapper/requestListener.ts"],"names":[],"mappings":";;;AAEA,oDAAqE;AAErE,iCAA8C;AAiB9C,MAAM,QAAQ,GAAG,CAAC,IAAa,EAAyC,EAAE,CACxE,IAAA,uBAAU,EAAC,IAAI,CAAC,IAAI,IAAA,qBAAQ,EAAC,IAAI,CAAC,CAAC;AAOrC;;;;GAIG;AACI,MAAM,kBAAkB,GAAG,KAAK,EAAE,EACvC,aAAa,EACb,UAAU,GACL,EAAiB,EAAE;IACxB,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE;QACzB,iDAAiD;QACjD,OAAO;KACR;IAED,IAAI,MAAM,GAAG,UAAU,CAAC;IAExB,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;QAC1D,0CAA0C;QAC1C,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC;KACzB;IAED,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;QACpC,8CAA8C;QAC9C,OAAO;KACR;IAED,MAAM,eAAe,GACnB,OAAO,MAAM,KAAK,UAAU;QAC1B,CAAC,CAAC,MAAM;QACR,CAAC,CAAC,MAAM,CAAC,eAAe,IAAI,MAAM,CAAC,QAAQ,EAAE,EAAE,CAAC;IAEpD,IAAI,OAAO,eAAe,KAAK,UAAU,EAAE;QACzC,gEAAgE;QAChE,OAAO;KACR;IAED,MAAM,IAAI,GAAG,IAAA,qBAAQ,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC;IAEjE,OAAO,IAAA,2BAAoB,EAAC,eAAe,EAAE,IAAI,CAAC,CAAC;AACrD,CAAC,CAAC;AAlCW,QAAA,kBAAkB,sBAkC7B"}
|
package/package.json
CHANGED
|
@@ -6,13 +6,9 @@
|
|
|
6
6
|
"url": "https://github.com/seek-oss/skuba/issues"
|
|
7
7
|
},
|
|
8
8
|
"dependencies": {
|
|
9
|
-
"@changesets/cli": "^2.22.0",
|
|
10
|
-
"@changesets/pre": "^1.0.10",
|
|
11
|
-
"@changesets/read": "^0.5.4",
|
|
12
|
-
"@manypkg/get-packages": "^1.1.3",
|
|
13
9
|
"@octokit/rest": "^18.12.0",
|
|
14
10
|
"@octokit/types": "^6.34.0",
|
|
15
|
-
"@types/jest": "^27.
|
|
11
|
+
"@types/jest": "^27.5.0",
|
|
16
12
|
"@types/node": ">=14.18",
|
|
17
13
|
"chalk": "^4.1.0",
|
|
18
14
|
"concurrently": "^7.0.0",
|
|
@@ -20,7 +16,7 @@
|
|
|
20
16
|
"ejs": "^3.1.6",
|
|
21
17
|
"enquirer": "^2.3.6",
|
|
22
18
|
"eslint": "^8.11.0",
|
|
23
|
-
"eslint-config-skuba": "1.0
|
|
19
|
+
"eslint-config-skuba": "1.1.0",
|
|
24
20
|
"execa": "^5.0.0",
|
|
25
21
|
"fdir": "^5.0.0",
|
|
26
22
|
"fs-extra": "^10.0.0",
|
|
@@ -29,54 +25,49 @@
|
|
|
29
25
|
"ignore": "^5.1.8",
|
|
30
26
|
"is-installed-globally": "^0.4.0",
|
|
31
27
|
"isomorphic-git": "^1.11.1",
|
|
32
|
-
"jest": "^
|
|
28
|
+
"jest": "^28.1.0",
|
|
33
29
|
"latest-version": "^5.1.0",
|
|
34
30
|
"lodash.mergewith": "^4.6.2",
|
|
35
|
-
"mdast-util-to-string": "^2.0.0",
|
|
36
|
-
"module-alias": "^2.2.2",
|
|
37
31
|
"normalize-package-data": "^4.0.0",
|
|
38
32
|
"npm-run-path": "^4.0.1",
|
|
39
33
|
"npm-which": "^3.0.1",
|
|
40
34
|
"picomatch": "^2.2.2",
|
|
41
35
|
"prettier": "~2.6.0",
|
|
42
36
|
"read-pkg-up": "^7.0.1",
|
|
43
|
-
"remark-parse": "^9.0.0",
|
|
44
|
-
"remark-stringify": "^9.0.1",
|
|
45
37
|
"runtypes": "^6.0.0",
|
|
46
38
|
"semantic-release": "^19.0.0",
|
|
47
39
|
"serialize-error": "^8.0.1",
|
|
48
40
|
"simple-git": "^3.5.0",
|
|
49
41
|
"strip-ansi": "^6.0.1",
|
|
50
|
-
"ts-jest": "^
|
|
51
|
-
"ts-node": "^10.
|
|
42
|
+
"ts-jest": "^28.0.2",
|
|
43
|
+
"ts-node": "^10.7.0",
|
|
52
44
|
"ts-node-dev": "^2.0.0-0",
|
|
53
|
-
"tsconfig-paths": "^
|
|
45
|
+
"tsconfig-paths": "^4.0.0",
|
|
54
46
|
"tsconfig-seek": "1.0.2",
|
|
55
|
-
"typescript": "~4.6.
|
|
56
|
-
"unified": "^9.2.2"
|
|
47
|
+
"typescript": "~4.6.4"
|
|
57
48
|
},
|
|
58
49
|
"description": "SEEK development toolkit for backend applications and packages",
|
|
59
50
|
"devDependencies": {
|
|
51
|
+
"@changesets/cli": "2.22.0",
|
|
60
52
|
"@changesets/get-github-info": "0.5.0",
|
|
61
|
-
"@
|
|
62
|
-
"@
|
|
63
|
-
"@types/ejs": "3.1.0",
|
|
53
|
+
"@jest/reporters": "28.1.0",
|
|
54
|
+
"@types/ejs": "3.1.1",
|
|
64
55
|
"@types/express": "4.17.13",
|
|
65
56
|
"@types/fs-extra": "9.0.13",
|
|
66
57
|
"@types/koa": "2.13.4",
|
|
67
|
-
"@types/lodash.mergewith": "4.6.
|
|
58
|
+
"@types/lodash.mergewith": "4.6.7",
|
|
68
59
|
"@types/module-alias": "2.0.1",
|
|
69
60
|
"@types/npm-which": "3.0.1",
|
|
70
61
|
"@types/picomatch": "2.3.0",
|
|
71
62
|
"@types/supertest": "2.0.12",
|
|
72
|
-
"enhanced-resolve": "5.9.
|
|
73
|
-
"express": "4.
|
|
63
|
+
"enhanced-resolve": "5.9.3",
|
|
64
|
+
"express": "4.18.1",
|
|
74
65
|
"jsonfile": "6.1.0",
|
|
75
66
|
"koa": "2.13.4",
|
|
76
|
-
"memfs": "3.4.
|
|
77
|
-
"semver": "7.3.
|
|
78
|
-
"supertest": "6.2.
|
|
79
|
-
"type-fest": "2.12.
|
|
67
|
+
"memfs": "3.4.3",
|
|
68
|
+
"semver": "7.3.7",
|
|
69
|
+
"supertest": "6.2.3",
|
|
70
|
+
"type-fest": "2.12.2"
|
|
80
71
|
},
|
|
81
72
|
"engines": {
|
|
82
73
|
"node": ">=14.18"
|
|
@@ -108,8 +99,7 @@
|
|
|
108
99
|
"url": "git+https://github.com/seek-oss/skuba.git"
|
|
109
100
|
},
|
|
110
101
|
"resolutions": {
|
|
111
|
-
"**/@types/node": ">=14.18"
|
|
112
|
-
"semantic-release/@semantic-release/npm/npm/**/ansi-regex": "5.0.1"
|
|
102
|
+
"**/@types/node": ">=14.18"
|
|
113
103
|
},
|
|
114
104
|
"scripts": {
|
|
115
105
|
"build": "ts-node --transpile-only src/skuba build && scripts/postbuild.sh",
|
|
@@ -133,5 +123,5 @@
|
|
|
133
123
|
"version": "4.0.0"
|
|
134
124
|
},
|
|
135
125
|
"types": "./lib/index.d.ts",
|
|
136
|
-
"version": "4.2.
|
|
126
|
+
"version": "4.2.1"
|
|
137
127
|
}
|
|
@@ -9,7 +9,7 @@ configs:
|
|
|
9
9
|
NPM_READ_TOKEN: arn:aws:secretsmanager:ap-southeast-2:987872074697:secret:npm/npm-read-token
|
|
10
10
|
|
|
11
11
|
- &docker-ecr-cache
|
|
12
|
-
seek-oss/docker-ecr-cache#
|
|
12
|
+
seek-oss/docker-ecr-cache#v2.0.0:
|
|
13
13
|
cache-on:
|
|
14
14
|
- package.json
|
|
15
15
|
- yarn.lock
|
|
@@ -53,6 +53,7 @@ steps:
|
|
|
53
53
|
- *docker-ecr-cache
|
|
54
54
|
- docker-compose#v3.9.0:
|
|
55
55
|
run: app
|
|
56
|
+
timeout_in_minutes: 10
|
|
56
57
|
|
|
57
58
|
- label: 📦 Build & Package
|
|
58
59
|
depends_on: warm-prod
|
|
@@ -60,7 +61,7 @@ steps:
|
|
|
60
61
|
- *aws-sm
|
|
61
62
|
- *private-npm
|
|
62
63
|
- *docker-ecr-cache
|
|
63
|
-
- seek-jobs/gantry#v1.
|
|
64
|
+
- seek-jobs/gantry#v1.7.0:
|
|
64
65
|
command: build
|
|
65
66
|
file: gantry.build.yml
|
|
66
67
|
region: <%- region %>
|
|
@@ -77,7 +78,7 @@ steps:
|
|
|
77
78
|
concurrency_group: <%- teamName %>/deploy/gantry/<%- devGantryEnvironmentName %>
|
|
78
79
|
key: deploy-dev
|
|
79
80
|
plugins:
|
|
80
|
-
- seek-jobs/gantry#v1.
|
|
81
|
+
- seek-jobs/gantry#v1.7.0:
|
|
81
82
|
command: apply
|
|
82
83
|
environment: <%- devGantryEnvironmentName %>
|
|
83
84
|
file: gantry.apply.yml
|
|
@@ -92,7 +93,7 @@ steps:
|
|
|
92
93
|
concurrency_group: <%- teamName %>/deploy/gantry/<%- prodGantryEnvironmentName %>
|
|
93
94
|
depends_on: deploy-dev
|
|
94
95
|
plugins:
|
|
95
|
-
- seek-jobs/gantry#v1.
|
|
96
|
+
- seek-jobs/gantry#v1.7.0:
|
|
96
97
|
command: apply
|
|
97
98
|
environment: <%- prodGantryEnvironmentName %>
|
|
98
99
|
file: gantry.apply.yml
|
|
@@ -25,13 +25,13 @@ COPY --from=build /workdir/lib lib
|
|
|
25
25
|
|
|
26
26
|
COPY --from=deps /workdir/node_modules node_modules
|
|
27
27
|
|
|
28
|
-
ENV NODE_ENV
|
|
28
|
+
ENV NODE_ENV=production
|
|
29
29
|
|
|
30
30
|
# https://nodejs.org/api/cli.html#cli_node_options_options
|
|
31
|
-
ENV NODE_OPTIONS
|
|
31
|
+
ENV NODE_OPTIONS=--enable-source-maps
|
|
32
32
|
|
|
33
33
|
ARG PORT=8001
|
|
34
|
-
ENV PORT
|
|
34
|
+
ENV PORT=${PORT}
|
|
35
35
|
EXPOSE ${PORT}
|
|
36
36
|
|
|
37
37
|
CMD ["lib/listen.js"]
|
|
@@ -9,7 +9,7 @@ configs:
|
|
|
9
9
|
NPM_READ_TOKEN: arn:aws:secretsmanager:ap-southeast-2:987872074697:secret:npm/npm-read-token
|
|
10
10
|
|
|
11
11
|
- &docker-ecr-cache
|
|
12
|
-
seek-oss/docker-ecr-cache#
|
|
12
|
+
seek-oss/docker-ecr-cache#v2.0.0:
|
|
13
13
|
cache-on:
|
|
14
14
|
- package.json
|
|
15
15
|
- yarn.lock
|
|
@@ -34,3 +34,4 @@ steps:
|
|
|
34
34
|
- *docker-ecr-cache
|
|
35
35
|
- docker-compose#v3.9.0:
|
|
36
36
|
run: app
|
|
37
|
+
timeout_in_minutes: 10
|
|
@@ -9,7 +9,7 @@ configs:
|
|
|
9
9
|
NPM_READ_TOKEN: arn:aws:secretsmanager:ap-southeast-2:987872074697:secret:npm/npm-read-token
|
|
10
10
|
|
|
11
11
|
- &docker-ecr-cache
|
|
12
|
-
seek-oss/docker-ecr-cache#
|
|
12
|
+
seek-oss/docker-ecr-cache#v2.0.0:
|
|
13
13
|
cache-on:
|
|
14
14
|
- package.json
|
|
15
15
|
- yarn.lock
|
|
@@ -53,6 +53,7 @@ steps:
|
|
|
53
53
|
- *docker-ecr-cache
|
|
54
54
|
- docker-compose#v3.9.0:
|
|
55
55
|
run: app
|
|
56
|
+
timeout_in_minutes: 10
|
|
56
57
|
|
|
57
58
|
- label: 📦 Build & Package
|
|
58
59
|
depends_on: warm-prod
|
|
@@ -60,7 +61,7 @@ steps:
|
|
|
60
61
|
- *aws-sm
|
|
61
62
|
- *private-npm
|
|
62
63
|
- *docker-ecr-cache
|
|
63
|
-
- seek-jobs/gantry#v1.
|
|
64
|
+
- seek-jobs/gantry#v1.7.0:
|
|
64
65
|
command: build
|
|
65
66
|
file: gantry.build.yml
|
|
66
67
|
region: <%- region %>
|
|
@@ -77,7 +78,7 @@ steps:
|
|
|
77
78
|
concurrency_group: <%- teamName %>/deploy/gantry/<%- devGantryEnvironmentName %>
|
|
78
79
|
key: deploy-dev
|
|
79
80
|
plugins:
|
|
80
|
-
- seek-jobs/gantry#v1.
|
|
81
|
+
- seek-jobs/gantry#v1.7.0:
|
|
81
82
|
command: apply
|
|
82
83
|
environment: <%- devGantryEnvironmentName %>
|
|
83
84
|
file: gantry.apply.yml
|
|
@@ -92,7 +93,7 @@ steps:
|
|
|
92
93
|
concurrency_group: <%- teamName %>/deploy/gantry/<%- prodGantryEnvironmentName %>
|
|
93
94
|
depends_on: deploy-dev
|
|
94
95
|
plugins:
|
|
95
|
-
- seek-jobs/gantry#v1.
|
|
96
|
+
- seek-jobs/gantry#v1.7.0:
|
|
96
97
|
command: apply
|
|
97
98
|
environment: <%- prodGantryEnvironmentName %>
|
|
98
99
|
file: gantry.apply.yml
|
|
@@ -25,13 +25,13 @@ COPY --from=build /workdir/lib lib
|
|
|
25
25
|
|
|
26
26
|
COPY --from=deps /workdir/node_modules node_modules
|
|
27
27
|
|
|
28
|
-
ENV NODE_ENV
|
|
28
|
+
ENV NODE_ENV=production
|
|
29
29
|
|
|
30
30
|
# https://nodejs.org/api/cli.html#cli_node_options_options
|
|
31
|
-
ENV NODE_OPTIONS
|
|
31
|
+
ENV NODE_OPTIONS=--enable-source-maps
|
|
32
32
|
|
|
33
33
|
ARG PORT=8001
|
|
34
|
-
ENV PORT
|
|
34
|
+
ENV PORT=${PORT}
|
|
35
35
|
EXPOSE ${PORT}
|
|
36
36
|
|
|
37
37
|
CMD ["--require", "./lib/tracing.js", "./lib/listen.js"]
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"dependencies": {
|
|
3
3
|
"@koa/router": "^10.1.1",
|
|
4
|
-
"@opentelemetry/api": "^1.0
|
|
4
|
+
"@opentelemetry/api": "^1.1.0",
|
|
5
5
|
"@opentelemetry/exporter-collector-grpc": "^0.25.0",
|
|
6
|
-
"@opentelemetry/instrumentation-aws-sdk": "^0.
|
|
7
|
-
"@opentelemetry/instrumentation-http": "^0.
|
|
8
|
-
"@opentelemetry/sdk-node": "^0.
|
|
6
|
+
"@opentelemetry/instrumentation-aws-sdk": "^0.7.0",
|
|
7
|
+
"@opentelemetry/instrumentation-http": "^0.28.0",
|
|
8
|
+
"@opentelemetry/sdk-node": "^0.28.0",
|
|
9
9
|
"@seek/logger": "^5.0.1",
|
|
10
10
|
"aws-sdk": "^2.1039.0",
|
|
11
11
|
"hot-shots": "^9.0.0",
|
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
"runtypes": "^6.4.1",
|
|
16
16
|
"runtypes-filter": "^0.6.0",
|
|
17
17
|
"seek-datadog-custom-metrics": "^4.0.0",
|
|
18
|
-
"seek-koala": "^5.
|
|
18
|
+
"seek-koala": "^5.2.0",
|
|
19
19
|
"skuba-dive": "^2.0.0",
|
|
20
20
|
"uuid": "^8.3.2"
|
|
21
21
|
},
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { logger } from 'src/framework/logging';
|
|
2
2
|
import { metricsClient } from 'src/framework/metrics';
|
|
3
3
|
import * as storage from 'src/storage/jobs';
|
|
4
4
|
import { Middleware } from 'src/types/koa';
|
|
@@ -7,7 +7,7 @@ export const getJobsHandler: Middleware = async (ctx) => {
|
|
|
7
7
|
const jobs = await storage.readJobs();
|
|
8
8
|
|
|
9
9
|
// no PII in these jobs
|
|
10
|
-
|
|
10
|
+
logger.debug({ jobs }, 'read jobs');
|
|
11
11
|
|
|
12
12
|
metricsClient.increment('job.reads', jobs.length);
|
|
13
13
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { logger } from 'src/framework/logging';
|
|
2
2
|
import { metricsClient } from 'src/framework/metrics';
|
|
3
3
|
import { validateRequestBody } from 'src/framework/validation';
|
|
4
4
|
import * as storage from 'src/storage/jobs';
|
|
@@ -11,7 +11,7 @@ export const postJobHandler: Middleware = async (ctx) => {
|
|
|
11
11
|
const job = await storage.createJob(jobInput);
|
|
12
12
|
|
|
13
13
|
// no PII in these jobs
|
|
14
|
-
|
|
14
|
+
logger.debug({ job }, 'created job');
|
|
15
15
|
|
|
16
16
|
metricsClient.increment('job.creations');
|
|
17
17
|
|
|
@@ -2,14 +2,20 @@ import createLogger from '@seek/logger';
|
|
|
2
2
|
import { RequestLogging } from 'seek-koala';
|
|
3
3
|
|
|
4
4
|
import { config } from 'src/config';
|
|
5
|
-
import { Context } from 'src/types/koa';
|
|
6
5
|
|
|
7
|
-
|
|
6
|
+
const { createContextMiddleware, mixin } =
|
|
7
|
+
RequestLogging.createContextStorage();
|
|
8
|
+
|
|
9
|
+
export const contextMiddleware = createContextMiddleware();
|
|
10
|
+
|
|
11
|
+
export const logger = createLogger({
|
|
8
12
|
base: {
|
|
9
13
|
environment: config.environment,
|
|
10
14
|
version: config.version,
|
|
11
15
|
},
|
|
12
16
|
|
|
17
|
+
mixin,
|
|
18
|
+
|
|
13
19
|
level: config.logLevel,
|
|
14
20
|
|
|
15
21
|
name: config.name,
|
|
@@ -17,6 +23,3 @@ export const rootLogger = createLogger({
|
|
|
17
23
|
transport:
|
|
18
24
|
config.environment === 'local' ? { target: 'pino-pretty' } : undefined,
|
|
19
25
|
});
|
|
20
|
-
|
|
21
|
-
export const contextLogger = (ctx: Context) =>
|
|
22
|
-
rootLogger.child(RequestLogging.contextFields(ctx));
|
|
@@ -3,9 +3,9 @@ import { createStatsDClient } from 'seek-datadog-custom-metrics';
|
|
|
3
3
|
|
|
4
4
|
import { config } from 'src/config';
|
|
5
5
|
|
|
6
|
-
import {
|
|
6
|
+
import { logger } from './logging';
|
|
7
7
|
|
|
8
8
|
/* istanbul ignore next: StatsD client is not our responsibility */
|
|
9
9
|
export const metricsClient = createStatsDClient(StatsD, config, (err) =>
|
|
10
|
-
|
|
10
|
+
logger.error({ err }, 'StatsD error'),
|
|
11
11
|
);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import Router from '@koa/router';
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import { logger } from 'src/testing/logging';
|
|
4
4
|
import { metricsClient } from 'src/testing/metrics';
|
|
5
5
|
import { agentFromRouter } from 'src/testing/server';
|
|
6
6
|
import { chance } from 'src/testing/types';
|
|
@@ -15,10 +15,10 @@ const router = new Router()
|
|
|
15
15
|
const agent = agentFromRouter(router);
|
|
16
16
|
|
|
17
17
|
describe('createApp', () => {
|
|
18
|
-
beforeAll(
|
|
18
|
+
beforeAll(logger.spy);
|
|
19
19
|
|
|
20
20
|
afterEach(metricsClient.clear);
|
|
21
|
-
afterEach(
|
|
21
|
+
afterEach(logger.clear);
|
|
22
22
|
|
|
23
23
|
it('handles root route', async () => {
|
|
24
24
|
middleware.mockImplementation((ctx) => (ctx.body = ''));
|
|
@@ -29,9 +29,9 @@ describe('createApp', () => {
|
|
|
29
29
|
.expect('server', /.+/)
|
|
30
30
|
.expect('x-api-version', /.+/);
|
|
31
31
|
|
|
32
|
-
expect(
|
|
32
|
+
expect(logger.error).not.toBeCalled();
|
|
33
33
|
|
|
34
|
-
expect(
|
|
34
|
+
expect(logger.info).not.toBeCalled();
|
|
35
35
|
|
|
36
36
|
metricsClient.expectTagSubset(['env:test', 'version:test']);
|
|
37
37
|
metricsClient.expectTagSubset([
|
|
@@ -51,9 +51,9 @@ describe('createApp', () => {
|
|
|
51
51
|
.expect('server', /.+/)
|
|
52
52
|
.expect('x-api-version', /.+/);
|
|
53
53
|
|
|
54
|
-
expect(
|
|
54
|
+
expect(logger.error).not.toBeCalled();
|
|
55
55
|
|
|
56
|
-
expect(
|
|
56
|
+
expect(logger.info).not.toBeCalled();
|
|
57
57
|
|
|
58
58
|
metricsClient.expectTagSubset([
|
|
59
59
|
'http_method:put',
|
|
@@ -72,9 +72,9 @@ describe('createApp', () => {
|
|
|
72
72
|
.expect('server', /.+/)
|
|
73
73
|
.expect('x-api-version', /.+/);
|
|
74
74
|
|
|
75
|
-
expect(
|
|
75
|
+
expect(logger.error).not.toBeCalled();
|
|
76
76
|
|
|
77
|
-
expect(
|
|
77
|
+
expect(logger.info).nthCalledWith(
|
|
78
78
|
1,
|
|
79
79
|
expect.objectContaining({ status: 404 }),
|
|
80
80
|
'Client error',
|
|
@@ -102,9 +102,9 @@ describe('createApp', () => {
|
|
|
102
102
|
.expect('server', /.+/)
|
|
103
103
|
.expect('x-api-version', /.+/);
|
|
104
104
|
|
|
105
|
-
expect(
|
|
105
|
+
expect(logger.error).not.toBeCalled();
|
|
106
106
|
|
|
107
|
-
expect(
|
|
107
|
+
expect(logger.info).nthCalledWith(
|
|
108
108
|
1,
|
|
109
109
|
expect.objectContaining({ status: 400 }),
|
|
110
110
|
'Client error',
|
|
@@ -129,9 +129,9 @@ describe('createApp', () => {
|
|
|
129
129
|
.expect('server', /.+/)
|
|
130
130
|
.expect('x-api-version', /.+/);
|
|
131
131
|
|
|
132
|
-
expect(
|
|
132
|
+
expect(logger.error).not.toBeCalled();
|
|
133
133
|
|
|
134
|
-
expect(
|
|
134
|
+
expect(logger.info).nthCalledWith(
|
|
135
135
|
1,
|
|
136
136
|
expect.objectContaining({ err: expect.any(Error), status: 400 }),
|
|
137
137
|
'Client error',
|
|
@@ -156,13 +156,13 @@ describe('createApp', () => {
|
|
|
156
156
|
.expect('server', /.+/)
|
|
157
157
|
.expect('x-api-version', /.+/);
|
|
158
158
|
|
|
159
|
-
expect(
|
|
159
|
+
expect(logger.error).nthCalledWith(
|
|
160
160
|
1,
|
|
161
161
|
expect.objectContaining({ err: expect.any(Error), status: 500 }),
|
|
162
162
|
'Server error',
|
|
163
163
|
);
|
|
164
164
|
|
|
165
|
-
expect(
|
|
165
|
+
expect(logger.info).not.toBeCalled();
|
|
166
166
|
|
|
167
167
|
metricsClient.expectTagSubset([
|
|
168
168
|
'http_method:get',
|
|
@@ -185,13 +185,13 @@ describe('createApp', () => {
|
|
|
185
185
|
.expect('server', /.+/)
|
|
186
186
|
.expect('x-api-version', /.+/);
|
|
187
187
|
|
|
188
|
-
expect(
|
|
188
|
+
expect(logger.error).nthCalledWith(
|
|
189
189
|
1,
|
|
190
190
|
expect.objectContaining({ err, status: 500 }),
|
|
191
191
|
'Server error',
|
|
192
192
|
);
|
|
193
193
|
|
|
194
|
-
expect(
|
|
194
|
+
expect(logger.info).not.toBeCalled();
|
|
195
195
|
|
|
196
196
|
metricsClient.expectTagSubset([
|
|
197
197
|
'http_method:get',
|
|
@@ -213,13 +213,13 @@ describe('createApp', () => {
|
|
|
213
213
|
.expect('server', /.+/)
|
|
214
214
|
.expect('x-api-version', /.+/);
|
|
215
215
|
|
|
216
|
-
expect(
|
|
216
|
+
expect(logger.error).nthCalledWith(
|
|
217
217
|
1,
|
|
218
218
|
expect.objectContaining({ err: null, status: 500 }),
|
|
219
219
|
'Server error',
|
|
220
220
|
);
|
|
221
221
|
|
|
222
|
-
expect(
|
|
222
|
+
expect(logger.info).not.toBeCalled();
|
|
223
223
|
|
|
224
224
|
metricsClient.expectTagSubset([
|
|
225
225
|
'http_method:get',
|
|
@@ -242,13 +242,13 @@ describe('createApp', () => {
|
|
|
242
242
|
.expect('server', /.+/)
|
|
243
243
|
.expect('x-api-version', /.+/);
|
|
244
244
|
|
|
245
|
-
expect(
|
|
245
|
+
expect(logger.error).nthCalledWith(
|
|
246
246
|
1,
|
|
247
247
|
expect.objectContaining({ err, status: 500 }),
|
|
248
248
|
'Server error',
|
|
249
249
|
);
|
|
250
250
|
|
|
251
|
-
expect(
|
|
251
|
+
expect(logger.info).not.toBeCalled();
|
|
252
252
|
|
|
253
253
|
metricsClient.expectTagSubset([
|
|
254
254
|
'http_method:get',
|
|
@@ -9,7 +9,7 @@ import {
|
|
|
9
9
|
} from 'seek-koala';
|
|
10
10
|
|
|
11
11
|
import { config } from 'src/config';
|
|
12
|
-
import {
|
|
12
|
+
import { contextMiddleware, logger } from 'src/framework/logging';
|
|
13
13
|
import { metricsClient } from 'src/framework/metrics';
|
|
14
14
|
|
|
15
15
|
const metrics = MetricsMiddleware.create(
|
|
@@ -26,8 +26,8 @@ const requestLogging = RequestLogging.createMiddleware((ctx, fields, err) => {
|
|
|
26
26
|
}
|
|
27
27
|
|
|
28
28
|
return ctx.status < 500
|
|
29
|
-
?
|
|
30
|
-
:
|
|
29
|
+
? logger.info(fields, 'Client error')
|
|
30
|
+
: logger.error(fields, 'Server error');
|
|
31
31
|
});
|
|
32
32
|
|
|
33
33
|
const version = VersionMiddleware.create({
|
|
@@ -43,6 +43,7 @@ export const createApp = <State, Context>(
|
|
|
43
43
|
// https://github.com/seek-oss/koala/tree/master/src/secureHeaders
|
|
44
44
|
// https://github.com/venables/koa-helmet
|
|
45
45
|
// .use(SecureHeaders.middleware)
|
|
46
|
+
.use(contextMiddleware)
|
|
46
47
|
.use(requestLogging)
|
|
47
48
|
.use(metrics)
|
|
48
49
|
.use(ErrorMiddleware.handle)
|
|
@@ -2,7 +2,7 @@ import './register';
|
|
|
2
2
|
|
|
3
3
|
import app from './app';
|
|
4
4
|
import { config } from './config';
|
|
5
|
-
import {
|
|
5
|
+
import { logger } from './framework/logging';
|
|
6
6
|
|
|
7
7
|
// This implements a minimal version of `koa-cluster`'s interface
|
|
8
8
|
// If your application is deployed with more than 1 vCPU you can delete this
|
|
@@ -12,6 +12,6 @@ const listener = app.listen(config.port, () => {
|
|
|
12
12
|
const address = listener.address();
|
|
13
13
|
|
|
14
14
|
if (typeof address === 'object' && address) {
|
|
15
|
-
|
|
15
|
+
logger.debug(`listening on port ${address.port}`);
|
|
16
16
|
}
|
|
17
17
|
});
|
|
@@ -1,31 +1,16 @@
|
|
|
1
1
|
import * as logging from 'src/framework/logging';
|
|
2
2
|
|
|
3
|
-
export const
|
|
3
|
+
export const logger = {
|
|
4
4
|
error: jest.fn(),
|
|
5
5
|
info: jest.fn(),
|
|
6
6
|
|
|
7
7
|
clear: () => {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
},
|
|
11
|
-
|
|
12
|
-
spy: () =>
|
|
13
|
-
jest.spyOn(logging, 'contextLogger').mockReturnValue(contextLogger as any),
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
export const rootLogger = {
|
|
17
|
-
error: jest.fn(),
|
|
18
|
-
info: jest.fn(),
|
|
19
|
-
|
|
20
|
-
clear: () => {
|
|
21
|
-
rootLogger.error.mockClear();
|
|
22
|
-
rootLogger.info.mockClear();
|
|
8
|
+
logger.error.mockClear();
|
|
9
|
+
logger.info.mockClear();
|
|
23
10
|
},
|
|
24
11
|
|
|
25
12
|
spy: () => {
|
|
26
|
-
jest
|
|
27
|
-
|
|
28
|
-
.mockImplementation(rootLogger.error);
|
|
29
|
-
jest.spyOn(logging.rootLogger, 'info').mockImplementation(rootLogger.info);
|
|
13
|
+
jest.spyOn(logging.logger, 'error').mockImplementation(logger.error);
|
|
14
|
+
jest.spyOn(logging.logger, 'info').mockImplementation(logger.info);
|
|
30
15
|
},
|
|
31
16
|
};
|
|
@@ -9,7 +9,7 @@ configs:
|
|
|
9
9
|
NPM_READ_TOKEN: arn:aws:secretsmanager:ap-southeast-2:987872074697:secret:npm/npm-read-token
|
|
10
10
|
|
|
11
11
|
- &docker-ecr-cache
|
|
12
|
-
seek-oss/docker-ecr-cache#
|
|
12
|
+
seek-oss/docker-ecr-cache#v2.0.0:
|
|
13
13
|
cache-on:
|
|
14
14
|
- package.json
|
|
15
15
|
- yarn.lock
|
|
@@ -63,6 +63,7 @@ steps:
|
|
|
63
63
|
- *docker-ecr-cache
|
|
64
64
|
- docker-compose#v3.9.0:
|
|
65
65
|
run: app
|
|
66
|
+
timeout_in_minutes: 10
|
|
66
67
|
|
|
67
68
|
- agents:
|
|
68
69
|
queue: <%- devBuildkiteQueueName %>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
16
|