Fix #962, 5.0: Add item by identifier in collection

Also adds a test for this, but lookup tests are disabled
until #699 is resolved.
This commit is contained in:
Dan Stillman 2016-04-24 04:28:56 -04:00
parent 425c86ca5e
commit 6a47d1dc44
2 changed files with 49 additions and 39 deletions

View file

@ -7,18 +7,17 @@ function lookupIdentifier(win, identifier) {
describe.skip("Add Item by Identifier", function() {
var win;
before(function() {
this.timeout(5000);
// Load a Zotero pane and update the translators (needed to
// make sure they're available before we run the tests)
return loadZoteroPane().then(function(w) {
win = w;
});
before(function* () {
win = yield loadZoteroPane();
});
after(function() {
win.close();
});
// TODO: mock external services: https://github.com/zotero/zotero/issues/699
it("should add an ISBN-10", function() {
this.timeout(20000);
return lookupIdentifier(win, "0838985890").then(function(ids) {
@ -26,6 +25,7 @@ describe.skip("Add Item by Identifier", function() {
assert.equal(item.getField("title"), "Zotero: a guide for librarians, researchers, and educators");
});
});
it("should add an ISBN-13", function() {
this.timeout(20000);
return lookupIdentifier(win, "978-0838985892").then(function(ids) {
@ -33,6 +33,7 @@ describe.skip("Add Item by Identifier", function() {
assert.equal(item.getField("title"), "Zotero: a guide for librarians, researchers, and educators");
});
});
it("should add a DOI", function() {
this.timeout(10000);
return lookupIdentifier(win, "10.4103/0976-500X.85940").then(function(ids) {
@ -40,6 +41,7 @@ describe.skip("Add Item by Identifier", function() {
assert.equal(item.getField("title"), "Zotero: A bibliographic assistant to researcher");
});
});
it("should add a PMID", function() {
this.timeout(10000);
return lookupIdentifier(win, "24297125").then(function(ids) {
@ -47,4 +49,16 @@ describe.skip("Add Item by Identifier", function() {
assert.equal(item.getField("title"), "Taking control of your digital library: how modern citation managers do more than just referencing");
});
});
it("should add an item within a collection", function* () {
this.timeout(10000);
var col = yield createDataObject('collection');
yield waitForItemsLoad(win);
var ids = yield lookupIdentifier(win, "10.4103/0976-500X.85940");
var item = Zotero.Items.get(ids[0]);
assert.equal(item.getField("title"), "Zotero: A bibliographic assistant to researcher");
assert.isTrue(item.inCollection(col.id));
});
});