Merge branch 'Juris-M-zmaster-test-implicit-update'

This commit is contained in:
Adomas Venčkauskas 2019-02-13 10:18:26 +02:00
commit 4a61cffc99

View file

@ -448,7 +448,7 @@ describe("Zotero.Integration", function () {
} }
}); });
it('should insert citation if not in field', insertMultipleCitations); it('should insert citation if not in field', insertMultipleCitations);
it('should edit citation if in citation field', function* () { it('should edit citation if in citation field', function* () {
yield insertMultipleCitations.call(this); yield insertMultipleCitations.call(this);
var docID = this.test.fullTitle(); var docID = this.test.fullTitle();
@ -465,6 +465,59 @@ describe("Zotero.Integration", function () {
assert.equal(citation.citationItems[0].id, testItems[3].id); assert.equal(citation.citationItems[0].id, testItems[3].id);
}); });
it('should write an implicitly updated citation into the document', function* () {
yield insertMultipleCitations.call(this);
var docID = this.test.fullTitle();
var doc = applications[docID].doc;
testItems[3].setCreator(0, {creatorType: 'author', lastName: 'Smith', firstName: 'Robert'});
testItems[3].setField('date', '2019-01-01');
setAddEditItems(testItems[3]);
yield execCommand('addEditCitation', docID);
assert.equal(doc.fields[2].text, "(Smith, 2019)");
sinon.stub(doc, 'cursorInField').resolves(doc.fields[0]);
sinon.stub(doc, 'canInsertField').resolves(false);
testItems[4].setCreator(0, {creatorType: 'author', lastName: 'Smith', firstName: 'Robert'});
testItems[4].setField('date', '2019-01-01');
setAddEditItems(testItems[4]);
yield execCommand('addEditCitation', docID);
assert.equal(doc.fields.length, 3);
assert.equal(doc.fields[0].text, "(Smith, 2019a)");
assert.equal(doc.fields[2].text, "(Smith, 2019b)");
});
it('should place an implicitly updated citation correctly after multiple new insertions', function* () {
yield insertMultipleCitations.call(this);
var docID = this.test.fullTitle();
var doc = applications[docID].doc;
testItems[3].setCreator(0, {creatorType: 'author', lastName: 'Smith', firstName: 'Robert'});
testItems[3].setField('date', '2019-01-01');
setAddEditItems(testItems[3]);
yield execCommand('addEditCitation', docID);
assert.equal(doc.fields[2].text, "(Smith, 2019)");
sinon.stub(doc, 'cursorInField').resolves(doc.fields[0]);
sinon.stub(doc, 'canInsertField').resolves(false);
doc.fields[1].code = doc.fields[0].code;
doc.fields[1].text = doc.fields[0].text;
testItems[4].setCreator(0, {creatorType: 'author', lastName: 'Smith', firstName: 'Robert'});
testItems[4].setField('date', '2019-01-01');
setAddEditItems(testItems[4]);
yield execCommand('addEditCitation', docID);
assert.equal(doc.fields.length, 3);
assert.equal(doc.fields[0].text, "(Smith, 2019a)");
assert.equal(doc.fields[2].text, "(Smith, 2019b)");
});
it('should update bibliography if present', function* () { it('should update bibliography if present', function* () {
yield insertMultipleCitations.call(this); yield insertMultipleCitations.call(this);
var docID = this.test.fullTitle(); var docID = this.test.fullTitle();