@hanseltime/template-repo-sync 2.2.1 → 2.4.0-alpha.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/CHANGELOG.md +43 -45
- package/dist/cjs/checkout-drivers/git-checkout.js +37 -0
- package/dist/cjs/checkout-drivers/git-checkout.spec.js +60 -0
- package/dist/cjs/checkout-drivers/index.js +21 -0
- package/dist/cjs/checkout-drivers/types.js +11 -0
- package/dist/cjs/clone-drivers/git-clone.js +25 -0
- package/dist/cjs/clone-drivers/index.js +21 -0
- package/dist/cjs/clone-drivers/types.js +8 -0
- package/dist/cjs/diff-drivers/git-diff.js +30 -0
- package/dist/cjs/diff-drivers/git-diff.spec.js +138 -0
- package/dist/cjs/diff-drivers/index.js +21 -0
- package/dist/cjs/diff-drivers/types.js +6 -0
- package/dist/cjs/formatting/index.js +21 -0
- package/dist/cjs/formatting/infer-json-indent.js +26 -0
- package/dist/cjs/formatting/infer-json-indent.spec.js +50 -0
- package/dist/cjs/formatting/sync-results-to-md.js +62 -0
- package/dist/cjs/formatting/sync-results-to-md.spec.js +45 -0
- package/dist/cjs/index.js +22 -0
- package/dist/cjs/load-plugin.js +44 -0
- package/dist/cjs/match.js +51 -0
- package/dist/cjs/match.spec.js +75 -0
- package/dist/cjs/merge-file.js +91 -0
- package/dist/cjs/merge-file.spec.js +508 -0
- package/dist/cjs/plugins/index.js +20 -0
- package/dist/cjs/plugins/json-merge.js +228 -0
- package/dist/cjs/plugins/json-merge.spec.js +514 -0
- package/dist/cjs/ref-drivers/git-current-ref.js +18 -0
- package/dist/cjs/ref-drivers/git-current-ref.spec.js +15 -0
- package/dist/cjs/ref-drivers/index.js +20 -0
- package/dist/cjs/ref-drivers/types.js +11 -0
- package/dist/cjs/template-sync.js +236 -0
- package/dist/cjs/template-sync.spec.js +521 -0
- package/dist/cjs/test-utils/index.js +26 -0
- package/dist/cjs/types.js +12 -0
- package/dist/esm/checkout-drivers/git-checkout.mjs +27 -0
- package/dist/esm/checkout-drivers/git-checkout.spec.mjs +56 -0
- package/dist/esm/checkout-drivers/index.mjs +4 -0
- package/dist/esm/checkout-drivers/types.mjs +8 -0
- package/dist/esm/clone-drivers/git-clone.mjs +15 -0
- package/dist/esm/clone-drivers/index.mjs +4 -0
- package/dist/esm/clone-drivers/types.mjs +8 -0
- package/dist/esm/diff-drivers/git-diff.mjs +26 -0
- package/dist/esm/diff-drivers/git-diff.spec.mjs +93 -0
- package/dist/esm/diff-drivers/index.mjs +4 -0
- package/dist/esm/diff-drivers/types.mjs +6 -0
- package/dist/esm/formatting/index.mjs +4 -0
- package/dist/esm/formatting/infer-json-indent.mjs +16 -0
- package/dist/esm/formatting/infer-json-indent.spec.mjs +46 -0
- package/dist/esm/formatting/sync-results-to-md.mjs +52 -0
- package/dist/esm/formatting/sync-results-to-md.spec.mjs +41 -0
- package/dist/esm/index.mjs +5 -0
- package/dist/esm/load-plugin.mjs +40 -0
- package/dist/esm/match.mjs +40 -0
- package/dist/esm/match.spec.mjs +71 -0
- package/dist/esm/merge-file.mjs +88 -0
- package/dist/esm/merge-file.spec.mjs +504 -0
- package/dist/esm/plugins/index.mjs +10 -0
- package/dist/esm/plugins/json-merge.mjs +164 -0
- package/dist/esm/plugins/json-merge.spec.mjs +469 -0
- package/dist/esm/ref-drivers/git-current-ref.mjs +8 -0
- package/dist/esm/ref-drivers/git-current-ref.spec.mjs +11 -0
- package/dist/esm/ref-drivers/index.mjs +3 -0
- package/dist/esm/ref-drivers/types.mjs +8 -0
- package/dist/esm/template-sync.mjs +174 -0
- package/dist/esm/template-sync.spec.mjs +517 -0
- package/dist/esm/test-utils/index.mjs +10 -0
- package/dist/esm/types.mjs +9 -0
- package/{lib/cjs → dist/types}/checkout-drivers/git-checkout.d.ts +1 -0
- package/dist/types/checkout-drivers/git-checkout.d.ts.map +1 -0
- package/dist/types/checkout-drivers/git-checkout.spec.d.ts +2 -0
- package/dist/types/checkout-drivers/git-checkout.spec.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/checkout-drivers/index.d.ts +1 -0
- package/dist/types/checkout-drivers/index.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/checkout-drivers/types.d.ts +1 -0
- package/dist/types/checkout-drivers/types.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/clone-drivers/git-clone.d.ts +2 -1
- package/dist/types/clone-drivers/git-clone.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/clone-drivers/index.d.ts +2 -1
- package/dist/types/clone-drivers/index.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/clone-drivers/types.d.ts +1 -0
- package/dist/types/clone-drivers/types.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/diff-drivers/git-diff.d.ts +1 -0
- package/dist/types/diff-drivers/git-diff.d.ts.map +1 -0
- package/dist/types/diff-drivers/git-diff.spec.d.ts +2 -0
- package/dist/types/diff-drivers/git-diff.spec.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/diff-drivers/index.d.ts +2 -1
- package/dist/types/diff-drivers/index.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/diff-drivers/types.d.ts +1 -0
- package/dist/types/diff-drivers/types.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/formatting/index.d.ts +2 -1
- package/dist/types/formatting/index.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/formatting/infer-json-indent.d.ts +1 -0
- package/dist/types/formatting/infer-json-indent.d.ts.map +1 -0
- package/dist/types/formatting/infer-json-indent.spec.d.ts +2 -0
- package/dist/types/formatting/infer-json-indent.spec.d.ts.map +1 -0
- package/dist/types/formatting/sync-results-to-md.d.ts +3 -0
- package/dist/types/formatting/sync-results-to-md.d.ts.map +1 -0
- package/dist/types/formatting/sync-results-to-md.spec.d.ts +2 -0
- package/dist/types/formatting/sync-results-to-md.spec.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/index.d.ts +3 -2
- package/dist/types/index.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/load-plugin.d.ts +2 -1
- package/dist/types/load-plugin.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/match.d.ts +1 -0
- package/dist/types/match.d.ts.map +1 -0
- package/dist/types/match.spec.d.ts +2 -0
- package/dist/types/match.spec.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/merge-file.d.ts +3 -2
- package/dist/types/merge-file.d.ts.map +1 -0
- package/dist/types/merge-file.spec.d.ts +2 -0
- package/dist/types/merge-file.spec.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/plugins/index.d.ts +2 -1
- package/dist/types/plugins/index.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/plugins/json-merge.d.ts +2 -1
- package/dist/types/plugins/json-merge.d.ts.map +1 -0
- package/dist/types/plugins/json-merge.spec.d.ts +2 -0
- package/dist/types/plugins/json-merge.spec.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/ref-drivers/git-current-ref.d.ts +1 -0
- package/dist/types/ref-drivers/git-current-ref.d.ts.map +1 -0
- package/dist/types/ref-drivers/git-current-ref.spec.d.ts +2 -0
- package/dist/types/ref-drivers/git-current-ref.spec.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/ref-drivers/index.d.ts +1 -0
- package/dist/types/ref-drivers/index.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/ref-drivers/types.d.ts +1 -0
- package/dist/types/ref-drivers/types.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/template-sync.d.ts +6 -5
- package/dist/types/template-sync.d.ts.map +1 -0
- package/dist/types/template-sync.spec.d.ts +2 -0
- package/dist/types/template-sync.spec.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/test-utils/index.d.ts +1 -0
- package/dist/types/test-utils/index.d.ts.map +1 -0
- package/{lib/cjs → dist/types}/types.d.ts +1 -0
- package/dist/types/types.d.ts.map +1 -0
- package/package.json +26 -23
- package/.eslintrc.js +0 -10
- package/.github/CODEOWNERS +0 -6
- package/.github/workflows/pr-checks.yaml +0 -12
- package/.github/workflows/release.yaml +0 -47
- package/.github/workflows/test-flow.yaml +0 -63
- package/.husky/commit-msg +0 -4
- package/.prettierignore +0 -1
- package/.prettierrc +0 -1
- package/action.yml +0 -13
- package/commitlint.config.js +0 -3
- package/docs/merge-plugins/CURRENT_PLUGINS.md +0 -168
- package/docs/merge-plugins/PLUGIN_DEVELOPMENT.md +0 -122
- package/docs/merge-plugins/README.md +0 -75
- package/jest.config.js +0 -19
- package/lib/cjs/checkout-drivers/git-checkout.js +0 -29
- package/lib/cjs/checkout-drivers/index.js +0 -18
- package/lib/cjs/checkout-drivers/types.js +0 -2
- package/lib/cjs/clone-drivers/git-clone.js +0 -17
- package/lib/cjs/clone-drivers/index.js +0 -18
- package/lib/cjs/clone-drivers/types.js +0 -2
- package/lib/cjs/diff-drivers/git-diff.js +0 -41
- package/lib/cjs/diff-drivers/index.js +0 -18
- package/lib/cjs/diff-drivers/types.js +0 -2
- package/lib/cjs/formatting/index.js +0 -18
- package/lib/cjs/formatting/infer-json-indent.js +0 -18
- package/lib/cjs/formatting/sync-results-to-md.d.ts +0 -2
- package/lib/cjs/formatting/sync-results-to-md.js +0 -57
- package/lib/cjs/index.js +0 -19
- package/lib/cjs/load-plugin.js +0 -69
- package/lib/cjs/match.js +0 -45
- package/lib/cjs/merge-file.js +0 -98
- package/lib/cjs/plugins/index.js +0 -11
- package/lib/cjs/plugins/json-merge.js +0 -208
- package/lib/cjs/ref-drivers/git-current-ref.js +0 -12
- package/lib/cjs/ref-drivers/index.js +0 -17
- package/lib/cjs/ref-drivers/types.js +0 -2
- package/lib/cjs/template-sync.js +0 -163
- package/lib/cjs/test-utils/index.js +0 -10
- package/lib/cjs/types.js +0 -2
- package/lib/esm/checkout-drivers/git-checkout.js +0 -29
- package/lib/esm/checkout-drivers/index.js +0 -18
- package/lib/esm/checkout-drivers/types.js +0 -2
- package/lib/esm/clone-drivers/git-clone.js +0 -17
- package/lib/esm/clone-drivers/index.js +0 -18
- package/lib/esm/clone-drivers/types.js +0 -2
- package/lib/esm/diff-drivers/git-diff.js +0 -41
- package/lib/esm/diff-drivers/index.js +0 -18
- package/lib/esm/diff-drivers/types.js +0 -2
- package/lib/esm/formatting/index.js +0 -18
- package/lib/esm/formatting/infer-json-indent.js +0 -18
- package/lib/esm/formatting/sync-results-to-md.js +0 -57
- package/lib/esm/index.js +0 -19
- package/lib/esm/load-plugin.js +0 -46
- package/lib/esm/match.js +0 -45
- package/lib/esm/merge-file.js +0 -98
- package/lib/esm/plugins/index.js +0 -11
- package/lib/esm/plugins/json-merge.js +0 -208
- package/lib/esm/ref-drivers/git-current-ref.js +0 -12
- package/lib/esm/ref-drivers/index.js +0 -17
- package/lib/esm/ref-drivers/types.js +0 -2
- package/lib/esm/template-sync.js +0 -163
- package/lib/esm/test-utils/index.js +0 -10
- package/lib/esm/types.js +0 -2
- package/release.config.js +0 -40
- package/src/checkout-drivers/git-checkout.spec.ts +0 -69
- package/src/checkout-drivers/git-checkout.ts +0 -38
- package/src/checkout-drivers/index.ts +0 -2
- package/src/checkout-drivers/types.ts +0 -14
- package/src/clone-drivers/git-clone.ts +0 -20
- package/src/clone-drivers/index.ts +0 -2
- package/src/clone-drivers/types.ts +0 -20
- package/src/diff-drivers/git-diff.spec.ts +0 -73
- package/src/diff-drivers/git-diff.ts +0 -39
- package/src/diff-drivers/index.ts +0 -2
- package/src/diff-drivers/types.ts +0 -14
- package/src/formatting/__snapshots__/sync-results-to-md.spec.ts.snap +0 -39
- package/src/formatting/index.ts +0 -2
- package/src/formatting/infer-json-indent.spec.ts +0 -49
- package/src/formatting/infer-json-indent.ts +0 -16
- package/src/formatting/sync-results-to-md.spec.ts +0 -31
- package/src/formatting/sync-results-to-md.ts +0 -63
- package/src/index.ts +0 -3
- package/src/load-plugin.ts +0 -51
- package/src/match.spec.ts +0 -68
- package/src/match.ts +0 -52
- package/src/merge-file.spec.ts +0 -506
- package/src/merge-file.ts +0 -154
- package/src/plugins/index.ts +0 -12
- package/src/plugins/json-merge.spec.ts +0 -436
- package/src/plugins/json-merge.ts +0 -215
- package/src/ref-drivers/git-current-ref.spec.ts +0 -12
- package/src/ref-drivers/git-current-ref.ts +0 -9
- package/src/ref-drivers/index.ts +0 -1
- package/src/ref-drivers/types.ts +0 -10
- package/src/template-sync.spec.ts +0 -509
- package/src/template-sync.ts +0 -256
- package/src/test-utils/index.ts +0 -13
- package/src/types.ts +0 -129
- package/templatesync.local.json +0 -15
- package/test-fixtures/downstream/README.md +0 -3
- package/test-fixtures/downstream/package.json +0 -18
- package/test-fixtures/downstream/plugins/custom-plugin.js +0 -11
- package/test-fixtures/downstream/src/index.js +0 -2
- package/test-fixtures/downstream/src/index.ts +0 -1
- package/test-fixtures/downstream/src/templated.js +0 -2
- package/test-fixtures/downstream/src/templated.ts +0 -1
- package/test-fixtures/downstream/templatesync.json +0 -16
- package/test-fixtures/downstream/templatesync.local.json +0 -10
- package/test-fixtures/dummy-plugin.js +0 -8
- package/test-fixtures/glob-test/folder1/something.js +0 -1
- package/test-fixtures/glob-test/folder1/something.ts +0 -0
- package/test-fixtures/glob-test/toplevel.js +0 -0
- package/test-fixtures/glob-test/toplevel.txt +0 -0
- package/test-fixtures/template/custom-bin/something.txt +0 -1
- package/test-fixtures/template/package.json +0 -17
- package/test-fixtures/template/src/index.js +0 -2
- package/test-fixtures/template/src/index.ts +0 -1
- package/test-fixtures/template/src/templated.js +0 -2
- package/test-fixtures/template/src/templated.ts +0 -1
- package/test-fixtures/template/templatesync.json +0 -16
- package/test-fixtures/testGitRepo/README.md +0 -17
- package/test-fixtures/testGitRepo/gitDir/COMMIT_EDITMSG +0 -14
- package/test-fixtures/testGitRepo/gitDir/HEAD +0 -1
- package/test-fixtures/testGitRepo/gitDir/config +0 -7
- package/test-fixtures/testGitRepo/gitDir/description +0 -1
- package/test-fixtures/testGitRepo/gitDir/hooks/applypatch-msg.sample +0 -15
- package/test-fixtures/testGitRepo/gitDir/hooks/commit-msg.sample +0 -24
- package/test-fixtures/testGitRepo/gitDir/hooks/fsmonitor-watchman.sample +0 -174
- package/test-fixtures/testGitRepo/gitDir/hooks/post-update.sample +0 -8
- package/test-fixtures/testGitRepo/gitDir/hooks/pre-applypatch.sample +0 -14
- package/test-fixtures/testGitRepo/gitDir/hooks/pre-commit.sample +0 -49
- package/test-fixtures/testGitRepo/gitDir/hooks/pre-merge-commit.sample +0 -13
- package/test-fixtures/testGitRepo/gitDir/hooks/pre-push.sample +0 -53
- package/test-fixtures/testGitRepo/gitDir/hooks/pre-rebase.sample +0 -169
- package/test-fixtures/testGitRepo/gitDir/hooks/pre-receive.sample +0 -24
- package/test-fixtures/testGitRepo/gitDir/hooks/prepare-commit-msg.sample +0 -42
- package/test-fixtures/testGitRepo/gitDir/hooks/push-to-checkout.sample +0 -78
- package/test-fixtures/testGitRepo/gitDir/hooks/sendemail-validate.sample +0 -77
- package/test-fixtures/testGitRepo/gitDir/hooks/update.sample +0 -128
- package/test-fixtures/testGitRepo/gitDir/index +0 -0
- package/test-fixtures/testGitRepo/gitDir/info/exclude +0 -6
- package/test-fixtures/testGitRepo/gitDir/logs/HEAD +0 -5
- package/test-fixtures/testGitRepo/gitDir/logs/refs/heads/master +0 -2
- package/test-fixtures/testGitRepo/gitDir/logs/refs/heads/test-branch +0 -2
- package/test-fixtures/testGitRepo/gitDir/objects/4b/825dc642cb6eb9a060e54bf8d69288fbee4904 +0 -0
- package/test-fixtures/testGitRepo/gitDir/objects/6e/187bee8d02f39d0a1be8331dd8fe6a00c9b613 +0 -0
- package/test-fixtures/testGitRepo/gitDir/objects/73/185f1f3f5a6345e087d9f46dc4af77cc59449f +0 -2
- package/test-fixtures/testGitRepo/gitDir/objects/90/e7ea1089f939840e9649fd617584c1ad117159 +0 -3
- package/test-fixtures/testGitRepo/gitDir/objects/ba/99a452b9097047e9bfa8d5a08b3e452fcb364a +0 -0
- package/test-fixtures/testGitRepo/gitDir/objects/c5/8d400177cd5180b8566f82a127fafc5bf394b7 +0 -0
- package/test-fixtures/testGitRepo/gitDir/objects/e2/e668265db019249a7e8296d85f79000e3d71cf +0 -0
- package/test-fixtures/testGitRepo/gitDir/objects/e4/243e430c1ab69f3e344249f5b1859e90abc883 +0 -1
- package/test-fixtures/testGitRepo/gitDir/objects/ec/6c1cb72312605282ac61858cf1eaf1ea9f1d02 +0 -0
- package/test-fixtures/testGitRepo/gitDir/objects/fc/89cecc4ac0b5b075bd7d0ce9e09b2f50598b82 +0 -0
- package/test-fixtures/testGitRepo/gitDir/refs/heads/master +0 -1
- package/test-fixtures/testGitRepo/gitDir/refs/heads/test-branch +0 -1
- package/tsconfig.cjs.json +0 -12
- package/tsconfig.esm.json +0 -10
- package/tsconfig.json +0 -22
|
@@ -0,0 +1,517 @@
|
|
|
1
|
+
import { existsSync, readFileSync, writeFileSync } from "fs";
|
|
2
|
+
import { mkdtemp, readFile, rm } from "node:fs/promises";
|
|
3
|
+
import { copy } from "fs-extra";
|
|
4
|
+
import { join, resolve } from "path";
|
|
5
|
+
import { templateSync } from "./template-sync.mjs";
|
|
6
|
+
import { TEST_FIXTURES_DIR, tempDir } from "./test-utils/index.mjs";
|
|
7
|
+
const dummyCheckoutDriver = jest.fn();
|
|
8
|
+
const dummyCurrentRefDriver = jest.fn();
|
|
9
|
+
const downstreamDir = resolve(TEST_FIXTURES_DIR, "downstream");
|
|
10
|
+
describe("templateSync", ()=>{
|
|
11
|
+
let tmpDir;
|
|
12
|
+
let templateDir;
|
|
13
|
+
let dummyCloneDriver;
|
|
14
|
+
beforeEach(async ()=>{
|
|
15
|
+
jest.resetAllMocks();
|
|
16
|
+
tmpDir = await mkdtemp(tempDir());
|
|
17
|
+
templateDir = await mkdtemp(tempDir());
|
|
18
|
+
await copy(resolve(TEST_FIXTURES_DIR, "template"), templateDir);
|
|
19
|
+
await copy(downstreamDir, tmpDir);
|
|
20
|
+
dummyCloneDriver = async ()=>{
|
|
21
|
+
return {
|
|
22
|
+
dir: templateDir,
|
|
23
|
+
remoteName: "ourRemote"
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
});
|
|
27
|
+
afterEach(async ()=>{
|
|
28
|
+
await rm(tmpDir, {
|
|
29
|
+
force: true,
|
|
30
|
+
recursive: true
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
// Note: for this test, we expect actions and users to handle misconfigured template syncs
|
|
34
|
+
it.each([
|
|
35
|
+
[
|
|
36
|
+
"local",
|
|
37
|
+
`templatesync.local.json plugin option errors:
|
|
38
|
+
\tPlugin (plugins/fail-validate-plugin.js):
|
|
39
|
+
\t\toh no!
|
|
40
|
+
\t\tnot this one too!
|
|
41
|
+
`
|
|
42
|
+
],
|
|
43
|
+
[
|
|
44
|
+
"template",
|
|
45
|
+
`templatesync.json plugin option errors:
|
|
46
|
+
\tPlugin (dummy-fail-plugin.js):
|
|
47
|
+
\t\tshucks
|
|
48
|
+
\t\tno good
|
|
49
|
+
`
|
|
50
|
+
],
|
|
51
|
+
[
|
|
52
|
+
"both",
|
|
53
|
+
`templatesync.json plugin option errors:
|
|
54
|
+
\tPlugin (dummy-fail-plugin.js):
|
|
55
|
+
\t\tshucks
|
|
56
|
+
\t\tno good
|
|
57
|
+
templatesync.local.json plugin option errors:
|
|
58
|
+
\tPlugin (plugins/fail-validate-plugin.js):
|
|
59
|
+
\t\toh no!
|
|
60
|
+
\t\tnot this one too!
|
|
61
|
+
`
|
|
62
|
+
]
|
|
63
|
+
])("throws errors from plugin validation", async (mode, expected)=>{
|
|
64
|
+
// Remove the local sync overrides
|
|
65
|
+
await rm(join(tmpDir, "templatesync.local.json"));
|
|
66
|
+
if (mode === "local" || mode == "both") {
|
|
67
|
+
writeFileSync(join(tmpDir, "templatesync.local.json"), JSON.stringify({
|
|
68
|
+
ignore: [
|
|
69
|
+
// Ignores the templated.ts
|
|
70
|
+
"**/*.ts",
|
|
71
|
+
// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins
|
|
72
|
+
"plugins/**"
|
|
73
|
+
],
|
|
74
|
+
merge: [
|
|
75
|
+
{
|
|
76
|
+
glob: "package.json",
|
|
77
|
+
plugin: "plugins/fail-validate-plugin.js",
|
|
78
|
+
options: {}
|
|
79
|
+
}
|
|
80
|
+
]
|
|
81
|
+
}));
|
|
82
|
+
}
|
|
83
|
+
if (mode === "template" || mode === "both") {
|
|
84
|
+
writeFileSync(join(templateDir, "templatesync.json"), JSON.stringify({
|
|
85
|
+
ignore: [
|
|
86
|
+
// Ignores the templated.ts
|
|
87
|
+
"**/*.ts",
|
|
88
|
+
// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins
|
|
89
|
+
"plugins/**"
|
|
90
|
+
],
|
|
91
|
+
merge: [
|
|
92
|
+
{
|
|
93
|
+
glob: "package.json",
|
|
94
|
+
plugin: "dummy-fail-plugin.js",
|
|
95
|
+
options: {}
|
|
96
|
+
}
|
|
97
|
+
]
|
|
98
|
+
}));
|
|
99
|
+
}
|
|
100
|
+
await expect(async ()=>await templateSync({
|
|
101
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
102
|
+
cloneDriver: dummyCloneDriver,
|
|
103
|
+
repoUrl: "not-important",
|
|
104
|
+
repoDir: tmpDir,
|
|
105
|
+
checkoutDriver: dummyCheckoutDriver,
|
|
106
|
+
currentRefDriver: dummyCurrentRefDriver
|
|
107
|
+
})).rejects.toThrow(expected);
|
|
108
|
+
});
|
|
109
|
+
it("appropriately merges according to just the templatesync config file into an empty dir", async ()=>{
|
|
110
|
+
const emptyTmpDir = await mkdtemp(tempDir());
|
|
111
|
+
expect(await templateSync({
|
|
112
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
113
|
+
cloneDriver: dummyCloneDriver,
|
|
114
|
+
repoUrl: "not-important",
|
|
115
|
+
repoDir: emptyTmpDir,
|
|
116
|
+
checkoutDriver: dummyCheckoutDriver,
|
|
117
|
+
currentRefDriver: dummyCurrentRefDriver
|
|
118
|
+
})).toEqual({
|
|
119
|
+
// Expect no changes since there was no local sync file
|
|
120
|
+
localSkipFiles: [],
|
|
121
|
+
localFileChanges: {},
|
|
122
|
+
modifiedFiles: {
|
|
123
|
+
added: [
|
|
124
|
+
"package.json",
|
|
125
|
+
"src/index.js",
|
|
126
|
+
"src/templated.js",
|
|
127
|
+
"src/templated.ts",
|
|
128
|
+
"templatesync.json"
|
|
129
|
+
],
|
|
130
|
+
deleted: [],
|
|
131
|
+
modified: [],
|
|
132
|
+
total: 5
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
// Verify the files
|
|
136
|
+
await fileMatchTemplate(emptyTmpDir, "templatesync.json");
|
|
137
|
+
await fileMatchTemplate(emptyTmpDir, "package.json");
|
|
138
|
+
await fileMatchTemplate(emptyTmpDir, "src/templated.ts");
|
|
139
|
+
// Expect the ignores to not be a problem
|
|
140
|
+
expect(existsSync(resolve(emptyTmpDir, "src/index.ts"))).toBeFalsy();
|
|
141
|
+
expect(existsSync(resolve(emptyTmpDir, "src/custom-bin"))).toBeFalsy();
|
|
142
|
+
expect(dummyCheckoutDriver).not.toHaveBeenCalled();
|
|
143
|
+
});
|
|
144
|
+
it("Checks out the branch and then appropriately merges", async ()=>{
|
|
145
|
+
const emptyTmpDir = await mkdtemp(tempDir());
|
|
146
|
+
expect(await templateSync({
|
|
147
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
148
|
+
cloneDriver: dummyCloneDriver,
|
|
149
|
+
repoUrl: "not-important",
|
|
150
|
+
repoDir: emptyTmpDir,
|
|
151
|
+
branch: "new-template-test",
|
|
152
|
+
checkoutDriver: dummyCheckoutDriver,
|
|
153
|
+
currentRefDriver: dummyCurrentRefDriver
|
|
154
|
+
})).toEqual({
|
|
155
|
+
// Expect no changes since there was no local sync file
|
|
156
|
+
localSkipFiles: [],
|
|
157
|
+
localFileChanges: {},
|
|
158
|
+
modifiedFiles: {
|
|
159
|
+
added: [
|
|
160
|
+
"package.json",
|
|
161
|
+
"src/index.js",
|
|
162
|
+
"src/templated.js",
|
|
163
|
+
"src/templated.ts",
|
|
164
|
+
"templatesync.json"
|
|
165
|
+
],
|
|
166
|
+
deleted: [],
|
|
167
|
+
modified: [],
|
|
168
|
+
total: 5
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
// Verify the files
|
|
172
|
+
await fileMatchTemplate(emptyTmpDir, "templatesync.json");
|
|
173
|
+
await fileMatchTemplate(emptyTmpDir, "package.json");
|
|
174
|
+
await fileMatchTemplate(emptyTmpDir, "src/templated.ts");
|
|
175
|
+
// Expect the ignores to not be a problem
|
|
176
|
+
expect(existsSync(resolve(emptyTmpDir, "src/index.ts"))).toBeFalsy();
|
|
177
|
+
expect(existsSync(resolve(emptyTmpDir, "src/custom-bin"))).toBeFalsy();
|
|
178
|
+
const cloneInfo = await dummyCloneDriver();
|
|
179
|
+
expect(dummyCheckoutDriver).toHaveBeenCalledWith({
|
|
180
|
+
tmpDir: cloneInfo.dir,
|
|
181
|
+
remoteName: cloneInfo.remoteName,
|
|
182
|
+
branch: "new-template-test"
|
|
183
|
+
});
|
|
184
|
+
});
|
|
185
|
+
it("appropriately merges according to just the templatesync config file in an existing repo", async ()=>{
|
|
186
|
+
// Remove the local sync overrides
|
|
187
|
+
await rm(join(tmpDir, "templatesync.local.json"));
|
|
188
|
+
const result = await templateSync({
|
|
189
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
190
|
+
cloneDriver: dummyCloneDriver,
|
|
191
|
+
repoUrl: "not-important",
|
|
192
|
+
repoDir: tmpDir,
|
|
193
|
+
checkoutDriver: dummyCheckoutDriver,
|
|
194
|
+
currentRefDriver: dummyCurrentRefDriver
|
|
195
|
+
});
|
|
196
|
+
expect(result.localSkipFiles).toEqual([]);
|
|
197
|
+
expect(result.localFileChanges).toEqual({});
|
|
198
|
+
// Verify the files
|
|
199
|
+
await fileMatchTemplate(tmpDir, "templatesync.json");
|
|
200
|
+
await fileMatchTemplate(tmpDir, "src/templated.ts");
|
|
201
|
+
const packageJson = JSON.parse(readFileSync(resolve(tmpDir, "package.json")).toString());
|
|
202
|
+
expect(packageJson).toEqual({
|
|
203
|
+
name: "mypkg",
|
|
204
|
+
description: "my description",
|
|
205
|
+
dependencies: {
|
|
206
|
+
mypackage: "^1.2.0",
|
|
207
|
+
newpacakge: "^22.2.2",
|
|
208
|
+
package2: "3.22.1",
|
|
209
|
+
huh: "~1.0.0"
|
|
210
|
+
},
|
|
211
|
+
engines: {
|
|
212
|
+
node: ">=15"
|
|
213
|
+
},
|
|
214
|
+
scripts: {
|
|
215
|
+
build: "build",
|
|
216
|
+
test: "jest",
|
|
217
|
+
myscript: "somescript"
|
|
218
|
+
},
|
|
219
|
+
// By default we add new top-level fields
|
|
220
|
+
version: "new-version"
|
|
221
|
+
});
|
|
222
|
+
// Expect the ignores to not be a problem
|
|
223
|
+
await fileMatchDownstream(tmpDir, "src/index.ts");
|
|
224
|
+
await fileMatchDownstream(tmpDir, "plugins/custom-plugin.js");
|
|
225
|
+
expect(dummyCheckoutDriver).not.toHaveBeenCalled();
|
|
226
|
+
});
|
|
227
|
+
it("appropriately merges according to the templatesync config file and the local config in an existing repo", async ()=>{
|
|
228
|
+
// Remove the local sync overrides
|
|
229
|
+
await rm(join(tmpDir, "templatesync.local.json"));
|
|
230
|
+
writeFileSync(join(tmpDir, "templatesync.local.json"), JSON.stringify({
|
|
231
|
+
ignore: [
|
|
232
|
+
// Ignores the templated.ts
|
|
233
|
+
"**/*.ts",
|
|
234
|
+
// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins
|
|
235
|
+
"plugins/**"
|
|
236
|
+
],
|
|
237
|
+
merge: [
|
|
238
|
+
{
|
|
239
|
+
glob: "package.json",
|
|
240
|
+
plugin: "plugins/custom-plugin.js",
|
|
241
|
+
options: {}
|
|
242
|
+
}
|
|
243
|
+
]
|
|
244
|
+
}));
|
|
245
|
+
const result = await templateSync({
|
|
246
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
247
|
+
cloneDriver: dummyCloneDriver,
|
|
248
|
+
repoUrl: "not-important",
|
|
249
|
+
repoDir: tmpDir,
|
|
250
|
+
checkoutDriver: dummyCheckoutDriver,
|
|
251
|
+
currentRefDriver: dummyCurrentRefDriver
|
|
252
|
+
});
|
|
253
|
+
expect(result.localSkipFiles).toEqual([
|
|
254
|
+
"src/templated.ts"
|
|
255
|
+
]);
|
|
256
|
+
// TODO: more rigorous testing around diff changes
|
|
257
|
+
expect(result.localFileChanges).toEqual(expect.objectContaining({
|
|
258
|
+
"package.json": expect.arrayContaining([])
|
|
259
|
+
}));
|
|
260
|
+
// Make sure the result captures the changes
|
|
261
|
+
expect(result.modifiedFiles).toEqual({
|
|
262
|
+
added: [
|
|
263
|
+
"package.json",
|
|
264
|
+
"src/index.js",
|
|
265
|
+
"src/templated.js",
|
|
266
|
+
"templatesync.json"
|
|
267
|
+
],
|
|
268
|
+
deleted: [],
|
|
269
|
+
modified: [],
|
|
270
|
+
total: 4
|
|
271
|
+
});
|
|
272
|
+
// Verify the files
|
|
273
|
+
await fileMatchTemplate(tmpDir, "templatesync.json");
|
|
274
|
+
await fileMatchDownstream(tmpDir, "src/templated.ts");
|
|
275
|
+
const packageJson = JSON.parse(readFileSync(resolve(tmpDir, "package.json")).toString());
|
|
276
|
+
// The plugin nuked this
|
|
277
|
+
expect(packageJson).toEqual({
|
|
278
|
+
downstream: true
|
|
279
|
+
});
|
|
280
|
+
// Expect the ignores to not be a problem
|
|
281
|
+
await fileMatchDownstream(tmpDir, "src/index.ts");
|
|
282
|
+
await fileMatchDownstream(tmpDir, "plugins/custom-plugin.js");
|
|
283
|
+
expect(dummyCheckoutDriver).not.toHaveBeenCalled();
|
|
284
|
+
});
|
|
285
|
+
it("appropriately merges according to the templatesync config file and the local config in an existing repo with afterRef", async ()=>{
|
|
286
|
+
// Remove the local sync overrides
|
|
287
|
+
await rm(join(tmpDir, "templatesync.local.json"));
|
|
288
|
+
writeFileSync(join(tmpDir, "templatesync.local.json"), JSON.stringify({
|
|
289
|
+
afterRef: "dummySha",
|
|
290
|
+
ignore: [
|
|
291
|
+
// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins
|
|
292
|
+
"plugins/**"
|
|
293
|
+
]
|
|
294
|
+
}));
|
|
295
|
+
// We will only update the templated.ts
|
|
296
|
+
const mockDiffDriver = jest.fn().mockImplementation(async ()=>({
|
|
297
|
+
added: [
|
|
298
|
+
"src/templated.ts"
|
|
299
|
+
],
|
|
300
|
+
modified: [],
|
|
301
|
+
deleted: []
|
|
302
|
+
}));
|
|
303
|
+
const result = await templateSync({
|
|
304
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
305
|
+
cloneDriver: dummyCloneDriver,
|
|
306
|
+
repoUrl: "not-important",
|
|
307
|
+
repoDir: tmpDir,
|
|
308
|
+
diffDriver: mockDiffDriver,
|
|
309
|
+
currentRefDriver: dummyCurrentRefDriver,
|
|
310
|
+
checkoutDriver: dummyCheckoutDriver
|
|
311
|
+
});
|
|
312
|
+
// since there was no override for this file, not changes from the local file
|
|
313
|
+
expect(result.localFileChanges).toEqual(expect.objectContaining({}));
|
|
314
|
+
// Verify the files
|
|
315
|
+
await fileMatchTemplate(tmpDir, "templatesync.json");
|
|
316
|
+
await fileMatchTemplate(tmpDir, "src/templated.ts");
|
|
317
|
+
// Expect the none of the diff files to work
|
|
318
|
+
await fileMatchDownstream(tmpDir, "src/index.ts");
|
|
319
|
+
await fileMatchDownstream(tmpDir, "plugins/custom-plugin.js");
|
|
320
|
+
await fileMatchDownstream(tmpDir, "package.json");
|
|
321
|
+
expect(dummyCheckoutDriver).not.toHaveBeenCalled();
|
|
322
|
+
});
|
|
323
|
+
it("updates the local templatesync with the current ref if updateAfterRef is true", async ()=>{
|
|
324
|
+
// Remove the local sync overrides
|
|
325
|
+
await rm(join(tmpDir, "templatesync.local.json"));
|
|
326
|
+
const mockLocalConfig = {
|
|
327
|
+
afterRef: "dummySha",
|
|
328
|
+
ignore: [
|
|
329
|
+
// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins
|
|
330
|
+
"plugins/**"
|
|
331
|
+
]
|
|
332
|
+
};
|
|
333
|
+
writeFileSync(join(tmpDir, "templatesync.local.json"), JSON.stringify(mockLocalConfig));
|
|
334
|
+
// We will only update the templated.ts
|
|
335
|
+
const mockDiffDriver = jest.fn().mockImplementation(async ()=>({
|
|
336
|
+
added: [
|
|
337
|
+
"src/templated.ts"
|
|
338
|
+
],
|
|
339
|
+
modified: [
|
|
340
|
+
"src/index.ts"
|
|
341
|
+
],
|
|
342
|
+
deleted: []
|
|
343
|
+
}));
|
|
344
|
+
const mockCurrentRefDriver = jest.fn().mockImplementation(async ()=>"newestSha");
|
|
345
|
+
const result = await templateSync({
|
|
346
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
347
|
+
cloneDriver: dummyCloneDriver,
|
|
348
|
+
repoUrl: "not-important",
|
|
349
|
+
repoDir: tmpDir,
|
|
350
|
+
updateAfterRef: true,
|
|
351
|
+
diffDriver: mockDiffDriver,
|
|
352
|
+
currentRefDriver: mockCurrentRefDriver,
|
|
353
|
+
checkoutDriver: dummyCheckoutDriver
|
|
354
|
+
});
|
|
355
|
+
// since there was no override for this file, no changes from the local file
|
|
356
|
+
expect(result.localFileChanges).toEqual(expect.objectContaining({}));
|
|
357
|
+
expect(result.modifiedFiles).toEqual({
|
|
358
|
+
added: [
|
|
359
|
+
"src/templated.ts"
|
|
360
|
+
],
|
|
361
|
+
modified: [
|
|
362
|
+
"templatesync.local.json"
|
|
363
|
+
],
|
|
364
|
+
deleted: [],
|
|
365
|
+
total: 2
|
|
366
|
+
});
|
|
367
|
+
// Verify the files
|
|
368
|
+
await fileMatchTemplate(tmpDir, "templatesync.json");
|
|
369
|
+
await fileMatchTemplate(tmpDir, "src/templated.ts");
|
|
370
|
+
// Expect the none of the diff files to work
|
|
371
|
+
await fileMatchDownstream(tmpDir, "src/index.ts");
|
|
372
|
+
await fileMatchDownstream(tmpDir, "plugins/custom-plugin.js");
|
|
373
|
+
await fileMatchDownstream(tmpDir, "package.json");
|
|
374
|
+
// Ensure we have updated the local template field
|
|
375
|
+
expect(JSON.parse((await readFile(join(tmpDir, "templatesync.local.json"))).toString())).toEqual({
|
|
376
|
+
...mockLocalConfig,
|
|
377
|
+
afterRef: "newestSha"
|
|
378
|
+
});
|
|
379
|
+
expect(dummyCheckoutDriver).not.toHaveBeenCalled();
|
|
380
|
+
});
|
|
381
|
+
it("Does not update the local templatesync if updateAfterRef is true and the ref is the same", async ()=>{
|
|
382
|
+
// Remove the local sync overrides
|
|
383
|
+
await rm(join(tmpDir, "templatesync.local.json"));
|
|
384
|
+
const mockLocalConfig = {
|
|
385
|
+
afterRef: "dummySha",
|
|
386
|
+
ignore: [
|
|
387
|
+
// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins
|
|
388
|
+
"plugins/**"
|
|
389
|
+
]
|
|
390
|
+
};
|
|
391
|
+
writeFileSync(join(tmpDir, "templatesync.local.json"), JSON.stringify(mockLocalConfig));
|
|
392
|
+
// We will only update the templated.ts
|
|
393
|
+
const mockDiffDriver = jest.fn().mockImplementation(async ()=>({
|
|
394
|
+
added: [
|
|
395
|
+
"src/templated.ts"
|
|
396
|
+
],
|
|
397
|
+
modified: [
|
|
398
|
+
"src/index.ts"
|
|
399
|
+
],
|
|
400
|
+
deleted: []
|
|
401
|
+
}));
|
|
402
|
+
const mockCurrentRefDriver = jest.fn().mockImplementation(async ()=>"dummySha");
|
|
403
|
+
const result = await templateSync({
|
|
404
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
405
|
+
cloneDriver: dummyCloneDriver,
|
|
406
|
+
repoUrl: "not-important",
|
|
407
|
+
repoDir: tmpDir,
|
|
408
|
+
updateAfterRef: true,
|
|
409
|
+
diffDriver: mockDiffDriver,
|
|
410
|
+
currentRefDriver: mockCurrentRefDriver,
|
|
411
|
+
checkoutDriver: dummyCheckoutDriver
|
|
412
|
+
});
|
|
413
|
+
// Nothing shoudl be reported as changing
|
|
414
|
+
expect(result).toEqual({
|
|
415
|
+
localFileChanges: {},
|
|
416
|
+
localSkipFiles: [],
|
|
417
|
+
modifiedFiles: {
|
|
418
|
+
added: [],
|
|
419
|
+
modified: [],
|
|
420
|
+
deleted: [],
|
|
421
|
+
total: 0
|
|
422
|
+
}
|
|
423
|
+
});
|
|
424
|
+
// Verify the files
|
|
425
|
+
await fileMatchDownstream(tmpDir, "templatesync.json");
|
|
426
|
+
await fileMatchDownstream(tmpDir, "src/templated.ts");
|
|
427
|
+
// Expect the none of the diff files to work
|
|
428
|
+
await fileMatchDownstream(tmpDir, "src/index.ts");
|
|
429
|
+
await fileMatchDownstream(tmpDir, "plugins/custom-plugin.js");
|
|
430
|
+
await fileMatchDownstream(tmpDir, "package.json");
|
|
431
|
+
// Ensure we have updated the local template field
|
|
432
|
+
expect(JSON.parse((await readFile(join(tmpDir, "templatesync.local.json"))).toString())).toEqual({
|
|
433
|
+
...mockLocalConfig
|
|
434
|
+
});
|
|
435
|
+
expect(dummyCheckoutDriver).not.toHaveBeenCalled();
|
|
436
|
+
});
|
|
437
|
+
it("creates the local templatesync with the current ref if updateAfterRef is true and no local template exists", async ()=>{
|
|
438
|
+
// Remove the local sync overrides
|
|
439
|
+
await rm(join(tmpDir, "templatesync.local.json"));
|
|
440
|
+
// We will only update the templated.ts
|
|
441
|
+
const mockDiffDriver = jest.fn().mockImplementation(async ()=>({
|
|
442
|
+
added: [
|
|
443
|
+
"src/templated.ts"
|
|
444
|
+
]
|
|
445
|
+
}));
|
|
446
|
+
const mockCurrentRefDriver = jest.fn().mockImplementation(async ()=>"newestSha");
|
|
447
|
+
const result = await templateSync({
|
|
448
|
+
tmpCloneDir: "stubbed-by-driver",
|
|
449
|
+
cloneDriver: dummyCloneDriver,
|
|
450
|
+
repoUrl: "not-important",
|
|
451
|
+
repoDir: tmpDir,
|
|
452
|
+
updateAfterRef: true,
|
|
453
|
+
diffDriver: mockDiffDriver,
|
|
454
|
+
currentRefDriver: mockCurrentRefDriver,
|
|
455
|
+
checkoutDriver: dummyCheckoutDriver
|
|
456
|
+
});
|
|
457
|
+
// since there was no override for this file, no changes from the local file
|
|
458
|
+
expect(result.localFileChanges).toEqual(expect.objectContaining({}));
|
|
459
|
+
expect(result.modifiedFiles).toEqual({
|
|
460
|
+
added: [
|
|
461
|
+
"package.json",
|
|
462
|
+
"src/index.js",
|
|
463
|
+
"src/templated.js",
|
|
464
|
+
"src/templated.ts",
|
|
465
|
+
"templatesync.json",
|
|
466
|
+
"templatesync.local.json"
|
|
467
|
+
],
|
|
468
|
+
deleted: [],
|
|
469
|
+
modified: [],
|
|
470
|
+
total: 6
|
|
471
|
+
});
|
|
472
|
+
// Verify the files
|
|
473
|
+
await fileMatchTemplate(tmpDir, "templatesync.json");
|
|
474
|
+
await fileMatchTemplate(tmpDir, "src/templated.ts");
|
|
475
|
+
const packageJson = JSON.parse(readFileSync(resolve(tmpDir, "package.json")).toString());
|
|
476
|
+
expect(packageJson).toEqual({
|
|
477
|
+
name: "mypkg",
|
|
478
|
+
description: "my description",
|
|
479
|
+
dependencies: {
|
|
480
|
+
mypackage: "^1.2.0",
|
|
481
|
+
newpacakge: "^22.2.2",
|
|
482
|
+
package2: "3.22.1",
|
|
483
|
+
huh: "~1.0.0"
|
|
484
|
+
},
|
|
485
|
+
engines: {
|
|
486
|
+
node: ">=15"
|
|
487
|
+
},
|
|
488
|
+
scripts: {
|
|
489
|
+
build: "build",
|
|
490
|
+
test: "jest",
|
|
491
|
+
myscript: "somescript"
|
|
492
|
+
},
|
|
493
|
+
// By default we add new top-level fields
|
|
494
|
+
version: "new-version"
|
|
495
|
+
});
|
|
496
|
+
// Expect the none of the diff files to work
|
|
497
|
+
await fileMatchDownstream(tmpDir, "src/index.ts");
|
|
498
|
+
await fileMatchDownstream(tmpDir, "plugins/custom-plugin.js");
|
|
499
|
+
// Ensure we have updated the local template field
|
|
500
|
+
expect(JSON.parse((await readFile(join(tmpDir, "templatesync.local.json"))).toString())).toEqual({
|
|
501
|
+
afterRef: "newestSha"
|
|
502
|
+
});
|
|
503
|
+
});
|
|
504
|
+
// helper
|
|
505
|
+
async function fileMatchTemplate(_tmpDir, relPath) {
|
|
506
|
+
return fileMatch(_tmpDir, relPath, "template");
|
|
507
|
+
}
|
|
508
|
+
async function fileMatchDownstream(_tmpDir, relPath) {
|
|
509
|
+
return fileMatch(_tmpDir, relPath, "downstream");
|
|
510
|
+
}
|
|
511
|
+
async function fileMatch(_tmpDir, relPath, source) {
|
|
512
|
+
const dir = source === "downstream" ? downstreamDir : (await dummyCloneDriver()).dir;
|
|
513
|
+
expect((await readFile(resolve(_tmpDir, relPath))).toString()).toEqual((await readFile(resolve(dir, relPath))).toString());
|
|
514
|
+
}
|
|
515
|
+
});
|
|
516
|
+
|
|
517
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/template-sync.spec.ts"],"sourcesContent":["import { existsSync, readFileSync, writeFileSync } from \"fs\";\nimport { mkdtemp, readFile, rm } from \"fs/promises\";\nimport { copy } from \"fs-extra\";\nimport { join, resolve } from \"path\";\nimport { templateSync } from \"./template-sync\";\nimport { TEST_FIXTURES_DIR, tempDir } from \"./test-utils\";\n\nconst dummyCheckoutDriver = jest.fn();\nconst dummyCurrentRefDriver = jest.fn();\n\nconst downstreamDir = resolve(TEST_FIXTURES_DIR, \"downstream\");\n\ndescribe(\"templateSync\", () => {\n\tlet tmpDir: string;\n\tlet templateDir: string;\n\tlet dummyCloneDriver: () => Promise<{ dir: string; remoteName: string }>;\n\tbeforeEach(async () => {\n\t\tjest.resetAllMocks();\n\t\ttmpDir = await mkdtemp(tempDir());\n\t\ttemplateDir = await mkdtemp(tempDir());\n\t\tawait copy(resolve(TEST_FIXTURES_DIR, \"template\"), templateDir);\n\t\tawait copy(downstreamDir, tmpDir);\n\t\tdummyCloneDriver = async () => {\n\t\t\treturn {\n\t\t\t\tdir: templateDir,\n\t\t\t\tremoteName: \"ourRemote\",\n\t\t\t};\n\t\t};\n\t});\n\tafterEach(async () => {\n\t\tawait rm(tmpDir, {\n\t\t\tforce: true,\n\t\t\trecursive: true,\n\t\t});\n\t});\n\t// Note: for this test, we expect actions and users to handle misconfigured template syncs\n\tit.each([\n\t\t[\n\t\t\t\"local\",\n\t\t\t`templatesync.local.json plugin option errors:\n\\tPlugin (plugins/fail-validate-plugin.js):\n\\t\\toh no!\n\\t\\tnot this one too!\n`,\n\t\t],\n\t\t[\n\t\t\t\"template\",\n\t\t\t`templatesync.json plugin option errors:\n\\tPlugin (dummy-fail-plugin.js):\n\\t\\tshucks\n\\t\\tno good\n`,\n\t\t],\n\t\t[\n\t\t\t\"both\",\n\t\t\t`templatesync.json plugin option errors:\n\\tPlugin (dummy-fail-plugin.js):\n\\t\\tshucks\n\\t\\tno good\ntemplatesync.local.json plugin option errors:\n\\tPlugin (plugins/fail-validate-plugin.js):\n\\t\\toh no!\n\\t\\tnot this one too!\n`,\n\t\t],\n\t])(\"throws errors from plugin validation\", async (mode, expected) => {\n\t\t// Remove the local sync overrides\n\t\tawait rm(join(tmpDir, \"templatesync.local.json\"));\n\n\t\tif (mode === \"local\" || mode == \"both\") {\n\t\t\twriteFileSync(\n\t\t\t\tjoin(tmpDir, \"templatesync.local.json\"),\n\t\t\t\tJSON.stringify({\n\t\t\t\t\tignore: [\n\t\t\t\t\t\t// Ignores the templated.ts\n\t\t\t\t\t\t\"**/*.ts\",\n\t\t\t\t\t\t// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins\n\t\t\t\t\t\t\"plugins/**\",\n\t\t\t\t\t],\n\t\t\t\t\tmerge: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tglob: \"package.json\",\n\t\t\t\t\t\t\tplugin: \"plugins/fail-validate-plugin.js\",\n\t\t\t\t\t\t\toptions: {},\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\t\tif (mode === \"template\" || mode === \"both\") {\n\t\t\twriteFileSync(\n\t\t\t\tjoin(templateDir, \"templatesync.json\"),\n\t\t\t\tJSON.stringify({\n\t\t\t\t\tignore: [\n\t\t\t\t\t\t// Ignores the templated.ts\n\t\t\t\t\t\t\"**/*.ts\",\n\t\t\t\t\t\t// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins\n\t\t\t\t\t\t\"plugins/**\",\n\t\t\t\t\t],\n\t\t\t\t\tmerge: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tglob: \"package.json\",\n\t\t\t\t\t\t\tplugin: \"dummy-fail-plugin.js\",\n\t\t\t\t\t\t\toptions: {},\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\tawait expect(\n\t\t\tasync () =>\n\t\t\t\tawait templateSync({\n\t\t\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\t\t\trepoUrl: \"not-important\",\n\t\t\t\t\trepoDir: tmpDir,\n\t\t\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t\t\t\tcurrentRefDriver: dummyCurrentRefDriver,\n\t\t\t\t}),\n\t\t).rejects.toThrow(expected);\n\t});\n\tit(\"appropriately merges according to just the templatesync config file into an empty dir\", async () => {\n\t\tconst emptyTmpDir = await mkdtemp(tempDir());\n\t\texpect(\n\t\t\tawait templateSync({\n\t\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\t\trepoUrl: \"not-important\",\n\t\t\t\trepoDir: emptyTmpDir,\n\t\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t\t\tcurrentRefDriver: dummyCurrentRefDriver,\n\t\t\t}),\n\t\t).toEqual({\n\t\t\t// Expect no changes since there was no local sync file\n\t\t\tlocalSkipFiles: [],\n\t\t\tlocalFileChanges: {},\n\t\t\tmodifiedFiles: {\n\t\t\t\tadded: [\n\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\"src/index.js\",\n\t\t\t\t\t\"src/templated.js\",\n\t\t\t\t\t\"src/templated.ts\",\n\t\t\t\t\t\"templatesync.json\",\n\t\t\t\t],\n\t\t\t\tdeleted: [],\n\t\t\t\tmodified: [],\n\t\t\t\ttotal: 5,\n\t\t\t},\n\t\t});\n\n\t\t// Verify the files\n\t\tawait fileMatchTemplate(emptyTmpDir, \"templatesync.json\");\n\t\tawait fileMatchTemplate(emptyTmpDir, \"package.json\");\n\t\tawait fileMatchTemplate(emptyTmpDir, \"src/templated.ts\");\n\n\t\t// Expect the ignores to not be a problem\n\t\texpect(existsSync(resolve(emptyTmpDir, \"src/index.ts\"))).toBeFalsy();\n\t\texpect(existsSync(resolve(emptyTmpDir, \"src/custom-bin\"))).toBeFalsy();\n\n\t\texpect(dummyCheckoutDriver).not.toHaveBeenCalled();\n\t});\n\tit(\"Checks out the branch and then appropriately merges\", async () => {\n\t\tconst emptyTmpDir = await mkdtemp(tempDir());\n\t\texpect(\n\t\t\tawait templateSync({\n\t\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\t\trepoUrl: \"not-important\",\n\t\t\t\trepoDir: emptyTmpDir,\n\t\t\t\tbranch: \"new-template-test\",\n\t\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t\t\tcurrentRefDriver: dummyCurrentRefDriver,\n\t\t\t}),\n\t\t).toEqual({\n\t\t\t// Expect no changes since there was no local sync file\n\t\t\tlocalSkipFiles: [],\n\t\t\tlocalFileChanges: {},\n\t\t\tmodifiedFiles: {\n\t\t\t\tadded: [\n\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\"src/index.js\",\n\t\t\t\t\t\"src/templated.js\",\n\t\t\t\t\t\"src/templated.ts\",\n\t\t\t\t\t\"templatesync.json\",\n\t\t\t\t],\n\t\t\t\tdeleted: [],\n\t\t\t\tmodified: [],\n\t\t\t\ttotal: 5,\n\t\t\t},\n\t\t});\n\n\t\t// Verify the files\n\t\tawait fileMatchTemplate(emptyTmpDir, \"templatesync.json\");\n\t\tawait fileMatchTemplate(emptyTmpDir, \"package.json\");\n\t\tawait fileMatchTemplate(emptyTmpDir, \"src/templated.ts\");\n\n\t\t// Expect the ignores to not be a problem\n\t\texpect(existsSync(resolve(emptyTmpDir, \"src/index.ts\"))).toBeFalsy();\n\t\texpect(existsSync(resolve(emptyTmpDir, \"src/custom-bin\"))).toBeFalsy();\n\t\tconst cloneInfo = await dummyCloneDriver();\n\t\texpect(dummyCheckoutDriver).toHaveBeenCalledWith({\n\t\t\ttmpDir: cloneInfo.dir,\n\t\t\tremoteName: cloneInfo.remoteName,\n\t\t\tbranch: \"new-template-test\",\n\t\t});\n\t});\n\tit(\"appropriately merges according to just the templatesync config file in an existing repo\", async () => {\n\t\t// Remove the local sync overrides\n\t\tawait rm(join(tmpDir, \"templatesync.local.json\"));\n\n\t\tconst result = await templateSync({\n\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\trepoUrl: \"not-important\",\n\t\t\trepoDir: tmpDir,\n\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t\tcurrentRefDriver: dummyCurrentRefDriver,\n\t\t});\n\n\t\texpect(result.localSkipFiles).toEqual([]);\n\t\texpect(result.localFileChanges).toEqual({});\n\n\t\t// Verify the files\n\t\tawait fileMatchTemplate(tmpDir, \"templatesync.json\");\n\t\tawait fileMatchTemplate(tmpDir, \"src/templated.ts\");\n\t\tconst packageJson = JSON.parse(\n\t\t\treadFileSync(resolve(tmpDir, \"package.json\")).toString(),\n\t\t);\n\n\t\texpect(packageJson).toEqual({\n\t\t\tname: \"mypkg\",\n\t\t\tdescription: \"my description\",\n\t\t\tdependencies: {\n\t\t\t\tmypackage: \"^1.2.0\",\n\t\t\t\tnewpacakge: \"^22.2.2\",\n\t\t\t\tpackage2: \"3.22.1\",\n\t\t\t\thuh: \"~1.0.0\",\n\t\t\t},\n\t\t\tengines: {\n\t\t\t\tnode: \">=15\",\n\t\t\t},\n\t\t\tscripts: {\n\t\t\t\tbuild: \"build\",\n\t\t\t\ttest: \"jest\",\n\t\t\t\tmyscript: \"somescript\",\n\t\t\t},\n\t\t\t// By default we add new top-level fields\n\t\t\tversion: \"new-version\",\n\t\t});\n\n\t\t// Expect the ignores to not be a problem\n\t\tawait fileMatchDownstream(tmpDir, \"src/index.ts\");\n\t\tawait fileMatchDownstream(tmpDir, \"plugins/custom-plugin.js\");\n\t\texpect(dummyCheckoutDriver).not.toHaveBeenCalled();\n\t});\n\tit(\"appropriately merges according to the templatesync config file and the local config in an existing repo\", async () => {\n\t\t// Remove the local sync overrides\n\t\tawait rm(join(tmpDir, \"templatesync.local.json\"));\n\n\t\twriteFileSync(\n\t\t\tjoin(tmpDir, \"templatesync.local.json\"),\n\t\t\tJSON.stringify({\n\t\t\t\tignore: [\n\t\t\t\t\t// Ignores the templated.ts\n\t\t\t\t\t\"**/*.ts\",\n\t\t\t\t\t// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins\n\t\t\t\t\t\"plugins/**\",\n\t\t\t\t],\n\t\t\t\tmerge: [\n\t\t\t\t\t{\n\t\t\t\t\t\tglob: \"package.json\",\n\t\t\t\t\t\tplugin: \"plugins/custom-plugin.js\",\n\t\t\t\t\t\toptions: {},\n\t\t\t\t\t},\n\t\t\t\t],\n\t\t\t}),\n\t\t);\n\n\t\tconst result = await templateSync({\n\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\trepoUrl: \"not-important\",\n\t\t\trepoDir: tmpDir,\n\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t\tcurrentRefDriver: dummyCurrentRefDriver,\n\t\t});\n\n\t\texpect(result.localSkipFiles).toEqual([\"src/templated.ts\"]);\n\t\t// TODO: more rigorous testing around diff changes\n\t\texpect(result.localFileChanges).toEqual(\n\t\t\texpect.objectContaining({\n\t\t\t\t\"package.json\": expect.arrayContaining([]),\n\t\t\t}),\n\t\t);\n\t\t// Make sure the result captures the changes\n\t\texpect(result.modifiedFiles).toEqual({\n\t\t\tadded: [\n\t\t\t\t\"package.json\",\n\t\t\t\t\"src/index.js\",\n\t\t\t\t\"src/templated.js\",\n\t\t\t\t\"templatesync.json\",\n\t\t\t],\n\t\t\tdeleted: [],\n\t\t\tmodified: [],\n\t\t\ttotal: 4,\n\t\t});\n\n\t\t// Verify the files\n\t\tawait fileMatchTemplate(tmpDir, \"templatesync.json\");\n\t\tawait fileMatchDownstream(tmpDir, \"src/templated.ts\");\n\t\tconst packageJson = JSON.parse(\n\t\t\treadFileSync(resolve(tmpDir, \"package.json\")).toString(),\n\t\t);\n\n\t\t// The plugin nuked this\n\t\texpect(packageJson).toEqual({\n\t\t\tdownstream: true,\n\t\t});\n\n\t\t// Expect the ignores to not be a problem\n\t\tawait fileMatchDownstream(tmpDir, \"src/index.ts\");\n\t\tawait fileMatchDownstream(tmpDir, \"plugins/custom-plugin.js\");\n\t\texpect(dummyCheckoutDriver).not.toHaveBeenCalled();\n\t});\n\tit(\"appropriately merges according to the templatesync config file and the local config in an existing repo with afterRef\", async () => {\n\t\t// Remove the local sync overrides\n\t\tawait rm(join(tmpDir, \"templatesync.local.json\"));\n\n\t\twriteFileSync(\n\t\t\tjoin(tmpDir, \"templatesync.local.json\"),\n\t\t\tJSON.stringify({\n\t\t\t\tafterRef: \"dummySha\",\n\t\t\t\tignore: [\n\t\t\t\t\t// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins\n\t\t\t\t\t\"plugins/**\",\n\t\t\t\t],\n\t\t\t}),\n\t\t);\n\n\t\t// We will only update the templated.ts\n\t\tconst mockDiffDriver = jest.fn().mockImplementation(async () => ({\n\t\t\tadded: [\"src/templated.ts\"],\n\t\t\tmodified: [],\n\t\t\tdeleted: [],\n\t\t}));\n\t\tconst result = await templateSync({\n\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\trepoUrl: \"not-important\",\n\t\t\trepoDir: tmpDir,\n\t\t\tdiffDriver: mockDiffDriver,\n\t\t\tcurrentRefDriver: dummyCurrentRefDriver,\n\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t});\n\n\t\t// since there was no override for this file, not changes from the local file\n\t\texpect(result.localFileChanges).toEqual(expect.objectContaining({}));\n\n\t\t// Verify the files\n\t\tawait fileMatchTemplate(tmpDir, \"templatesync.json\");\n\t\tawait fileMatchTemplate(tmpDir, \"src/templated.ts\");\n\n\t\t// Expect the none of the diff files to work\n\t\tawait fileMatchDownstream(tmpDir, \"src/index.ts\");\n\t\tawait fileMatchDownstream(tmpDir, \"plugins/custom-plugin.js\");\n\t\tawait fileMatchDownstream(tmpDir, \"package.json\");\n\t\texpect(dummyCheckoutDriver).not.toHaveBeenCalled();\n\t});\n\tit(\"updates the local templatesync with the current ref if updateAfterRef is true\", async () => {\n\t\t// Remove the local sync overrides\n\t\tawait rm(join(tmpDir, \"templatesync.local.json\"));\n\n\t\tconst mockLocalConfig = {\n\t\t\tafterRef: \"dummySha\",\n\t\t\tignore: [\n\t\t\t\t// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins\n\t\t\t\t\"plugins/**\",\n\t\t\t],\n\t\t};\n\n\t\twriteFileSync(\n\t\t\tjoin(tmpDir, \"templatesync.local.json\"),\n\t\t\tJSON.stringify(mockLocalConfig),\n\t\t);\n\n\t\t// We will only update the templated.ts\n\t\tconst mockDiffDriver = jest.fn().mockImplementation(async () => ({\n\t\t\tadded: [\"src/templated.ts\"],\n\t\t\tmodified: [\"src/index.ts\"], // Add index.ts so we make sure it is still ignored - see test-fixtures/template/templatesync.json ignores\n\t\t\tdeleted: [],\n\t\t}));\n\t\tconst mockCurrentRefDriver = jest\n\t\t\t.fn()\n\t\t\t.mockImplementation(async () => \"newestSha\");\n\t\tconst result = await templateSync({\n\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\trepoUrl: \"not-important\",\n\t\t\trepoDir: tmpDir,\n\t\t\tupdateAfterRef: true,\n\t\t\tdiffDriver: mockDiffDriver,\n\t\t\tcurrentRefDriver: mockCurrentRefDriver,\n\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t});\n\n\t\t// since there was no override for this file, no changes from the local file\n\t\texpect(result.localFileChanges).toEqual(expect.objectContaining({}));\n\t\texpect(result.modifiedFiles).toEqual({\n\t\t\tadded: [\"src/templated.ts\"],\n\t\t\tmodified: [\"templatesync.local.json\"], // Add index.ts so we make sure it is still ignored - due to a bug\n\t\t\tdeleted: [],\n\t\t\ttotal: 2,\n\t\t});\n\n\t\t// Verify the files\n\t\tawait fileMatchTemplate(tmpDir, \"templatesync.json\");\n\t\tawait fileMatchTemplate(tmpDir, \"src/templated.ts\");\n\n\t\t// Expect the none of the diff files to work\n\t\tawait fileMatchDownstream(tmpDir, \"src/index.ts\");\n\t\tawait fileMatchDownstream(tmpDir, \"plugins/custom-plugin.js\");\n\t\tawait fileMatchDownstream(tmpDir, \"package.json\");\n\n\t\t// Ensure we have updated the local template field\n\t\texpect(\n\t\t\tJSON.parse(\n\t\t\t\t(await readFile(join(tmpDir, \"templatesync.local.json\"))).toString(),\n\t\t\t),\n\t\t).toEqual({\n\t\t\t...mockLocalConfig,\n\t\t\tafterRef: \"newestSha\",\n\t\t});\n\t\texpect(dummyCheckoutDriver).not.toHaveBeenCalled();\n\t});\n\tit(\"Does not update the local templatesync if updateAfterRef is true and the ref is the same\", async () => {\n\t\t// Remove the local sync overrides\n\t\tawait rm(join(tmpDir, \"templatesync.local.json\"));\n\n\t\tconst mockLocalConfig = {\n\t\t\tafterRef: \"dummySha\",\n\t\t\tignore: [\n\t\t\t\t// We don't have a need for this in here, but it's an example of keeping things cleaner for our custom plugins\n\t\t\t\t\"plugins/**\",\n\t\t\t],\n\t\t};\n\n\t\twriteFileSync(\n\t\t\tjoin(tmpDir, \"templatesync.local.json\"),\n\t\t\tJSON.stringify(mockLocalConfig),\n\t\t);\n\n\t\t// We will only update the templated.ts\n\t\tconst mockDiffDriver = jest.fn().mockImplementation(async () => ({\n\t\t\tadded: [\"src/templated.ts\"],\n\t\t\tmodified: [\"src/index.ts\"], // Add index.ts so we make sure it is still ignored - see test-fixtures/template/templatesync.json ignores\n\t\t\tdeleted: [],\n\t\t}));\n\t\tconst mockCurrentRefDriver = jest\n\t\t\t.fn()\n\t\t\t.mockImplementation(async () => \"dummySha\");\n\t\tconst result = await templateSync({\n\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\trepoUrl: \"not-important\",\n\t\t\trepoDir: tmpDir,\n\t\t\tupdateAfterRef: true,\n\t\t\tdiffDriver: mockDiffDriver,\n\t\t\tcurrentRefDriver: mockCurrentRefDriver,\n\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t});\n\n\t\t// Nothing shoudl be reported as changing\n\t\texpect(result).toEqual({\n\t\t\tlocalFileChanges: {},\n\t\t\tlocalSkipFiles: [],\n\t\t\tmodifiedFiles: {\n\t\t\t\tadded: [],\n\t\t\t\tmodified: [],\n\t\t\t\tdeleted: [],\n\t\t\t\ttotal: 0,\n\t\t\t},\n\t\t});\n\t\t// Verify the files\n\t\tawait fileMatchDownstream(tmpDir, \"templatesync.json\");\n\t\tawait fileMatchDownstream(tmpDir, \"src/templated.ts\");\n\n\t\t// Expect the none of the diff files to work\n\t\tawait fileMatchDownstream(tmpDir, \"src/index.ts\");\n\t\tawait fileMatchDownstream(tmpDir, \"plugins/custom-plugin.js\");\n\t\tawait fileMatchDownstream(tmpDir, \"package.json\");\n\n\t\t// Ensure we have updated the local template field\n\t\texpect(\n\t\t\tJSON.parse(\n\t\t\t\t(await readFile(join(tmpDir, \"templatesync.local.json\"))).toString(),\n\t\t\t),\n\t\t).toEqual({\n\t\t\t...mockLocalConfig,\n\t\t});\n\t\texpect(dummyCheckoutDriver).not.toHaveBeenCalled();\n\t});\n\tit(\"creates the local templatesync with the current ref if updateAfterRef is true and no local template exists\", async () => {\n\t\t// Remove the local sync overrides\n\t\tawait rm(join(tmpDir, \"templatesync.local.json\"));\n\n\t\t// We will only update the templated.ts\n\t\tconst mockDiffDriver = jest.fn().mockImplementation(async () => ({\n\t\t\tadded: [\"src/templated.ts\"],\n\t\t}));\n\t\tconst mockCurrentRefDriver = jest\n\t\t\t.fn()\n\t\t\t.mockImplementation(async () => \"newestSha\");\n\t\tconst result = await templateSync({\n\t\t\ttmpCloneDir: \"stubbed-by-driver\",\n\t\t\tcloneDriver: dummyCloneDriver,\n\t\t\trepoUrl: \"not-important\",\n\t\t\trepoDir: tmpDir,\n\t\t\tupdateAfterRef: true,\n\t\t\tdiffDriver: mockDiffDriver,\n\t\t\tcurrentRefDriver: mockCurrentRefDriver,\n\t\t\tcheckoutDriver: dummyCheckoutDriver,\n\t\t});\n\n\t\t// since there was no override for this file, no changes from the local file\n\t\texpect(result.localFileChanges).toEqual(expect.objectContaining({}));\n\t\texpect(result.modifiedFiles).toEqual({\n\t\t\tadded: [\n\t\t\t\t\"package.json\",\n\t\t\t\t\"src/index.js\",\n\t\t\t\t\"src/templated.js\",\n\t\t\t\t\"src/templated.ts\",\n\t\t\t\t\"templatesync.json\",\n\t\t\t\t\"templatesync.local.json\",\n\t\t\t],\n\t\t\tdeleted: [],\n\t\t\tmodified: [],\n\t\t\ttotal: 6,\n\t\t});\n\n\t\t// Verify the files\n\t\tawait fileMatchTemplate(tmpDir, \"templatesync.json\");\n\t\tawait fileMatchTemplate(tmpDir, \"src/templated.ts\");\n\t\tconst packageJson = JSON.parse(\n\t\t\treadFileSync(resolve(tmpDir, \"package.json\")).toString(),\n\t\t);\n\n\t\texpect(packageJson).toEqual({\n\t\t\tname: \"mypkg\",\n\t\t\tdescription: \"my description\",\n\t\t\tdependencies: {\n\t\t\t\tmypackage: \"^1.2.0\",\n\t\t\t\tnewpacakge: \"^22.2.2\",\n\t\t\t\tpackage2: \"3.22.1\",\n\t\t\t\thuh: \"~1.0.0\",\n\t\t\t},\n\t\t\tengines: {\n\t\t\t\tnode: \">=15\",\n\t\t\t},\n\t\t\tscripts: {\n\t\t\t\tbuild: \"build\",\n\t\t\t\ttest: \"jest\",\n\t\t\t\tmyscript: \"somescript\",\n\t\t\t},\n\t\t\t// By default we add new top-level fields\n\t\t\tversion: \"new-version\",\n\t\t});\n\n\t\t// Expect the none of the diff files to work\n\t\tawait fileMatchDownstream(tmpDir, \"src/index.ts\");\n\t\tawait fileMatchDownstream(tmpDir, \"plugins/custom-plugin.js\");\n\n\t\t// Ensure we have updated the local template field\n\t\texpect(\n\t\t\tJSON.parse(\n\t\t\t\t(await readFile(join(tmpDir, \"templatesync.local.json\"))).toString(),\n\t\t\t),\n\t\t).toEqual({\n\t\t\tafterRef: \"newestSha\",\n\t\t});\n\t});\n\t// helper\n\tasync function fileMatchTemplate(_tmpDir: string, relPath: string) {\n\t\treturn fileMatch(_tmpDir, relPath, \"template\");\n\t}\n\n\tasync function fileMatchDownstream(_tmpDir: string, relPath: string) {\n\t\treturn fileMatch(_tmpDir, relPath, \"downstream\");\n\t}\n\n\tasync function fileMatch(\n\t\t_tmpDir: string,\n\t\trelPath: string,\n\t\tsource: \"downstream\" | \"template\",\n\t) {\n\t\tconst dir =\n\t\t\tsource === \"downstream\" ? downstreamDir : (await dummyCloneDriver()).dir;\n\t\texpect((await readFile(resolve(_tmpDir, relPath))).toString()).toEqual(\n\t\t\t(await readFile(resolve(dir, relPath))).toString(),\n\t\t);\n\t}\n});\n"],"names":["existsSync","readFileSync","writeFileSync","mkdtemp","readFile","rm","copy","join","resolve","templateSync","TEST_FIXTURES_DIR","tempDir","dummyCheckoutDriver","jest","fn","dummyCurrentRefDriver","downstreamDir","describe","tmpDir","templateDir","dummyCloneDriver","beforeEach","resetAllMocks","dir","remoteName","afterEach","force","recursive","it","each","mode","expected","JSON","stringify","ignore","merge","glob","plugin","options","expect","tmpCloneDir","cloneDriver","repoUrl","repoDir","checkoutDriver","currentRefDriver","rejects","toThrow","emptyTmpDir","toEqual","localSkipFiles","localFileChanges","modifiedFiles","added","deleted","modified","total","fileMatchTemplate","toBeFalsy","not","toHaveBeenCalled","branch","cloneInfo","toHaveBeenCalledWith","result","packageJson","parse","toString","name","description","dependencies","mypackage","newpacakge","package2","huh","engines","node","scripts","build","test","myscript","version","fileMatchDownstream","objectContaining","arrayContaining","downstream","afterRef","mockDiffDriver","mockImplementation","diffDriver","mockLocalConfig","mockCurrentRefDriver","updateAfterRef","_tmpDir","relPath","fileMatch","source"],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { tmpdir } from "os";
|
|
2
|
+
import { resolve, dirname as __swc_shim_dirname } from "path";
|
|
3
|
+
import { fileURLToPath as __swc_shim_fileURLToPath } from "url";
|
|
4
|
+
const __dirname = __swc_shim_dirname(__swc_shim_fileURLToPath(import.meta.url));
|
|
5
|
+
export const TEST_FIXTURES_DIR = resolve(__dirname, "..", "..", "test-fixtures");
|
|
6
|
+
export function tempDir() {
|
|
7
|
+
return process.env.RUNNER_TEMP ?? tmpdir();
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90ZXN0LXV0aWxzL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHRtcGRpciB9IGZyb20gXCJvc1wiO1xuaW1wb3J0IHsgcmVzb2x2ZSB9IGZyb20gXCJwYXRoXCI7XG5cbmV4cG9ydCBjb25zdCBURVNUX0ZJWFRVUkVTX0RJUiA9IHJlc29sdmUoXG5cdF9fZGlybmFtZSxcblx0XCIuLlwiLFxuXHRcIi4uXCIsXG5cdFwidGVzdC1maXh0dXJlc1wiLFxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIHRlbXBEaXIoKTogc3RyaW5nIHtcblx0cmV0dXJuIHByb2Nlc3MuZW52LlJVTk5FUl9URU1QID8/IHRtcGRpcigpO1xufVxuIl0sIm5hbWVzIjpbInRtcGRpciIsInJlc29sdmUiLCJURVNUX0ZJWFRVUkVTX0RJUiIsIl9fZGlybmFtZSIsInRlbXBEaXIiLCJwcm9jZXNzIiwiZW52IiwiUlVOTkVSX1RFTVAiXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLE1BQU0sUUFBUSxLQUFLO0FBQzVCLFNBQVNDLE9BQU8sdUNBQVEsT0FBTzs7O0FBRS9CLE9BQU8sTUFBTUMsb0JBQW9CRCxRQUNoQ0UsV0FDQSxNQUNBLE1BQ0EsaUJBQ0M7QUFFRixPQUFPLFNBQVNDO0lBQ2YsT0FBT0MsUUFBUUMsR0FBRyxDQUFDQyxXQUFXLElBQUlQO0FBQ25DIn0=
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* How we want to merge json
|
|
3
|
+
*
|
|
4
|
+
* overwrite - the template sync overwrites completely
|
|
5
|
+
* merge-template - we merge template into the current json with overrides on matching values happening from the template
|
|
6
|
+
* merge-current - we merge the current json into the template json with overrides on matching values happening from the current json
|
|
7
|
+
*/ export { };
|
|
8
|
+
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEhvdyB3ZSB3YW50IHRvIG1lcmdlIGpzb25cbiAqXG4gKiBvdmVyd3JpdGUgLSB0aGUgdGVtcGxhdGUgc3luYyBvdmVyd3JpdGVzIGNvbXBsZXRlbHlcbiAqIG1lcmdlLXRlbXBsYXRlIC0gd2UgbWVyZ2UgdGVtcGxhdGUgaW50byB0aGUgY3VycmVudCBqc29uIHdpdGggb3ZlcnJpZGVzIG9uIG1hdGNoaW5nIHZhbHVlcyBoYXBwZW5pbmcgZnJvbSB0aGUgdGVtcGxhdGVcbiAqIG1lcmdlLWN1cnJlbnQgLSB3ZSBtZXJnZSB0aGUgY3VycmVudCBqc29uIGludG8gdGhlIHRlbXBsYXRlIGpzb24gd2l0aCBvdmVycmlkZXMgb24gbWF0Y2hpbmcgdmFsdWVzIGhhcHBlbmluZyBmcm9tIHRoZSBjdXJyZW50IGpzb25cbiAqL1xuZXhwb3J0IHR5cGUgQmFzZUpzb25NZXJnZU9wdGlvbnMgPVxuXHR8IFwib3ZlcndyaXRlXCJcblx0fCBcIm1lcmdlLXRlbXBsYXRlXCJcblx0fCBcIm1lcmdlLWN1cnJlbnRcIjtcbmV4cG9ydCBpbnRlcmZhY2UgSnNvblBhdGhPdmVycmlkZXMge1xuXHQvKipcblx0ICogSWYgc2V0IHRvIHRydWUsIHRoaXMgbWVhbnMgd2Ugd29uJ3QgYWRkIG5ldyBwcm9wZXJ0aWVzIGZyb20gdGhlIHRlbXBsYXRlXG5cdCAqL1xuXHRpZ25vcmVOZXdQcm9wZXJ0aWVzPzogYm9vbGVhbjtcblx0LyoqXG5cdCAqIElmIHNldCB0byB0cnVlLCBvdmVyd3JpdGUgd2lsbCBhcHBseSB1bmRlZmluZWQgdmFsdWVzIGFzIGRlbGV0ZWQgZm9yIHRoZSBqc29ucGF0aHNcblx0ICogb3IgZm9yIHZhbHVlcyB0aGF0IGFyZSBzdXBwb3NlZCB0byBiZSBtZXJnZWQgb24gdG9wIG9mIG90aGVyIHZhbHVlc1xuXHQgKi9cblx0bWlzc2luZ0lzRGVsZXRlPzogYm9vbGVhbjtcblx0LyoqXG5cdCAqIE5vdGUsIGlmIG11bHRpcGxlIGpzb24gcGF0aHMgbWF0Y2ggYSBydWxlLCB3ZSBwaWNrIHRoZSBmaXJzdCBvbmUgaW4gdGhlIGxpc3QgdGhhdCBtYXRjaGVzXG5cdCAqL1xuXHRwYXRoczogLyoqXG5cdCAqIFdlIG9ubHkgb3ZlcnJpZGUganNvbnBhdGhzLiAgQW55dGhpbmcgbm90IHNwZWNpZmllZCBpcyBrZXB0IHRoZSBzYW1lLlxuXHQgKi9cblx0W2pzb25QYXRoOiBgJC4ke3N0cmluZ31gLCBvcHRpb25zOiBCYXNlSnNvbk1lcmdlT3B0aW9uc11bXTtcbn1cbmV4cG9ydCB0eXBlIEpzb25GaWxlTWVyZ2VPcHRpb25zID0gQmFzZUpzb25NZXJnZU9wdGlvbnMgfCBKc29uUGF0aE92ZXJyaWRlcztcblxuLy8gU3VtIG9mIGFsbCBiYXNpYyBmaWxlIG1lcmdlIG9wdGlvbnNcbnR5cGUgTWVyZ2VQbHVnaW5PcHRpb25zID0gSnNvbkZpbGVNZXJnZU9wdGlvbnM7XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBvYmplY3QgZm9yIGEgZ2l2ZW4gZmlsZSB0eXBlIG1lcmdlIGNvbmZpZ3VyYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNZXJnZUNvbmZpZzxUPiB7XG5cdC8qKlxuXHQgKiBBIGdsb2Igb3IgYXJyYXkgb2YgZ2xvYnMgKHVzaW5nIG1pY3JvbWF0Y2ggc3ludGF4KSB0aGF0IHNlbGVjdHMgdGhlIGZpbGVzIHRoYXQgdGhpcyBhcHBsaWVzIHRvXG5cdCAqIHdoZW4gbWVyZ2luZ1xuXHQgKi9cblx0Z2xvYjogc3RyaW5nIHwgc3RyaW5nW107XG5cdC8qKlxuXHQgKiBUaGUgbm9kZSBtb2R1bGUsIGF2YWlsYWJsZSBvbiB0aGUgY2FsbGluZyBub2RlIGNvbnRleHQsIHRoYXQgeW91IHdhbnQgdG8gcnVuLlxuXHQgKiBCdWlsdC1pbiBwbHVnaW5zIGNhbiBiZSBzcGVjaWZpZWQgdmlhIHRoZWlyIGJ1aWx0LWluIG5hbWUgKHNlZSBkb2N1bWVudGF0aW9uKTpcblx0ICpcblx0ICogRXhhbXBsZTogX2pzb25cblx0ICovXG5cdHBsdWdpbjogc3RyaW5nO1xuXHQvKipcblx0ICogQW4gYXJyYXkgb2YgZmlyc3QgbWF0Y2ggZmlsZSBnbG9icyB0aGF0IHdpbGwgdGhlbiBjYWxsIHRoZSBwbHVnaW4gd2l0aCB0aGUgYXBwcm9wcmlhdGUgb3B0aW9uc1xuXHQgKi9cblx0b3B0aW9uczogTWVyZ2VQbHVnaW5PcHRpb25zIHwgVDtcbn1cblxuLyoqXG4gKiBUaGUgc2hhcGUgb2YgYSB0ZW1wbGF0ZSBzeW5jIGNvbmZpZyBmaWxlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29uZmlnPFQgPSB1bmtub3duPiB7XG5cdGlnbm9yZTogc3RyaW5nW107XG5cdC8qKlxuXHQgKiBJZiB0aGVyZSBpcyBubyBtZXJnZSBjb25maWcsIHRoZW4gd2Ugd2lsbCBhbHdheXMganVzdCBvdmVyd3JpdGUgdGhlIGZpbGUgZm9yIHRoZSBkaWZmXG5cdCAqL1xuXHRtZXJnZT86IE1lcmdlQ29uZmlnPFQ+W107XG59XG5cbi8qKlxuICogVGhlIHNoYXBlIG9mIGEgbG9jYWwgdGVtcGxhdGUgc3luYyBjb25maWcgZmlsZSB0aGF0IG92ZXJyaWRlcyB0aGUgcm9vdCB0ZW1wbGF0ZSByZXBvXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTG9jYWxDb25maWc8VCA9IHVua25vd24+IHtcblx0LyoqXG5cdCAqIFRoaXMgaXMgdGhlIHJlZiB0aGF0IHdlIGNvbXBhcmUgYWdhaW5zdC4gIElmIGVtcHR5LCB3ZSB1c2UgYWxsIGZpbGVzIHRoYXQgaGF2ZSBjaGFuZ2VkIHNpbmNlIHRoZVxuXHQgKiBiZWdpbm5pbmcgb2YgdGhlIHRlbXBsYXRlIHJlcG8uXG5cdCAqL1xuXHRhZnRlclJlZj86IHN0cmluZztcblxuXHRpZ25vcmU6IHN0cmluZ1tdO1xuXHQvKipcblx0ICogSWYgdGhlcmUgaXMgbm8gbWVyZ2UgY29uZmlnLCB0aGVuIHdlIHdpbGwgYWx3YXlzIGp1c3Qgb3ZlcndyaXRlIHRoZSBmaWxlIGZvciB0aGUgZGlmZlxuXHQgKi9cblx0bWVyZ2U/OiBNZXJnZUNvbmZpZzxUPltdO1xufVxuXG4vKipcbiAqIEluZm9ybWF0aW9uIGFyb3VuZCB0aGUgZmlsZSB3ZSBhcmUgdHJ5aW5nIHRvIG1lcmdlIGFuZCB0aGF0IGFyZ3VtZW50cyBmb3IgdGhhdCBtZXJnZVxuICogZnJvbSBtYXRjaGluZyBhIG1lcmdlIGNvbmZpZ3VyYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNZXJnZUNvbnRleHQ8UGx1Z2luT3B0aW9ucyA9IHVua25vd24+IHtcblx0cmVsRmlsZVBhdGg6IHN0cmluZztcblx0LyoqXG5cdCAqIElmIHlvdSBoYXZlIHByb3ZpZGVkIGEgY3VzdG9tIG1lcmdlIHBsdWdpbiwgdGhpcyB3aWxsIGJlIHRoZSBcIm9wdGlvbnNcIiBzZWN0aW9uIG9mXG5cdCAqIHRoZSBtYXRjaGluZyBnbG9iXG5cdCAqL1xuXHRtZXJnZUFyZ3VtZW50czogUGx1Z2luT3B0aW9ucztcblx0LyoqXG5cdCAqIElmIHRoaXMgcnVuIGlzIGZvciB0aGUgbG9jYWwgY29uZmlnLiAgS2VlcCBpbiBtaW5kIHRoYXQgYW55IGxvY2FsIGNvbmZpZyBvdmVycmlkZXMgd2lsbFxuXHQgKiBiZSBydW4gYWZ0ZXIgdGhlIHRlbXBsYXRlIHN5bmMgb3B0aW9ucyBhbmQgd2Ugd291bGQgbGlrZSB0byByZXBvcnQgYW55IGNoYW5nZXMgdGhhdFxuXHQgKiBhcmUgZG9uZVxuXHQgKi9cblx0aXNMb2NhbE9wdGlvbnM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1lcmdlUGx1Z2luPFBsdWdpbk9wdGlvbnM+IHtcblx0LyoqXG5cdCAqIFRoaXMgbWV0aG9kIHdpbGwgYmUgY2FsbGVkIHdoZW4gYSBmaWxlIGZyb20gdGhlIHRlbXBsYXRlIGFuZCBpdCdzIGFuYWxvZyBpbiB0aGUgZG93bnN0cmVhbSByZXBvXG5cdCAqIGhhdmUgc29tZSBkaWZmZXJlbmNlcy4gIFRoZSBwbHVnaW4gbXVzdCBwZXJmb3JtIHRoZSBtZXJnZSBhbmQgcmV0dXJuIHRoZSBhcHByb3ByaWF0ZSBmaWxlIGNvbnRlbnRzXG5cdCAqIGFzIGEgc3RyaW5nXG5cdCAqXG5cdCAqIFRPRE86IHdlIG1heSBjcmVhdGUgYSBWMiBwbHVnaW4gdGhhdCBjb3VsZCBkZWFsIHdpdGggbGFyZ2UgZmlsZXMgYW5kIG5vdCBwYXNzIGFyb3VuZCBzdHJpbmdzIGluIG1lbW9yeSxcblx0ICogYnV0IGZvciBub3csIHRoaXMgaXMgdGhlIGN1cnJlbnQgaW1wbGVtZW50YXRpb25cblx0ICpcblx0ICogQHBhcmFtIGN1cnJlbnQgLSBUaGUgZG93bnN0cmVhbSByZXBvcyBjdXJyZW50IGZpbGUgY29udGVudHNcblx0ICogQHBhcmFtIGZyb21UZW1wbGF0ZVJlcG8gLSB0aGUgY3VycmVudFxuXHQgKiBAcGFyYW0gY29udGV4dCAtIGFuIG9iamVjdCBkZWZpbmluZyB0aGUgY29udGV4dCBhcm91bmQgdGhlIGZpbGUgYW5kIHRoZSBzcGVjaWZpYyBvcHRpb25zXG5cdCAqL1xuXHRtZXJnZShcblx0XHRjdXJyZW50OiBzdHJpbmcsXG5cdFx0ZnJvbVRlbXBsYXRlUmVwbzogc3RyaW5nLFxuXHRcdGNvbnRleHQ6IE1lcmdlQ29udGV4dDxQbHVnaW5PcHRpb25zPixcblx0KTogUHJvbWlzZTxzdHJpbmc+O1xuXHQvKipcblx0ICogR2l2ZW4gYW4gb3B0aW9ucyBvYmplY3QgZm9yIHRoZSBtZXJnZSwgdGhpcyB2YWxpZGF0ZXMgdGhlIG9wdGlvbnMgb2JqZWN0IGFuZCByZXR1cm5zIGVycm9yIG1lc3NhZ2VzIGlmIHRoZXJlIGlzIGFueXRoaW5nIHdyb25nLlxuXHQgKiBAcGFyYW0gb3B0aW9ucyBhbnkganNvbiB2YWx1ZSB0aGF0IHRoZSB1c2VyIHByb3ZpZGVkIC0gbXVzdCBiZSB2YWxpZGF0ZWQgYWdhaW5zdCB0aGUgZXhwZWN0ZWQgb3B0aW9uc1xuXHQgKi9cblx0dmFsaWRhdGUob3B0aW9uczogdW5rbm93bik6IHN0cmluZ1tdIHwgdW5kZWZpbmVkO1xufVxuXG5leHBvcnQgdHlwZSBGaWxlT3BlcmF0aW9uID0gXCJhZGRlZFwiIHwgXCJtb2RpZmllZFwiIHwgXCJkZWxldGVkXCI7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztDQU1DLEdBMEhELFdBQTZEIn0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git-checkout.d.ts","sourceRoot":"","sources":["../../../src/checkout-drivers/git-checkout.ts"],"names":[],"mappings":"AAEA,wBAAsB,WAAW,CAAC,OAAO,EAAE;IAC1C,uCAAuC;IACvC,MAAM,EAAE,MAAM,CAAC;IACf,yDAAyD;IACzD,UAAU,EAAE,MAAM,CAAC;IACnB,qCAAqC;IACrC,MAAM,EAAE,MAAM,CAAC;CACf,GAAG,OAAO,CAAC,OAAO,CAAC,CA4BnB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git-checkout.spec.d.ts","sourceRoot":"","sources":["../../../src/checkout-drivers/git-checkout.spec.ts"],"names":[],"mappings":""}
|