提交 a4c9fed9 编写于 作者: J Johannes Rieken

test for bad concurrent edits, test for subsequent good edits

上级 891852a7
......@@ -47,7 +47,7 @@ export class ExtHostDocumentSaveParticipant {
};
}
$participateInSave(resource: URI): TPromise<any> {
$participateInSave(resource: URI): TPromise<any[]> {
const entries = this._callbacks.entries();
return sequence(entries.map(([fn, thisArg]) => {
......@@ -106,8 +106,8 @@ export class ExtHostDocumentSaveParticipant {
return this._workspace.$applyWorkspaceEdit(edits);
}
// TODO@joh - fail?
console.warn('IGNORING changes because document has changed while computing changes');
// TODO@joh bubble this to listener?
return new Error('ignoring change because of concurrent edits');
}, err => {
// ignore error
......
......@@ -177,4 +177,82 @@ suite('ExtHostDocumentSaveParticipant', () => {
assert.equal(edits.length, 1);
});
});
test('event delivery, concurrent change', () => {
let edits: IResourceEdit[];
const participant = new ExtHostDocumentSaveParticipant(documents, new class extends MainThreadWorkspaceShape {
$applyWorkspaceEdit(_edits) {
edits = _edits;
return TPromise.as(true);
}
});
let sub = participant.onWillSaveTextDocumentEvent(function (e) {
// concurrent change from somewhere
documents.$acceptModelChanged(resource.toString(), [{
versionId: 2,
range: { startLineNumber: 1, startColumn: 1, endLineNumber: 1, endColumn: 1 },
text: 'bar',
rangeLength: undefined, eol: undefined, isRedoing: undefined, isUndoing: undefined,
}]);
e.waitUntil(TPromise.as([TextEdit.insert(new Position(0, 0), 'bar')]));
});
return participant.$participateInSave(resource).then(values => {
sub.dispose();
assert.equal(edits, undefined);
assert.ok((<Error>values[0]).message);
});
});
test('event delivery, two listeners -> two document states', () => {
const participant = new ExtHostDocumentSaveParticipant(documents, new class extends MainThreadWorkspaceShape {
$applyWorkspaceEdit(_edits: IResourceEdit[]) {
for (const {resource, newText, range} of _edits) {
documents.$acceptModelChanged(resource.toString(), [{
range,
text: newText,
versionId: documents.getDocumentData(resource).version + 1,
rangeLength: undefined, eol: undefined, isRedoing: undefined, isUndoing: undefined,
}]);
}
return TPromise.as(true);
}
});
const document = documents.getDocumentData(resource).document;
let sub1 = participant.onWillSaveTextDocumentEvent(function (e) {
// the document state we started with
assert.equal(document.version, 1);
assert.equal(document.getText(), 'foo');
e.waitUntil(TPromise.as([TextEdit.insert(new Position(0, 0), 'bar')]));
});
let sub2 = participant.onWillSaveTextDocumentEvent(function (e) {
// the document state AFTER the first listener kicked in
assert.equal(document.version, 2);
assert.equal(document.getText(), 'barfoo');
e.waitUntil(TPromise.as([TextEdit.insert(new Position(0, 0), 'bar')]));
});
return participant.$participateInSave(resource).then(values => {
sub1.dispose();
sub2.dispose();
// the document state AFTER eventing is done
assert.equal(document.version, 3);
assert.equal(document.getText(), 'barbarfoo');
});
});
});
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册