Refactor diff_spec.js to use table-based tests
This commit is contained in:
parent
61d08f575c
commit
f23737a498
1 changed files with 42 additions and 45 deletions
|
@ -9,60 +9,57 @@ describe('Multi-file editor library diff calculator', () => {
|
|||
});
|
||||
|
||||
describe('modified', () => {
|
||||
it('', () => {
|
||||
const diff = computeDiff('123', '1234')[0];
|
||||
it.each`
|
||||
originalContent | newContent | lineNumber
|
||||
${'123'} | ${'1234'} | ${1}
|
||||
${'123\n123\n123'} | ${'123\n1234\n123'} | ${2}
|
||||
`(
|
||||
'marks line $lineNumber as added and modified but not removed',
|
||||
({ originalContent, newContent, lineNumber }) => {
|
||||
const diff = computeDiff(originalContent, newContent)[0];
|
||||
|
||||
expect(diff.added).toBeTruthy();
|
||||
expect(diff.modified).toBeTruthy();
|
||||
expect(diff.removed).toBeUndefined();
|
||||
});
|
||||
|
||||
it('', () => {
|
||||
const diff = computeDiff('123\n123\n123', '123\n1234\n123')[0];
|
||||
|
||||
expect(diff.added).toBeTruthy();
|
||||
expect(diff.modified).toBeTruthy();
|
||||
expect(diff.removed).toBeUndefined();
|
||||
expect(diff.lineNumber).toBe(2);
|
||||
});
|
||||
expect(diff.lineNumber).toBe(lineNumber);
|
||||
},
|
||||
);
|
||||
});
|
||||
|
||||
describe('added', () => {
|
||||
it('', () => {
|
||||
const diff = computeDiff('123', '123\n123')[0];
|
||||
it.each`
|
||||
originalContent | newContent | lineNumber
|
||||
${'123'} | ${'123\n123'} | ${1}
|
||||
${'123\n123\n123'} | ${'123\n123\n1234\n123'} | ${3}
|
||||
`(
|
||||
'marks line $lineNumber as added but not modified and not removed',
|
||||
({ originalContent, newContent, lineNumber }) => {
|
||||
const diff = computeDiff(originalContent, newContent)[0];
|
||||
|
||||
expect(diff.added).toBeTruthy();
|
||||
expect(diff.modified).toBeUndefined();
|
||||
expect(diff.removed).toBeUndefined();
|
||||
});
|
||||
|
||||
it('', () => {
|
||||
const diff = computeDiff('123\n123\n123', '123\n123\n1234\n123')[0];
|
||||
|
||||
expect(diff.added).toBeTruthy();
|
||||
expect(diff.modified).toBeUndefined();
|
||||
expect(diff.removed).toBeUndefined();
|
||||
expect(diff.lineNumber).toBe(3);
|
||||
});
|
||||
expect(diff.lineNumber).toBe(lineNumber);
|
||||
},
|
||||
);
|
||||
});
|
||||
|
||||
describe('removed', () => {
|
||||
it('', () => {
|
||||
const diff = computeDiff('123', '')[0];
|
||||
it.each`
|
||||
originalContent | newContent | lineNumber | modified
|
||||
${'123'} | ${''} | ${1} | ${undefined}
|
||||
${'123\n123\n123'} | ${'123\n123'} | ${2} | ${true}
|
||||
`(
|
||||
'marks line $lineNumber as removed',
|
||||
({ originalContent, newContent, lineNumber, modified }) => {
|
||||
const diff = computeDiff(originalContent, newContent)[0];
|
||||
|
||||
expect(diff.added).toBeUndefined();
|
||||
expect(diff.modified).toBeUndefined();
|
||||
expect(diff.modified).toBe(modified);
|
||||
expect(diff.removed).toBeTruthy();
|
||||
});
|
||||
|
||||
it('', () => {
|
||||
const diff = computeDiff('123\n123\n123', '123\n123')[0];
|
||||
|
||||
expect(diff.added).toBeUndefined();
|
||||
expect(diff.modified).toBeTruthy();
|
||||
expect(diff.removed).toBeTruthy();
|
||||
expect(diff.lineNumber).toBe(2);
|
||||
});
|
||||
expect(diff.lineNumber).toBe(lineNumber);
|
||||
},
|
||||
);
|
||||
});
|
||||
|
||||
it('includes line number of change', () => {
|
||||
|
|
Loading…
Reference in a new issue