-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore: remove duplicate suffix lines in postprocess filter
- Loading branch information
Showing
3 changed files
with
113 additions
and
165 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
246 changes: 107 additions & 139 deletions
246
clients/tabby-agent/src/codeCompletion/postprocess/removeDuplicateSuffixLines.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,152 +1,120 @@ | ||
import { documentContext, inline, assertFilterResult } from "./testUtils"; | ||
import { removeDuplicateSuffixLines } from "./removeDuplicateSuffixLines"; | ||
|
||
describe("postprocess", () => { | ||
describe("removeDuplicateSuffixLines", () => { | ||
const filter = removeDuplicateSuffixLines(); | ||
describe("removeDuplicateSuffixLines", () => { | ||
const filter = removeDuplicateSuffixLines(); | ||
|
||
it("should remove duplicated suffix lines", async () => { | ||
const context = documentContext` | ||
function example() { | ||
const items = [ | ||
║ | ||
]; | ||
} | ||
`; | ||
context.language = "javascript"; | ||
const completion = inline` | ||
├1, | ||
2, | ||
3, | ||
4,┤ | ||
`; | ||
context.suffix = ` | ||
4, | ||
5, | ||
6 | ||
]; | ||
} | ||
`; | ||
const expected = inline` | ||
├1, | ||
2, | ||
3,┤ | ||
`; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
|
||
it("should handle empty suffix", async () => { | ||
const context = documentContext` | ||
const value = ║ | ||
`; | ||
context.language = "javascript"; | ||
const completion = inline` | ||
├42;┤ | ||
`; | ||
context.suffix = ""; | ||
const expected = completion; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
it("should remove duplicated array item", async () => { | ||
const context = documentContext` | ||
const items = [ | ||
║ | ||
{ id: 2 }, | ||
{ id: 3 } | ||
]; | ||
`; | ||
const completion = inline` | ||
├{ id: 1 }, | ||
{ id: 2 },┤ | ||
`; | ||
const expected = inline` | ||
├{ id: 1 },┤ | ||
`; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
|
||
it("should handle multiple line matches", async () => { | ||
const context = documentContext` | ||
class Example { | ||
constructor() { | ||
║ | ||
} | ||
} | ||
`; | ||
context.language = "javascript"; | ||
const completion = inline` | ||
├this.value = 1; | ||
this.name = "test"; | ||
this.items = []; | ||
this.setup();┤ | ||
`; | ||
context.suffix = ` | ||
this.setup(); | ||
this.init(); | ||
} | ||
} | ||
`; | ||
const expected = inline` | ||
├this.value = 1; | ||
this.name = "test"; | ||
this.items = [];┤ | ||
`; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
it("should handle empty content after cursor", async () => { | ||
const context = documentContext` | ||
const a = ║ | ||
`; | ||
const completion = inline` | ||
├42;┤ | ||
`; | ||
const expected = completion; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
|
||
it("should handle partial line matches without trimming", async () => { | ||
const context = documentContext` | ||
const config = { | ||
it("should remove duplicated comma items", async () => { | ||
const context = documentContext` | ||
function example() { | ||
const items = [ | ||
║ | ||
}; | ||
`; | ||
context.language = "javascript"; | ||
const completion = inline` | ||
├name: "test", | ||
value: 42, | ||
items: [], | ||
enabled: true,┤ | ||
`; | ||
context.suffix = ` | ||
enabled: true, | ||
debug: false | ||
}; | ||
`; | ||
const expected = inline` | ||
├name: "test", | ||
value: 42, | ||
items: [],┤ | ||
`; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
4, | ||
5, | ||
6 | ||
]; | ||
} | ||
`; | ||
const completion = inline` | ||
├1, | ||
2, | ||
3, | ||
4,┤ | ||
`; | ||
const expected = inline` | ||
├1, | ||
2, | ||
3,┤ | ||
`; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
|
||
it("should not modify when no matches found", async () => { | ||
const context = documentContext` | ||
function process() { | ||
it("should remove duplicate method calls", async () => { | ||
const context = documentContext` | ||
class Example { | ||
constructor() { | ||
║ | ||
this.setup(); | ||
this.init() | ||
} | ||
`; | ||
context.language = "javascript"; | ||
const completion = inline` | ||
├console.log("processing"); | ||
return true;┤ | ||
`; | ||
context.suffix = ` | ||
console.log("done"); | ||
} | ||
`; | ||
const expected = completion; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
} | ||
`; | ||
const completion = inline` | ||
├this.value = 1; | ||
this.name = "test"; | ||
this.items = []; | ||
this.setup();┤ | ||
`; | ||
const expected = inline` | ||
├this.value = 1; | ||
this.name = "test"; | ||
this.items = [];┤ | ||
`; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
|
||
it("should handle whitespace differences", async () => { | ||
const context = documentContext` | ||
const arr = [ | ||
║ | ||
]; | ||
`; | ||
context.language = "javascript"; | ||
const completion = inline` | ||
├1, | ||
2, | ||
3, | ||
4,┤ | ||
`; | ||
context.suffix = ` | ||
4, | ||
5, | ||
6 | ||
]; | ||
`; | ||
const expected = inline` | ||
├1, | ||
2, | ||
3,┤ | ||
`; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
it("should remove duplicate object properties", async () => { | ||
const context = documentContext` | ||
const config = { | ||
║ | ||
enabled: true, | ||
debug: false | ||
}; | ||
`; | ||
const completion = inline` | ||
├name: "test", | ||
value: 42, | ||
items: [], | ||
enabled: true,┤ | ||
`; | ||
const expected = inline` | ||
├name: "test", | ||
value: 42, | ||
items: [],┤ | ||
`; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
|
||
it("should keep content when no matches", async () => { | ||
const context = documentContext` | ||
function process() { | ||
║ | ||
console.log("done"); | ||
} | ||
`; | ||
const completion = inline` | ||
├console.log("processing");┤ | ||
`; | ||
const expected = completion; | ||
await assertFilterResult(filter, context, completion, expected); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters