@gitwand/core 1.6.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/LICENSE +21 -0
- package/README.md +52 -0
- package/dist/__tests__/bench.bench.d.ts +14 -0
- package/dist/__tests__/bench.bench.d.ts.map +1 -0
- package/dist/__tests__/bench.bench.js +137 -0
- package/dist/__tests__/bench.bench.js.map +1 -0
- package/dist/__tests__/confidence-v14.test.d.ts +13 -0
- package/dist/__tests__/confidence-v14.test.d.ts.map +1 -0
- package/dist/__tests__/confidence-v14.test.js +284 -0
- package/dist/__tests__/confidence-v14.test.js.map +1 -0
- package/dist/__tests__/config.test.d.ts +2 -0
- package/dist/__tests__/config.test.d.ts.map +1 -0
- package/dist/__tests__/config.test.js +317 -0
- package/dist/__tests__/config.test.js.map +1 -0
- package/dist/__tests__/corpus.d.ts +36 -0
- package/dist/__tests__/corpus.d.ts.map +1 -0
- package/dist/__tests__/corpus.js +541 -0
- package/dist/__tests__/corpus.js.map +1 -0
- package/dist/__tests__/corpus.test.d.ts +17 -0
- package/dist/__tests__/corpus.test.d.ts.map +1 -0
- package/dist/__tests__/corpus.test.js +179 -0
- package/dist/__tests__/corpus.test.js.map +1 -0
- package/dist/__tests__/diff.test.d.ts +10 -0
- package/dist/__tests__/diff.test.d.ts.map +1 -0
- package/dist/__tests__/diff.test.js +178 -0
- package/dist/__tests__/diff.test.js.map +1 -0
- package/dist/__tests__/format-resolvers.test.d.ts +2 -0
- package/dist/__tests__/format-resolvers.test.d.ts.map +1 -0
- package/dist/__tests__/format-resolvers.test.js +577 -0
- package/dist/__tests__/format-resolvers.test.js.map +1 -0
- package/dist/__tests__/imports-extended.test.d.ts +2 -0
- package/dist/__tests__/imports-extended.test.d.ts.map +1 -0
- package/dist/__tests__/imports-extended.test.js +94 -0
- package/dist/__tests__/imports-extended.test.js.map +1 -0
- package/dist/__tests__/lockfile-resolvers.test.d.ts +2 -0
- package/dist/__tests__/lockfile-resolvers.test.d.ts.map +1 -0
- package/dist/__tests__/lockfile-resolvers.test.js +200 -0
- package/dist/__tests__/lockfile-resolvers.test.js.map +1 -0
- package/dist/__tests__/patterns/insertion-at-boundary.test.d.ts +10 -0
- package/dist/__tests__/patterns/insertion-at-boundary.test.d.ts.map +1 -0
- package/dist/__tests__/patterns/insertion-at-boundary.test.js +185 -0
- package/dist/__tests__/patterns/insertion-at-boundary.test.js.map +1 -0
- package/dist/__tests__/patterns/reorder-only.test.d.ts +10 -0
- package/dist/__tests__/patterns/reorder-only.test.d.ts.map +1 -0
- package/dist/__tests__/patterns/reorder-only.test.js +181 -0
- package/dist/__tests__/patterns/reorder-only.test.js.map +1 -0
- package/dist/__tests__/phase-7-2-3b.test.d.ts +6 -0
- package/dist/__tests__/phase-7-2-3b.test.d.ts.map +1 -0
- package/dist/__tests__/phase-7-2-3b.test.js +730 -0
- package/dist/__tests__/phase-7-2-3b.test.js.map +1 -0
- package/dist/__tests__/resolver.test.d.ts +2 -0
- package/dist/__tests__/resolver.test.d.ts.map +1 -0
- package/dist/__tests__/resolver.test.js +927 -0
- package/dist/__tests__/resolver.test.js.map +1 -0
- package/dist/__tests__/resolvers/cargo.test.d.ts +10 -0
- package/dist/__tests__/resolvers/cargo.test.d.ts.map +1 -0
- package/dist/__tests__/resolvers/cargo.test.js +158 -0
- package/dist/__tests__/resolvers/cargo.test.js.map +1 -0
- package/dist/__tests__/resolvers/dockerfile.test.d.ts +8 -0
- package/dist/__tests__/resolvers/dockerfile.test.d.ts.map +1 -0
- package/dist/__tests__/resolvers/dockerfile.test.js +120 -0
- package/dist/__tests__/resolvers/dockerfile.test.js.map +1 -0
- package/dist/__tests__/resolvers/dotenv.test.d.ts +9 -0
- package/dist/__tests__/resolvers/dotenv.test.d.ts.map +1 -0
- package/dist/__tests__/resolvers/dotenv.test.js +113 -0
- package/dist/__tests__/resolvers/dotenv.test.js.map +1 -0
- package/dist/__tests__/resolvers/improvements-v14.test.d.ts +8 -0
- package/dist/__tests__/resolvers/improvements-v14.test.d.ts.map +1 -0
- package/dist/__tests__/resolvers/improvements-v14.test.js +306 -0
- package/dist/__tests__/resolvers/improvements-v14.test.js.map +1 -0
- package/dist/__tests__/validation.test.d.ts +12 -0
- package/dist/__tests__/validation.test.d.ts.map +1 -0
- package/dist/__tests__/validation.test.js +136 -0
- package/dist/__tests__/validation.test.js.map +1 -0
- package/dist/classifier.d.ts +21 -0
- package/dist/classifier.d.ts.map +1 -0
- package/dist/classifier.js +127 -0
- package/dist/classifier.js.map +1 -0
- package/dist/config.d.ts +108 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +200 -0
- package/dist/config.js.map +1 -0
- package/dist/diff.d.ts +69 -0
- package/dist/diff.d.ts.map +1 -0
- package/dist/diff.js +328 -0
- package/dist/diff.js.map +1 -0
- package/dist/index.d.ts +47 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +38 -0
- package/dist/index.js.map +1 -0
- package/dist/parser.d.ts +39 -0
- package/dist/parser.d.ts.map +1 -0
- package/dist/parser.js +164 -0
- package/dist/parser.js.map +1 -0
- package/dist/patterns/complex.d.ts +5 -0
- package/dist/patterns/complex.d.ts.map +1 -0
- package/dist/patterns/complex.js +27 -0
- package/dist/patterns/complex.js.map +1 -0
- package/dist/patterns/delete-no-change.d.ts +4 -0
- package/dist/patterns/delete-no-change.d.ts.map +1 -0
- package/dist/patterns/delete-no-change.js +75 -0
- package/dist/patterns/delete-no-change.js.map +1 -0
- package/dist/patterns/insertion-at-boundary.d.ts +22 -0
- package/dist/patterns/insertion-at-boundary.d.ts.map +1 -0
- package/dist/patterns/insertion-at-boundary.js +164 -0
- package/dist/patterns/insertion-at-boundary.js.map +1 -0
- package/dist/patterns/non-overlapping.d.ts +4 -0
- package/dist/patterns/non-overlapping.d.ts.map +1 -0
- package/dist/patterns/non-overlapping.js +28 -0
- package/dist/patterns/non-overlapping.js.map +1 -0
- package/dist/patterns/one-side-change.d.ts +4 -0
- package/dist/patterns/one-side-change.d.ts.map +1 -0
- package/dist/patterns/one-side-change.js +45 -0
- package/dist/patterns/one-side-change.js.map +1 -0
- package/dist/patterns/reorder-only.d.ts +14 -0
- package/dist/patterns/reorder-only.d.ts.map +1 -0
- package/dist/patterns/reorder-only.js +81 -0
- package/dist/patterns/reorder-only.js.map +1 -0
- package/dist/patterns/same-change.d.ts +4 -0
- package/dist/patterns/same-change.d.ts.map +1 -0
- package/dist/patterns/same-change.js +25 -0
- package/dist/patterns/same-change.js.map +1 -0
- package/dist/patterns/utils.d.ts +70 -0
- package/dist/patterns/utils.d.ts.map +1 -0
- package/dist/patterns/utils.js +206 -0
- package/dist/patterns/utils.js.map +1 -0
- package/dist/patterns/value-only-change.d.ts +4 -0
- package/dist/patterns/value-only-change.d.ts.map +1 -0
- package/dist/patterns/value-only-change.js +34 -0
- package/dist/patterns/value-only-change.js.map +1 -0
- package/dist/patterns/whitespace-only.d.ts +4 -0
- package/dist/patterns/whitespace-only.d.ts.map +1 -0
- package/dist/patterns/whitespace-only.js +32 -0
- package/dist/patterns/whitespace-only.js.map +1 -0
- package/dist/resolver/assemble.d.ts +25 -0
- package/dist/resolver/assemble.d.ts.map +1 -0
- package/dist/resolver/assemble.js +170 -0
- package/dist/resolver/assemble.js.map +1 -0
- package/dist/resolver/format-dispatch.d.ts +40 -0
- package/dist/resolver/format-dispatch.d.ts.map +1 -0
- package/dist/resolver/format-dispatch.js +51 -0
- package/dist/resolver/format-dispatch.js.map +1 -0
- package/dist/resolver/generated-detection.d.ts +48 -0
- package/dist/resolver/generated-detection.d.ts.map +1 -0
- package/dist/resolver/generated-detection.js +123 -0
- package/dist/resolver/generated-detection.js.map +1 -0
- package/dist/resolver/index.d.ts +26 -0
- package/dist/resolver/index.d.ts.map +1 -0
- package/dist/resolver/index.js +147 -0
- package/dist/resolver/index.js.map +1 -0
- package/dist/resolver/policy.d.ts +53 -0
- package/dist/resolver/policy.d.ts.map +1 -0
- package/dist/resolver/policy.js +99 -0
- package/dist/resolver/policy.js.map +1 -0
- package/dist/resolver/validation.d.ts +28 -0
- package/dist/resolver/validation.d.ts.map +1 -0
- package/dist/resolver/validation.js +96 -0
- package/dist/resolver/validation.js.map +1 -0
- package/dist/resolver.d.ts +18 -0
- package/dist/resolver.d.ts.map +1 -0
- package/dist/resolver.js +18 -0
- package/dist/resolver.js.map +1 -0
- package/dist/resolvers/cargo.d.ts +34 -0
- package/dist/resolvers/cargo.d.ts.map +1 -0
- package/dist/resolvers/cargo.js +262 -0
- package/dist/resolvers/cargo.js.map +1 -0
- package/dist/resolvers/css.d.ts +60 -0
- package/dist/resolvers/css.d.ts.map +1 -0
- package/dist/resolvers/css.js +531 -0
- package/dist/resolvers/css.js.map +1 -0
- package/dist/resolvers/dispatcher.d.ts +78 -0
- package/dist/resolvers/dispatcher.d.ts.map +1 -0
- package/dist/resolvers/dispatcher.js +290 -0
- package/dist/resolvers/dispatcher.js.map +1 -0
- package/dist/resolvers/dockerfile.d.ts +24 -0
- package/dist/resolvers/dockerfile.d.ts.map +1 -0
- package/dist/resolvers/dockerfile.js +221 -0
- package/dist/resolvers/dockerfile.js.map +1 -0
- package/dist/resolvers/dotenv.d.ts +27 -0
- package/dist/resolvers/dotenv.d.ts.map +1 -0
- package/dist/resolvers/dotenv.js +114 -0
- package/dist/resolvers/dotenv.js.map +1 -0
- package/dist/resolvers/imports.d.ts +63 -0
- package/dist/resolvers/imports.d.ts.map +1 -0
- package/dist/resolvers/imports.js +513 -0
- package/dist/resolvers/imports.js.map +1 -0
- package/dist/resolvers/json.d.ts +48 -0
- package/dist/resolvers/json.d.ts.map +1 -0
- package/dist/resolvers/json.js +363 -0
- package/dist/resolvers/json.js.map +1 -0
- package/dist/resolvers/lockfile-npm.d.ts +38 -0
- package/dist/resolvers/lockfile-npm.d.ts.map +1 -0
- package/dist/resolvers/lockfile-npm.js +267 -0
- package/dist/resolvers/lockfile-npm.js.map +1 -0
- package/dist/resolvers/lockfile-pnpm.d.ts +44 -0
- package/dist/resolvers/lockfile-pnpm.d.ts.map +1 -0
- package/dist/resolvers/lockfile-pnpm.js +277 -0
- package/dist/resolvers/lockfile-pnpm.js.map +1 -0
- package/dist/resolvers/lockfile-yarn.d.ts +40 -0
- package/dist/resolvers/lockfile-yarn.d.ts.map +1 -0
- package/dist/resolvers/lockfile-yarn.js +184 -0
- package/dist/resolvers/lockfile-yarn.js.map +1 -0
- package/dist/resolvers/markdown.d.ts +64 -0
- package/dist/resolvers/markdown.d.ts.map +1 -0
- package/dist/resolvers/markdown.js +335 -0
- package/dist/resolvers/markdown.js.map +1 -0
- package/dist/resolvers/vue.d.ts +65 -0
- package/dist/resolvers/vue.d.ts.map +1 -0
- package/dist/resolvers/vue.js +258 -0
- package/dist/resolvers/vue.js.map +1 -0
- package/dist/resolvers/yaml.d.ts +65 -0
- package/dist/resolvers/yaml.d.ts.map +1 -0
- package/dist/resolvers/yaml.js +405 -0
- package/dist/resolvers/yaml.js.map +1 -0
- package/dist/types.d.ts +256 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +8 -0
- package/dist/types.js.map +1 -0
- package/package.json +57 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests pour le résolveur d'imports étendu (Phase 8.1 — tri par groupes, Node builtins)
|
|
3
|
+
*/
|
|
4
|
+
import { describe, it, expect } from "vitest";
|
|
5
|
+
import { tryResolveImportConflict } from "../resolvers/imports.js";
|
|
6
|
+
describe("tryResolveImportConflict — extended", () => {
|
|
7
|
+
it("should merge imports added on both sides for the same named module", () => {
|
|
8
|
+
const base = [
|
|
9
|
+
'import { useState } from "react";',
|
|
10
|
+
];
|
|
11
|
+
const ours = [
|
|
12
|
+
'import { useState, useEffect } from "react";',
|
|
13
|
+
];
|
|
14
|
+
const theirs = [
|
|
15
|
+
'import { useState, useCallback } from "react";',
|
|
16
|
+
];
|
|
17
|
+
const result = tryResolveImportConflict(base, ours, theirs);
|
|
18
|
+
expect(result.mergedLines).not.toBeNull();
|
|
19
|
+
expect(result.unresolvedImports).toBe(0);
|
|
20
|
+
// All three names should be present
|
|
21
|
+
const merged = result.mergedLines.join("\n");
|
|
22
|
+
expect(merged).toContain("useCallback");
|
|
23
|
+
expect(merged).toContain("useEffect");
|
|
24
|
+
expect(merged).toContain("useState");
|
|
25
|
+
});
|
|
26
|
+
it("should merge when ours adds a new module and theirs adds a different one", () => {
|
|
27
|
+
const base = [
|
|
28
|
+
'import React from "react";',
|
|
29
|
+
];
|
|
30
|
+
const ours = [
|
|
31
|
+
'import React from "react";',
|
|
32
|
+
'import { formatDate } from "./utils";',
|
|
33
|
+
];
|
|
34
|
+
const theirs = [
|
|
35
|
+
'import React from "react";',
|
|
36
|
+
'import axios from "axios";',
|
|
37
|
+
];
|
|
38
|
+
const result = tryResolveImportConflict(base, ours, theirs);
|
|
39
|
+
expect(result.mergedLines).not.toBeNull();
|
|
40
|
+
expect(result.unresolvedImports).toBe(0);
|
|
41
|
+
const merged = result.mergedLines.join("\n");
|
|
42
|
+
expect(merged).toContain('axios');
|
|
43
|
+
expect(merged).toContain('./utils');
|
|
44
|
+
expect(merged).toContain('react');
|
|
45
|
+
});
|
|
46
|
+
it("should sort Node builtins before npm packages", () => {
|
|
47
|
+
const base = [];
|
|
48
|
+
const ours = [
|
|
49
|
+
'import path from "path";',
|
|
50
|
+
];
|
|
51
|
+
const theirs = [
|
|
52
|
+
'import axios from "axios";',
|
|
53
|
+
];
|
|
54
|
+
const result = tryResolveImportConflict(base, ours, theirs);
|
|
55
|
+
expect(result.mergedLines).not.toBeNull();
|
|
56
|
+
const lines = result.mergedLines.filter(l => l.trim());
|
|
57
|
+
// path (built-in) should come before axios (npm)
|
|
58
|
+
const pathIdx = lines.findIndex(l => l.includes("path"));
|
|
59
|
+
const axiosIdx = lines.findIndex(l => l.includes("axios"));
|
|
60
|
+
expect(pathIdx).toBeLessThan(axiosIdx);
|
|
61
|
+
});
|
|
62
|
+
it("should handle TypeScript type imports alongside value imports", () => {
|
|
63
|
+
const base = [
|
|
64
|
+
'import { useState } from "react";',
|
|
65
|
+
];
|
|
66
|
+
const ours = [
|
|
67
|
+
'import { useState } from "react";',
|
|
68
|
+
'import type { FC } from "react";',
|
|
69
|
+
];
|
|
70
|
+
const theirs = [
|
|
71
|
+
'import { useState, useRef } from "react";',
|
|
72
|
+
];
|
|
73
|
+
const result = tryResolveImportConflict(base, ours, theirs);
|
|
74
|
+
expect(result.mergedLines).not.toBeNull();
|
|
75
|
+
const merged = result.mergedLines.join("\n");
|
|
76
|
+
expect(merged).toContain("type");
|
|
77
|
+
expect(merged).toContain("useRef");
|
|
78
|
+
expect(merged).toContain("useState");
|
|
79
|
+
});
|
|
80
|
+
it("should detect conflict when same module imported incompatibly", () => {
|
|
81
|
+
const base = [];
|
|
82
|
+
const ours = [
|
|
83
|
+
'import * as React from "react";',
|
|
84
|
+
];
|
|
85
|
+
const theirs = [
|
|
86
|
+
'import React from "react";',
|
|
87
|
+
];
|
|
88
|
+
const result = tryResolveImportConflict(base, ours, theirs);
|
|
89
|
+
// Namespace vs default = conflict
|
|
90
|
+
expect(result.mergedLines).toBeNull();
|
|
91
|
+
expect(result.unresolvedImports).toBeGreaterThan(0);
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
//# sourceMappingURL=imports-extended.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"imports-extended.test.js","sourceRoot":"","sources":["../../src/__tests__/imports-extended.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lockfile-resolvers.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/lockfile-resolvers.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests pour les résolveurs lockfile sémantiques (Phase 8.1 — Auto-resolve étendu)
|
|
3
|
+
*/
|
|
4
|
+
import { describe, it, expect } from "vitest";
|
|
5
|
+
import { tryResolveLockfileNpmConflict } from "../resolvers/lockfile-npm.js";
|
|
6
|
+
import { tryResolveYarnLockConflict } from "../resolvers/lockfile-yarn.js";
|
|
7
|
+
import { tryResolvePnpmLockConflict } from "../resolvers/lockfile-pnpm.js";
|
|
8
|
+
// ─── npm lockfile (package-lock.json) ────────────────────
|
|
9
|
+
describe("tryResolveLockfileNpmConflict", () => {
|
|
10
|
+
it("should merge when ours adds a package and theirs adds a different one", () => {
|
|
11
|
+
const base = JSON.stringify({
|
|
12
|
+
name: "test",
|
|
13
|
+
lockfileVersion: 3,
|
|
14
|
+
packages: {
|
|
15
|
+
"": { name: "test", version: "1.0.0" },
|
|
16
|
+
"node_modules/react": { version: "18.2.0", resolved: "https://registry.npmjs.org/react/-/react-18.2.0.tgz" },
|
|
17
|
+
},
|
|
18
|
+
}, null, 2);
|
|
19
|
+
const ours = JSON.stringify({
|
|
20
|
+
name: "test",
|
|
21
|
+
lockfileVersion: 3,
|
|
22
|
+
packages: {
|
|
23
|
+
"": { name: "test", version: "1.0.0" },
|
|
24
|
+
"node_modules/react": { version: "18.2.0", resolved: "https://registry.npmjs.org/react/-/react-18.2.0.tgz" },
|
|
25
|
+
"node_modules/lodash": { version: "4.17.21", resolved: "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz" },
|
|
26
|
+
},
|
|
27
|
+
}, null, 2);
|
|
28
|
+
const theirs = JSON.stringify({
|
|
29
|
+
name: "test",
|
|
30
|
+
lockfileVersion: 3,
|
|
31
|
+
packages: {
|
|
32
|
+
"": { name: "test", version: "1.0.0" },
|
|
33
|
+
"node_modules/react": { version: "18.2.0", resolved: "https://registry.npmjs.org/react/-/react-18.2.0.tgz" },
|
|
34
|
+
"node_modules/axios": { version: "1.6.0", resolved: "https://registry.npmjs.org/axios/-/axios-1.6.0.tgz" },
|
|
35
|
+
},
|
|
36
|
+
}, null, 2);
|
|
37
|
+
const result = tryResolveLockfileNpmConflict(base.split("\n"), ours.split("\n"), theirs.split("\n"));
|
|
38
|
+
expect(result.merged).not.toBeNull();
|
|
39
|
+
expect(result.versionConflicts).toBe(0);
|
|
40
|
+
// Both lodash and axios should be present
|
|
41
|
+
const parsed = JSON.parse(result.merged);
|
|
42
|
+
expect(parsed.packages["node_modules/lodash"]).toBeDefined();
|
|
43
|
+
expect(parsed.packages["node_modules/axios"]).toBeDefined();
|
|
44
|
+
expect(parsed.packages["node_modules/react"]).toBeDefined();
|
|
45
|
+
});
|
|
46
|
+
it("should handle ours removing a package while theirs keeps it unchanged", () => {
|
|
47
|
+
const base = JSON.stringify({
|
|
48
|
+
name: "test",
|
|
49
|
+
lockfileVersion: 3,
|
|
50
|
+
packages: {
|
|
51
|
+
"node_modules/react": { version: "18.2.0" },
|
|
52
|
+
"node_modules/lodash": { version: "4.17.21" },
|
|
53
|
+
},
|
|
54
|
+
}, null, 2);
|
|
55
|
+
const ours = JSON.stringify({
|
|
56
|
+
name: "test",
|
|
57
|
+
lockfileVersion: 3,
|
|
58
|
+
packages: {
|
|
59
|
+
"node_modules/react": { version: "18.2.0" },
|
|
60
|
+
},
|
|
61
|
+
}, null, 2);
|
|
62
|
+
const theirs = base;
|
|
63
|
+
const result = tryResolveLockfileNpmConflict(base.split("\n"), ours.split("\n"), theirs.split("\n"));
|
|
64
|
+
expect(result.merged).not.toBeNull();
|
|
65
|
+
const parsed = JSON.parse(result.merged);
|
|
66
|
+
// lodash should be removed (ours removed it, theirs didn't change it)
|
|
67
|
+
expect(parsed.packages["node_modules/lodash"]).toBeUndefined();
|
|
68
|
+
expect(parsed.packages["node_modules/react"]).toBeDefined();
|
|
69
|
+
});
|
|
70
|
+
it("should resolve property-level conflicts (ours updates version, theirs updates integrity)", () => {
|
|
71
|
+
const base = JSON.stringify({
|
|
72
|
+
name: "test",
|
|
73
|
+
lockfileVersion: 3,
|
|
74
|
+
packages: {
|
|
75
|
+
"node_modules/react": { version: "18.2.0", integrity: "sha512-old", resolved: "https://old" },
|
|
76
|
+
},
|
|
77
|
+
}, null, 2);
|
|
78
|
+
const ours = JSON.stringify({
|
|
79
|
+
name: "test",
|
|
80
|
+
lockfileVersion: 3,
|
|
81
|
+
packages: {
|
|
82
|
+
"node_modules/react": { version: "18.3.0", integrity: "sha512-old", resolved: "https://old" },
|
|
83
|
+
},
|
|
84
|
+
}, null, 2);
|
|
85
|
+
const theirs = JSON.stringify({
|
|
86
|
+
name: "test",
|
|
87
|
+
lockfileVersion: 3,
|
|
88
|
+
packages: {
|
|
89
|
+
"node_modules/react": { version: "18.2.0", integrity: "sha512-new", resolved: "https://new" },
|
|
90
|
+
},
|
|
91
|
+
}, null, 2);
|
|
92
|
+
const result = tryResolveLockfileNpmConflict(base.split("\n"), ours.split("\n"), theirs.split("\n"));
|
|
93
|
+
expect(result.merged).not.toBeNull();
|
|
94
|
+
const parsed = JSON.parse(result.merged);
|
|
95
|
+
const react = parsed.packages["node_modules/react"];
|
|
96
|
+
// ours changed version, theirs changed integrity+resolved → both should be merged
|
|
97
|
+
expect(react.version).toBe("18.3.0");
|
|
98
|
+
expect(react.integrity).toBe("sha512-new");
|
|
99
|
+
expect(react.resolved).toBe("https://new");
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
// ─── yarn lockfile (yarn.lock) ───────────────────────────
|
|
103
|
+
describe("tryResolveYarnLockConflict", () => {
|
|
104
|
+
const baseLock = `# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
|
|
105
|
+
# yarn lockfile v1
|
|
106
|
+
|
|
107
|
+
react@^18.0.0:
|
|
108
|
+
version "18.2.0"
|
|
109
|
+
resolved "https://registry.yarnpkg.com/react/-/react-18.2.0.tgz"
|
|
110
|
+
integrity sha512-xxx
|
|
111
|
+
|
|
112
|
+
lodash@^4.0.0:
|
|
113
|
+
version "4.17.21"
|
|
114
|
+
resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz"
|
|
115
|
+
integrity sha512-yyy
|
|
116
|
+
`;
|
|
117
|
+
it("should merge when ours adds a package and theirs adds a different one", () => {
|
|
118
|
+
const oursLock = baseLock + `\naxios@^1.0.0:\n version "1.6.0"\n resolved "https://registry.yarnpkg.com/axios/-/axios-1.6.0.tgz"\n integrity sha512-aaa\n`;
|
|
119
|
+
const theirsLock = baseLock + `\ndate-fns@^3.0.0:\n version "3.0.0"\n resolved "https://registry.yarnpkg.com/date-fns/-/date-fns-3.0.0.tgz"\n integrity sha512-bbb\n`;
|
|
120
|
+
const result = tryResolveYarnLockConflict(baseLock.split("\n"), oursLock.split("\n"), theirsLock.split("\n"));
|
|
121
|
+
expect(result.merged).not.toBeNull();
|
|
122
|
+
expect(result.versionConflicts).toBe(0);
|
|
123
|
+
expect(result.merged).toContain("axios@^1.0.0:");
|
|
124
|
+
expect(result.merged).toContain("date-fns@^3.0.0:");
|
|
125
|
+
expect(result.merged).toContain("react@^18.0.0:");
|
|
126
|
+
expect(result.merged).toContain("lodash@^4.0.0:");
|
|
127
|
+
});
|
|
128
|
+
it("should handle deletion from one side", () => {
|
|
129
|
+
// Ours removes lodash
|
|
130
|
+
const oursLock = `# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
|
|
131
|
+
# yarn lockfile v1
|
|
132
|
+
|
|
133
|
+
react@^18.0.0:
|
|
134
|
+
version "18.2.0"
|
|
135
|
+
resolved "https://registry.yarnpkg.com/react/-/react-18.2.0.tgz"
|
|
136
|
+
integrity sha512-xxx
|
|
137
|
+
`;
|
|
138
|
+
const result = tryResolveYarnLockConflict(baseLock.split("\n"), oursLock.split("\n"), baseLock.split("\n"));
|
|
139
|
+
expect(result.merged).not.toBeNull();
|
|
140
|
+
expect(result.merged).not.toContain("lodash@^4.0.0:");
|
|
141
|
+
expect(result.merged).toContain("react@^18.0.0:");
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
// ─── pnpm lockfile (pnpm-lock.yaml) ─────────────────────
|
|
145
|
+
describe("tryResolvePnpmLockConflict", () => {
|
|
146
|
+
const baseLock = `lockfileVersion: '9.0'
|
|
147
|
+
|
|
148
|
+
settings:
|
|
149
|
+
autoInstallPeers: true
|
|
150
|
+
|
|
151
|
+
packages:
|
|
152
|
+
/react@18.2.0:
|
|
153
|
+
resolution: {integrity: sha512-xxx}
|
|
154
|
+
engines: {node: '>=16'}
|
|
155
|
+
|
|
156
|
+
/lodash@4.17.21:
|
|
157
|
+
resolution: {integrity: sha512-yyy}
|
|
158
|
+
`;
|
|
159
|
+
it("should merge when ours adds a package and theirs adds a different one", () => {
|
|
160
|
+
const oursLock = `lockfileVersion: '9.0'
|
|
161
|
+
|
|
162
|
+
settings:
|
|
163
|
+
autoInstallPeers: true
|
|
164
|
+
|
|
165
|
+
packages:
|
|
166
|
+
/react@18.2.0:
|
|
167
|
+
resolution: {integrity: sha512-xxx}
|
|
168
|
+
engines: {node: '>=16'}
|
|
169
|
+
|
|
170
|
+
/lodash@4.17.21:
|
|
171
|
+
resolution: {integrity: sha512-yyy}
|
|
172
|
+
|
|
173
|
+
/axios@1.6.0:
|
|
174
|
+
resolution: {integrity: sha512-aaa}
|
|
175
|
+
`;
|
|
176
|
+
const theirsLock = `lockfileVersion: '9.0'
|
|
177
|
+
|
|
178
|
+
settings:
|
|
179
|
+
autoInstallPeers: true
|
|
180
|
+
|
|
181
|
+
packages:
|
|
182
|
+
/react@18.2.0:
|
|
183
|
+
resolution: {integrity: sha512-xxx}
|
|
184
|
+
engines: {node: '>=16'}
|
|
185
|
+
|
|
186
|
+
/lodash@4.17.21:
|
|
187
|
+
resolution: {integrity: sha512-yyy}
|
|
188
|
+
|
|
189
|
+
/date-fns@3.0.0:
|
|
190
|
+
resolution: {integrity: sha512-bbb}
|
|
191
|
+
`;
|
|
192
|
+
const result = tryResolvePnpmLockConflict(baseLock.split("\n"), oursLock.split("\n"), theirsLock.split("\n"));
|
|
193
|
+
expect(result.merged).not.toBeNull();
|
|
194
|
+
expect(result.conflicts).toBe(0);
|
|
195
|
+
expect(result.merged).toContain("axios");
|
|
196
|
+
expect(result.merged).toContain("date-fns");
|
|
197
|
+
expect(result.merged).toContain("react");
|
|
198
|
+
});
|
|
199
|
+
});
|
|
200
|
+
//# sourceMappingURL=lockfile-resolvers.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lockfile-resolvers.test.js","sourceRoot":"","sources":["../../src/__tests__/lockfile-resolvers.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests du pattern insertion_at_boundary (v1.4)
|
|
3
|
+
*
|
|
4
|
+
* Fixtures :
|
|
5
|
+
* F23 — liste de dépendances npm (diff3, insertions distinctes)
|
|
6
|
+
* F24 — tableau de routes (diff3)
|
|
7
|
+
* + cas diff2, chevauchement, faux positifs
|
|
8
|
+
*/
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=insertion-at-boundary.test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insertion-at-boundary.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/patterns/insertion-at-boundary.test.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG"}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests du pattern insertion_at_boundary (v1.4)
|
|
3
|
+
*
|
|
4
|
+
* Fixtures :
|
|
5
|
+
* F23 — liste de dépendances npm (diff3, insertions distinctes)
|
|
6
|
+
* F24 — tableau de routes (diff3)
|
|
7
|
+
* + cas diff2, chevauchement, faux positifs
|
|
8
|
+
*/
|
|
9
|
+
import { describe, it, expect } from "vitest";
|
|
10
|
+
import { resolve } from "../../resolver.js";
|
|
11
|
+
// ─── F23 — liste de dépendances (diff3) ──────────────────────
|
|
12
|
+
describe("F23 — insertion_at_boundary : liste de dépendances npm (diff3)", () => {
|
|
13
|
+
const input = [
|
|
14
|
+
`<<<<<<< ours`,
|
|
15
|
+
` "lodash": "^4.17.21",`,
|
|
16
|
+
` "axios": "^1.6.0",`,
|
|
17
|
+
` "dayjs": "^1.11.10",`,
|
|
18
|
+
`||||||| base`,
|
|
19
|
+
` "lodash": "^4.17.21",`,
|
|
20
|
+
` "axios": "^1.6.0",`,
|
|
21
|
+
`=======`,
|
|
22
|
+
` "lodash": "^4.17.21",`,
|
|
23
|
+
` "axios": "^1.6.0",`,
|
|
24
|
+
` "zod": "^3.22.4",`,
|
|
25
|
+
`>>>>>>> theirs`,
|
|
26
|
+
].join("\n");
|
|
27
|
+
it("classifie en insertion_at_boundary", () => {
|
|
28
|
+
const result = resolve(input, "package.json");
|
|
29
|
+
expect(result.hunks[0].type).toBe("insertion_at_boundary");
|
|
30
|
+
});
|
|
31
|
+
it("auto-résout avec haute confiance (diff3)", () => {
|
|
32
|
+
const result = resolve(input, "package.json");
|
|
33
|
+
expect(result.stats.autoResolved).toBe(1);
|
|
34
|
+
expect(["high", "certain"]).toContain(result.hunks[0].confidence.label);
|
|
35
|
+
});
|
|
36
|
+
it("le résultat contient les insertions des deux côtés", () => {
|
|
37
|
+
const result = resolve(input, "package.json");
|
|
38
|
+
const merged = result.mergedContent;
|
|
39
|
+
expect(merged).toContain("dayjs");
|
|
40
|
+
expect(merged).toContain("zod");
|
|
41
|
+
expect(merged).toContain("lodash");
|
|
42
|
+
expect(merged).toContain("axios");
|
|
43
|
+
});
|
|
44
|
+
it("le booster 'Insertions pures' est présent", () => {
|
|
45
|
+
const result = resolve(input, "package.json");
|
|
46
|
+
expect(result.hunks[0].confidence.boosters.join(" ")).toMatch(/Insertions pures/);
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
// ─── F24 — tableau de routes (diff3) ─────────────────────────
|
|
50
|
+
describe("F24 — insertion_at_boundary : tableau de routes (diff3)", () => {
|
|
51
|
+
const input = [
|
|
52
|
+
`<<<<<<< ours`,
|
|
53
|
+
` { path: "/", component: Home },`,
|
|
54
|
+
` { path: "/about", component: About },`,
|
|
55
|
+
` { path: "/dashboard", component: Dashboard },`,
|
|
56
|
+
`||||||| base`,
|
|
57
|
+
` { path: "/", component: Home },`,
|
|
58
|
+
` { path: "/about", component: About },`,
|
|
59
|
+
`=======`,
|
|
60
|
+
` { path: "/", component: Home },`,
|
|
61
|
+
` { path: "/about", component: About },`,
|
|
62
|
+
` { path: "/settings", component: Settings },`,
|
|
63
|
+
`>>>>>>> theirs`,
|
|
64
|
+
].join("\n");
|
|
65
|
+
it("classifie en insertion_at_boundary", () => {
|
|
66
|
+
const result = resolve(input, "src/router.ts");
|
|
67
|
+
expect(result.hunks[0].type).toBe("insertion_at_boundary");
|
|
68
|
+
});
|
|
69
|
+
it("auto-résout", () => {
|
|
70
|
+
const result = resolve(input, "src/router.ts");
|
|
71
|
+
expect(result.stats.autoResolved).toBe(1);
|
|
72
|
+
});
|
|
73
|
+
it("les deux nouvelles routes sont présentes dans le résultat", () => {
|
|
74
|
+
const result = resolve(input, "src/router.ts");
|
|
75
|
+
const merged = result.mergedContent;
|
|
76
|
+
expect(merged).toContain("dashboard");
|
|
77
|
+
expect(merged).toContain("settings");
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
// ─── diff2 (sans base) — confiance réduite ───────────────────
|
|
81
|
+
// ─── diff2 (sans base) — heuristique stricte (sous-ensemble) ────────────────
|
|
82
|
+
// En diff2, insertion_at_boundary ne s'applique que si un côté est un strict
|
|
83
|
+
// sous-ensemble de l'autre (tailles différentes). Cas typique : ours a inséré
|
|
84
|
+
// une ligne de plus que theirs, ou vice versa.
|
|
85
|
+
describe("insertion_at_boundary sans base (diff2) — sous-ensemble strict", () => {
|
|
86
|
+
// ours a ajouté PURPLE par rapport à theirs
|
|
87
|
+
const input = [
|
|
88
|
+
`<<<<<<< ours`,
|
|
89
|
+
` RED = "red",`,
|
|
90
|
+
` GREEN = "green",`,
|
|
91
|
+
` BLUE = "blue",`,
|
|
92
|
+
` PURPLE = "purple",`,
|
|
93
|
+
`=======`,
|
|
94
|
+
` RED = "red",`,
|
|
95
|
+
` GREEN = "green",`,
|
|
96
|
+
` BLUE = "blue",`,
|
|
97
|
+
`>>>>>>> theirs`,
|
|
98
|
+
].join("\n");
|
|
99
|
+
// En diff2, la confiance est ~58 (medium) — nécessite minConfidence: "medium"
|
|
100
|
+
const opts = { minConfidence: "medium" };
|
|
101
|
+
it("classifie en insertion_at_boundary (heuristique diff2 — theirs ⊂ ours)", () => {
|
|
102
|
+
const result = resolve(input, "src/colors.ts", opts);
|
|
103
|
+
expect(result.hunks[0].type).toBe("insertion_at_boundary");
|
|
104
|
+
});
|
|
105
|
+
it("typeClassification inférieur au cas diff3 (confiance réduite)", () => {
|
|
106
|
+
const result = resolve(input, "src/colors.ts", opts);
|
|
107
|
+
expect(result.hunks[0].confidence.dimensions.typeClassification).toBeLessThan(90);
|
|
108
|
+
});
|
|
109
|
+
it("la pénalité 'Sans base (diff2)' est présente", () => {
|
|
110
|
+
const result = resolve(input, "src/colors.ts", opts);
|
|
111
|
+
expect(result.hunks[0].confidence.penalties.join(" ")).toMatch(/diff2/);
|
|
112
|
+
});
|
|
113
|
+
it("le résultat contient la ligne insérée par ours (avec minConfidence medium)", () => {
|
|
114
|
+
const result = resolve(input, "src/colors.ts", opts);
|
|
115
|
+
expect(result.stats.autoResolved).toBe(1);
|
|
116
|
+
const merged = result.mergedContent;
|
|
117
|
+
expect(merged).toContain("RED");
|
|
118
|
+
expect(merged).toContain("GREEN");
|
|
119
|
+
expect(merged).toContain("BLUE");
|
|
120
|
+
expect(merged).toContain("PURPLE");
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
// ─── Chevauchement — doit tomber en complex ───────────────────
|
|
124
|
+
describe("insertion_at_boundary : chevauchement d'insertions → pas de match", () => {
|
|
125
|
+
it("ne matche pas si les deux côtés ont inséré la même ligne", () => {
|
|
126
|
+
const input = [
|
|
127
|
+
`<<<<<<< ours`,
|
|
128
|
+
` foo,`,
|
|
129
|
+
` bar,`,
|
|
130
|
+
` shared,`,
|
|
131
|
+
`||||||| base`,
|
|
132
|
+
` foo,`,
|
|
133
|
+
` bar,`,
|
|
134
|
+
`=======`,
|
|
135
|
+
` foo,`,
|
|
136
|
+
` bar,`,
|
|
137
|
+
` shared,`,
|
|
138
|
+
`>>>>>>> theirs`,
|
|
139
|
+
].join("\n");
|
|
140
|
+
const result = resolve(input, "src/test.ts");
|
|
141
|
+
// same_change captera cela (ours === theirs)
|
|
142
|
+
expect(result.hunks[0].type).toBe("same_change");
|
|
143
|
+
});
|
|
144
|
+
it("ne matche pas si un côté supprime par rapport à la base", () => {
|
|
145
|
+
const input = [
|
|
146
|
+
`<<<<<<< ours`,
|
|
147
|
+
` foo,`,
|
|
148
|
+
` newThing,`,
|
|
149
|
+
`||||||| base`,
|
|
150
|
+
` foo,`,
|
|
151
|
+
` bar,`,
|
|
152
|
+
`=======`,
|
|
153
|
+
` foo,`,
|
|
154
|
+
` bar,`,
|
|
155
|
+
` anotherThing,`,
|
|
156
|
+
`>>>>>>> theirs`,
|
|
157
|
+
].join("\n");
|
|
158
|
+
const result = resolve(input, "src/test.ts");
|
|
159
|
+
// ours supprime "bar" → pas une insertion pure
|
|
160
|
+
expect(result.hunks[0].type).not.toBe("insertion_at_boundary");
|
|
161
|
+
});
|
|
162
|
+
});
|
|
163
|
+
// ─── Relation avec non_overlapping ───────────────────────────
|
|
164
|
+
describe("insertion_at_boundary vs non_overlapping", () => {
|
|
165
|
+
it("non_overlapping (prio 40) prend la main avant insertion_at_boundary (prio 57) quand le LCS réussit", () => {
|
|
166
|
+
// Insertions à positions clairement différentes → LCS 3-way réussit → non_overlapping
|
|
167
|
+
const input = [
|
|
168
|
+
`<<<<<<< ours`,
|
|
169
|
+
` alpha,`,
|
|
170
|
+
` INSERTED_OURS,`,
|
|
171
|
+
` beta,`,
|
|
172
|
+
`||||||| base`,
|
|
173
|
+
` alpha,`,
|
|
174
|
+
` beta,`,
|
|
175
|
+
`=======`,
|
|
176
|
+
` alpha,`,
|
|
177
|
+
` beta,`,
|
|
178
|
+
` INSERTED_THEIRS,`,
|
|
179
|
+
`>>>>>>> theirs`,
|
|
180
|
+
].join("\n");
|
|
181
|
+
const result = resolve(input, "src/list.ts");
|
|
182
|
+
expect(result.hunks[0].type).toBe("non_overlapping");
|
|
183
|
+
});
|
|
184
|
+
});
|
|
185
|
+
//# sourceMappingURL=insertion-at-boundary.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insertion-at-boundary.test.js","sourceRoot":"","sources":["../../../src/__tests__/patterns/insertion-at-boundary.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests du pattern reorder_only (v1.4)
|
|
3
|
+
*
|
|
4
|
+
* Fixtures :
|
|
5
|
+
* F21 — imports triés alphabétiquement
|
|
6
|
+
* F22 — clés de config réorganisées
|
|
7
|
+
* + cas limites : doublons, diff2 vs diff3, faux positifs
|
|
8
|
+
*/
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=reorder-only.test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reorder-only.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/patterns/reorder-only.test.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG"}
|