@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,317 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { resolve } from "../resolver.js";
|
|
3
|
+
import { matchGlob, effectivePolicyForFile, policyToConfig, parseGitwandrc, DEFAULT_POLICY, } from "../config.js";
|
|
4
|
+
// ═══════════════════════════════════════════════════════════════
|
|
5
|
+
// PHASE 7.4 — Politiques de merge et configuration par projet
|
|
6
|
+
// ═══════════════════════════════════════════════════════════════
|
|
7
|
+
describe("Phase 7.4 — matchGlob", () => {
|
|
8
|
+
describe("extensions simples", () => {
|
|
9
|
+
it("matche *.lock sur yarn.lock", () => {
|
|
10
|
+
expect(matchGlob("*.lock", "yarn.lock")).toBe(true);
|
|
11
|
+
});
|
|
12
|
+
it("matche *.lock sur Cargo.lock", () => {
|
|
13
|
+
expect(matchGlob("*.lock", "Cargo.lock")).toBe(true);
|
|
14
|
+
});
|
|
15
|
+
it("ne matche pas *.lock sur package.json", () => {
|
|
16
|
+
expect(matchGlob("*.lock", "package.json")).toBe(false);
|
|
17
|
+
});
|
|
18
|
+
it("matche *.json sur package.json", () => {
|
|
19
|
+
expect(matchGlob("*.json", "package.json")).toBe(true);
|
|
20
|
+
});
|
|
21
|
+
it("matche *.json même dans un sous-dossier (basename match)", () => {
|
|
22
|
+
expect(matchGlob("*.json", "src/config.json")).toBe(true);
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
describe("correspondance exacte", () => {
|
|
26
|
+
it("matche package.json exactement", () => {
|
|
27
|
+
expect(matchGlob("package.json", "package.json")).toBe(true);
|
|
28
|
+
});
|
|
29
|
+
it("ne matche pas package.json sur other.json", () => {
|
|
30
|
+
expect(matchGlob("package.json", "other.json")).toBe(false);
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
describe("globs avec slash", () => {
|
|
34
|
+
it("matche src/**/*.ts sur src/utils/helper.ts", () => {
|
|
35
|
+
expect(matchGlob("src/**/*.ts", "src/utils/helper.ts")).toBe(true);
|
|
36
|
+
});
|
|
37
|
+
it("matche src/**/*.ts sur src/components/App.ts", () => {
|
|
38
|
+
expect(matchGlob("src/**/*.ts", "src/components/App.ts")).toBe(true);
|
|
39
|
+
});
|
|
40
|
+
it("ne matche pas src/**/*.ts sur test/utils.ts", () => {
|
|
41
|
+
expect(matchGlob("src/**/*.ts", "test/utils.ts")).toBe(false);
|
|
42
|
+
});
|
|
43
|
+
it("matche docs/*.md sur docs/README.md", () => {
|
|
44
|
+
expect(matchGlob("docs/*.md", "docs/README.md")).toBe(true);
|
|
45
|
+
});
|
|
46
|
+
it("ne matche pas docs/*.md sur docs/sub/README.md", () => {
|
|
47
|
+
expect(matchGlob("docs/*.md", "docs/sub/README.md")).toBe(false);
|
|
48
|
+
});
|
|
49
|
+
it("matche **/*.lock sur node_modules/foo/yarn.lock", () => {
|
|
50
|
+
expect(matchGlob("**/*.lock", "node_modules/foo/yarn.lock")).toBe(true);
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
describe("Phase 7.4 — effectivePolicyForFile", () => {
|
|
55
|
+
it("retourne DEFAULT_POLICY si aucune option", () => {
|
|
56
|
+
expect(effectivePolicyForFile("src/app.ts")).toBe(DEFAULT_POLICY);
|
|
57
|
+
});
|
|
58
|
+
it("retourne la politique globale si définie", () => {
|
|
59
|
+
expect(effectivePolicyForFile("src/app.ts", "prefer-ours")).toBe("prefer-ours");
|
|
60
|
+
});
|
|
61
|
+
it("le pattern override bat la politique globale", () => {
|
|
62
|
+
expect(effectivePolicyForFile("yarn.lock", "prefer-ours", { "*.lock": "prefer-theirs" })).toBe("prefer-theirs");
|
|
63
|
+
});
|
|
64
|
+
it("le pattern le plus spécifique gagne", () => {
|
|
65
|
+
expect(effectivePolicyForFile("package.json", "prefer-merge", {
|
|
66
|
+
"*.json": "prefer-safety",
|
|
67
|
+
"package.json": "strict", // plus spécifique
|
|
68
|
+
})).toBe("strict");
|
|
69
|
+
});
|
|
70
|
+
it("les fichiers non-matchés utilisent la politique globale", () => {
|
|
71
|
+
expect(effectivePolicyForFile("src/app.ts", "prefer-merge", { "*.json": "strict" })).toBe("prefer-merge");
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
describe("Phase 7.4 — policyToConfig", () => {
|
|
75
|
+
it("prefer-ours : preferOurs = true", () => {
|
|
76
|
+
const cfg = policyToConfig("prefer-ours");
|
|
77
|
+
expect(cfg.preferOurs).toBe(true);
|
|
78
|
+
expect(cfg.allowWhitespace).toBe(true);
|
|
79
|
+
expect(cfg.allowValueOnly).toBe(true);
|
|
80
|
+
});
|
|
81
|
+
it("prefer-theirs : preferOurs = false", () => {
|
|
82
|
+
const cfg = policyToConfig("prefer-theirs");
|
|
83
|
+
expect(cfg.preferOurs).toBe(false);
|
|
84
|
+
});
|
|
85
|
+
it("prefer-merge : minConfidence medium", () => {
|
|
86
|
+
const cfg = policyToConfig("prefer-merge");
|
|
87
|
+
expect(cfg.minConfidence).toBe("medium");
|
|
88
|
+
expect(cfg.allowWhitespace).toBe(true);
|
|
89
|
+
});
|
|
90
|
+
it("prefer-safety : whitespace et value_only désactivés", () => {
|
|
91
|
+
const cfg = policyToConfig("prefer-safety");
|
|
92
|
+
expect(cfg.allowWhitespace).toBe(false);
|
|
93
|
+
expect(cfg.allowValueOnly).toBe(false);
|
|
94
|
+
expect(cfg.allowNonOverlapping).toBe(true);
|
|
95
|
+
});
|
|
96
|
+
it("strict : whitespace, value_only, non_overlapping désactivés", () => {
|
|
97
|
+
const cfg = policyToConfig("strict");
|
|
98
|
+
expect(cfg.allowWhitespace).toBe(false);
|
|
99
|
+
expect(cfg.allowValueOnly).toBe(false);
|
|
100
|
+
expect(cfg.allowNonOverlapping).toBe(false);
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
describe("Phase 7.4 — parseGitwandrc", () => {
|
|
104
|
+
it("parse un .gitwandrc valide", () => {
|
|
105
|
+
const json = JSON.stringify({
|
|
106
|
+
policy: "prefer-safety",
|
|
107
|
+
patterns: {
|
|
108
|
+
"*.lock": "prefer-theirs",
|
|
109
|
+
"src/**/*.ts": "prefer-ours",
|
|
110
|
+
},
|
|
111
|
+
});
|
|
112
|
+
const cfg = parseGitwandrc(json);
|
|
113
|
+
expect(cfg).not.toBeNull();
|
|
114
|
+
expect(cfg.policy).toBe("prefer-safety");
|
|
115
|
+
expect(cfg.patterns?.["*.lock"]).toBe("prefer-theirs");
|
|
116
|
+
});
|
|
117
|
+
it("retourne null pour JSON invalide", () => {
|
|
118
|
+
expect(parseGitwandrc("not json")).toBeNull();
|
|
119
|
+
});
|
|
120
|
+
it("ignore les politiques invalides", () => {
|
|
121
|
+
const json = JSON.stringify({ policy: "unknown-policy" });
|
|
122
|
+
const cfg = parseGitwandrc(json);
|
|
123
|
+
// Ne doit pas crasher, juste ignorer la politique invalide
|
|
124
|
+
expect(cfg).not.toBeNull();
|
|
125
|
+
expect(cfg.policy).toBeUndefined();
|
|
126
|
+
});
|
|
127
|
+
it("parse un objet partiel (seulement policy)", () => {
|
|
128
|
+
const json = JSON.stringify({ policy: "strict" });
|
|
129
|
+
const cfg = parseGitwandrc(json);
|
|
130
|
+
expect(cfg.policy).toBe("strict");
|
|
131
|
+
expect(cfg.patterns).toBeUndefined();
|
|
132
|
+
});
|
|
133
|
+
it("retourne null pour un JSON non-objet", () => {
|
|
134
|
+
expect(parseGitwandrc('"string"')).toBeNull();
|
|
135
|
+
expect(parseGitwandrc("42")).toBeNull();
|
|
136
|
+
expect(parseGitwandrc("null")).toBeNull();
|
|
137
|
+
});
|
|
138
|
+
// ─── P2.4 — generatedFiles ────────────────────────────────
|
|
139
|
+
it("P2.4: parse un tableau generatedFiles valide", () => {
|
|
140
|
+
const json = JSON.stringify({
|
|
141
|
+
generatedFiles: ["**/*.generated.ts", "*.pb.go"],
|
|
142
|
+
});
|
|
143
|
+
const cfg = parseGitwandrc(json);
|
|
144
|
+
expect(cfg.generatedFiles).toEqual(["**/*.generated.ts", "*.pb.go"]);
|
|
145
|
+
});
|
|
146
|
+
it("P2.4: filtre les entrées non-string dans generatedFiles", () => {
|
|
147
|
+
const json = JSON.stringify({
|
|
148
|
+
generatedFiles: ["**/*.gen.ts", 42, null, "", "valid.pattern"],
|
|
149
|
+
});
|
|
150
|
+
const cfg = parseGitwandrc(json);
|
|
151
|
+
expect(cfg.generatedFiles).toEqual(["**/*.gen.ts", "valid.pattern"]);
|
|
152
|
+
});
|
|
153
|
+
it("P2.4: generatedFiles non-array est ignoré", () => {
|
|
154
|
+
const json = JSON.stringify({ generatedFiles: "not an array" });
|
|
155
|
+
const cfg = parseGitwandrc(json);
|
|
156
|
+
expect(cfg.generatedFiles).toBeUndefined();
|
|
157
|
+
});
|
|
158
|
+
it("P2.4: generatedFiles vide ou sans entrée valide → undefined", () => {
|
|
159
|
+
expect(parseGitwandrc(JSON.stringify({ generatedFiles: [] })).generatedFiles).toBeUndefined();
|
|
160
|
+
expect(parseGitwandrc(JSON.stringify({ generatedFiles: [42, null] })).generatedFiles).toBeUndefined();
|
|
161
|
+
});
|
|
162
|
+
});
|
|
163
|
+
// ─── Fixtures pour les tests d'intégration ───────────────
|
|
164
|
+
const WHITESPACE_CONFLICT = `<<<<<<< ours
|
|
165
|
+
function hello() {
|
|
166
|
+
return "world";
|
|
167
|
+
}
|
|
168
|
+
=======
|
|
169
|
+
function hello() {
|
|
170
|
+
return "world";
|
|
171
|
+
}
|
|
172
|
+
>>>>>>> theirs`;
|
|
173
|
+
const VALUE_ONLY_CONFLICT = `<<<<<<< HEAD
|
|
174
|
+
"version": "3.2.1",
|
|
175
|
+
"integrity": "sha512-abc123"
|
|
176
|
+
=======
|
|
177
|
+
"version": "3.3.0",
|
|
178
|
+
"integrity": "sha512-xyz789"
|
|
179
|
+
>>>>>>> master`;
|
|
180
|
+
const NON_OVERLAPPING_CONFLICT = `<<<<<<< ours
|
|
181
|
+
import React from "react";
|
|
182
|
+
import { useState } from "react";
|
|
183
|
+
import { useEffect } from "react";
|
|
184
|
+
import axios from "axios";
|
|
185
|
+
||||||| base
|
|
186
|
+
import React from "react";
|
|
187
|
+
import { useState } from "react";
|
|
188
|
+
import axios from "axios";
|
|
189
|
+
=======
|
|
190
|
+
import React from "react";
|
|
191
|
+
import { useState } from "react";
|
|
192
|
+
import axios from "axios";
|
|
193
|
+
import dayjs from "dayjs";
|
|
194
|
+
>>>>>>> theirs`;
|
|
195
|
+
describe("Phase 7.4 — politiques via resolve()", () => {
|
|
196
|
+
describe("prefer-ours", () => {
|
|
197
|
+
it("whitespace_only : résolution avec ours", () => {
|
|
198
|
+
const result = resolve(WHITESPACE_CONFLICT, "style.css", { policy: "prefer-ours" });
|
|
199
|
+
expect(result.stats.autoResolved).toBe(1);
|
|
200
|
+
});
|
|
201
|
+
it("value_only_change : prend ours (pas theirs)", () => {
|
|
202
|
+
const result = resolve(VALUE_ONLY_CONFLICT, "lock.json", { policy: "prefer-ours" });
|
|
203
|
+
if (result.stats.autoResolved > 0) {
|
|
204
|
+
expect(result.mergedContent).toContain("3.2.1"); // ours
|
|
205
|
+
expect(result.mergedContent).not.toContain("3.3.0"); // pas theirs
|
|
206
|
+
}
|
|
207
|
+
});
|
|
208
|
+
it("la raison mentionne la politique", () => {
|
|
209
|
+
const result = resolve(VALUE_ONLY_CONFLICT, "lock.json", { policy: "prefer-ours" });
|
|
210
|
+
if (result.resolutions[0].autoResolved) {
|
|
211
|
+
expect(result.resolutions[0].resolutionReason).toMatch(/prefer-ours/);
|
|
212
|
+
}
|
|
213
|
+
});
|
|
214
|
+
});
|
|
215
|
+
describe("prefer-theirs (défaut)", () => {
|
|
216
|
+
it("value_only_change : prend theirs", () => {
|
|
217
|
+
const result = resolve(VALUE_ONLY_CONFLICT, "lock.json");
|
|
218
|
+
if (result.stats.autoResolved > 0) {
|
|
219
|
+
expect(result.mergedContent).toContain("3.3.0"); // theirs
|
|
220
|
+
expect(result.mergedContent).not.toContain("3.2.1"); // pas ours
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
});
|
|
224
|
+
describe("prefer-merge", () => {
|
|
225
|
+
it("résout non_overlapping normalement", () => {
|
|
226
|
+
const result = resolve(NON_OVERLAPPING_CONFLICT, "imports.ts", { policy: "prefer-merge" });
|
|
227
|
+
expect(result.stats.autoResolved).toBe(1);
|
|
228
|
+
});
|
|
229
|
+
it("accepte les hunks de confiance medium", () => {
|
|
230
|
+
// Un conflit whitespace sans base (diff2) → confidence: medium
|
|
231
|
+
const diff2ws = `<<<<<<< HEAD
|
|
232
|
+
function foo() {
|
|
233
|
+
return 1;
|
|
234
|
+
}
|
|
235
|
+
=======
|
|
236
|
+
function foo() {
|
|
237
|
+
return 1;
|
|
238
|
+
}
|
|
239
|
+
>>>>>>> master`;
|
|
240
|
+
const resultStrict = resolve(diff2ws, "f.ts", { policy: "strict" });
|
|
241
|
+
const resultMerge = resolve(diff2ws, "f.ts", { policy: "prefer-merge" });
|
|
242
|
+
// prefer-merge doit résoudre plus (ou autant) que strict
|
|
243
|
+
expect(resultMerge.stats.autoResolved).toBeGreaterThanOrEqual(resultStrict.stats.autoResolved);
|
|
244
|
+
});
|
|
245
|
+
});
|
|
246
|
+
describe("prefer-safety", () => {
|
|
247
|
+
it("ne résout pas whitespace_only", () => {
|
|
248
|
+
const result = resolve(WHITESPACE_CONFLICT, "style.css", { policy: "prefer-safety" });
|
|
249
|
+
expect(result.stats.autoResolved).toBe(0);
|
|
250
|
+
expect(result.resolutions[0].resolutionReason).toMatch(/prefer-safety/);
|
|
251
|
+
});
|
|
252
|
+
it("ne résout pas value_only_change", () => {
|
|
253
|
+
const result = resolve(VALUE_ONLY_CONFLICT, "lock.json", { policy: "prefer-safety" });
|
|
254
|
+
expect(result.stats.autoResolved).toBe(0);
|
|
255
|
+
expect(result.resolutions[0].resolutionReason).toMatch(/prefer-safety/);
|
|
256
|
+
});
|
|
257
|
+
it("résout quand même same_change", () => {
|
|
258
|
+
const sameChange = `import { useState } from "react";
|
|
259
|
+
<<<<<<< ours
|
|
260
|
+
import { useEffect } from "react";
|
|
261
|
+
||||||| base
|
|
262
|
+
=======
|
|
263
|
+
import { useEffect } from "react";
|
|
264
|
+
>>>>>>> theirs
|
|
265
|
+
export default function App() {}`;
|
|
266
|
+
const result = resolve(sameChange, "App.tsx", { policy: "prefer-safety" });
|
|
267
|
+
expect(result.stats.autoResolved).toBe(1);
|
|
268
|
+
});
|
|
269
|
+
});
|
|
270
|
+
describe("strict", () => {
|
|
271
|
+
it("ne résout pas non_overlapping", () => {
|
|
272
|
+
const result = resolve(NON_OVERLAPPING_CONFLICT, "imports.ts", { policy: "strict" });
|
|
273
|
+
expect(result.stats.autoResolved).toBe(0);
|
|
274
|
+
expect(result.resolutions[0].resolutionReason).toMatch(/strict/);
|
|
275
|
+
});
|
|
276
|
+
it("résout one_side_change", () => {
|
|
277
|
+
const oneSide = `const config = {
|
|
278
|
+
<<<<<<< ours
|
|
279
|
+
port: 3000,
|
|
280
|
+
host: "localhost",
|
|
281
|
+
||||||| base
|
|
282
|
+
port: 3000,
|
|
283
|
+
=======
|
|
284
|
+
port: 3000,
|
|
285
|
+
>>>>>>> theirs
|
|
286
|
+
};`;
|
|
287
|
+
const result = resolve(oneSide, "config.ts", { policy: "strict" });
|
|
288
|
+
expect(result.stats.autoResolved).toBe(1);
|
|
289
|
+
});
|
|
290
|
+
});
|
|
291
|
+
describe("patternOverrides", () => {
|
|
292
|
+
it("override par pattern pour les lockfiles", () => {
|
|
293
|
+
// En prefer-safety, value_only_change n'est pas résolu
|
|
294
|
+
// Mais avec un override *.lock → prefer-theirs, il devrait l'être
|
|
295
|
+
const result = resolve(VALUE_ONLY_CONFLICT, "yarn.lock", {
|
|
296
|
+
policy: "prefer-safety",
|
|
297
|
+
patternOverrides: { "*.lock": "prefer-theirs" },
|
|
298
|
+
});
|
|
299
|
+
// La politique "prefer-theirs" permet value_only_change
|
|
300
|
+
if (result.hunks[0]?.type === "value_only_change") {
|
|
301
|
+
expect(result.stats.autoResolved).toBe(1);
|
|
302
|
+
expect(result.resolutions[0].resolutionReason).toMatch(/prefer-theirs/);
|
|
303
|
+
}
|
|
304
|
+
});
|
|
305
|
+
it("les fichiers non-matchés gardent la politique globale", () => {
|
|
306
|
+
const result = resolve(VALUE_ONLY_CONFLICT, "config.ts", {
|
|
307
|
+
policy: "prefer-safety",
|
|
308
|
+
patternOverrides: { "*.lock": "prefer-theirs" },
|
|
309
|
+
});
|
|
310
|
+
// config.ts ne matche pas *.lock → prefer-safety → value_only skippé
|
|
311
|
+
if (result.hunks[0]?.type === "value_only_change") {
|
|
312
|
+
expect(result.stats.autoResolved).toBe(0);
|
|
313
|
+
}
|
|
314
|
+
});
|
|
315
|
+
});
|
|
316
|
+
});
|
|
317
|
+
//# sourceMappingURL=config.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.test.js","sourceRoot":"","sources":["../../src/__tests__/config.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GitWand — Corpus de conflits de référence
|
|
3
|
+
*
|
|
4
|
+
* Phase 7.5 : 20 fixtures réalistes couvrant tous les types de conflit,
|
|
5
|
+
* les deux formats (diff2 / diff3), et différents types de fichiers.
|
|
6
|
+
*
|
|
7
|
+
* Chaque fixture définit :
|
|
8
|
+
* - `input` : le fichier avec marqueurs de conflit
|
|
9
|
+
* - `expectedType` : le type attendu (ex: "same_change")
|
|
10
|
+
* - `expectedResolved`: si le moteur doit auto-résoudre
|
|
11
|
+
* - `expectedOutput` : le contenu attendu après résolution (optionnel)
|
|
12
|
+
* - `category` : famille du conflit
|
|
13
|
+
*/
|
|
14
|
+
import type { ConflictType, GitWandOptions } from "../types.js";
|
|
15
|
+
export interface CorpusFixture {
|
|
16
|
+
id: string;
|
|
17
|
+
description: string;
|
|
18
|
+
filePath: string;
|
|
19
|
+
input: string;
|
|
20
|
+
expectedType: ConflictType;
|
|
21
|
+
expectedResolved: boolean;
|
|
22
|
+
/** Contenu mergé attendu (null = non résolu, undefined = ne pas vérifier) */
|
|
23
|
+
expectedOutput?: string | null;
|
|
24
|
+
category: "trivial" | "structural" | "semantic" | "format-aware" | "complex";
|
|
25
|
+
options?: GitWandOptions;
|
|
26
|
+
}
|
|
27
|
+
export declare const CORPUS: CorpusFixture[];
|
|
28
|
+
/** Résumé par catégorie */
|
|
29
|
+
export declare const CORPUS_CATEGORIES: {
|
|
30
|
+
trivial: CorpusFixture[];
|
|
31
|
+
structural: CorpusFixture[];
|
|
32
|
+
semantic: CorpusFixture[];
|
|
33
|
+
"format-aware": CorpusFixture[];
|
|
34
|
+
complex: CorpusFixture[];
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=corpus.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"corpus.d.ts","sourceRoot":"","sources":["../../src/__tests__/corpus.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,KAAK,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAIhE,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,YAAY,CAAC;IAC3B,gBAAgB,EAAE,OAAO,CAAC;IAC1B,6EAA6E;IAC7E,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,SAAS,GAAG,YAAY,GAAG,UAAU,GAAG,cAAc,GAAG,SAAS,CAAC;IAC7E,OAAO,CAAC,EAAE,cAAc,CAAC;CAC1B;AAmiBD,eAAO,MAAM,MAAM,EAAE,aAAa,EAKjC,CAAC;AAEF,2BAA2B;AAC3B,eAAO,MAAM,iBAAiB;;;;;;CAM7B,CAAC"}
|