63f54d3184
Continue to Zotero.launchFile() as intended. https://forums.zotero.org/discussion/113179/pdfs-will-not-open-in-system-reader-when-double-clicked
147 lines
4.5 KiB
JavaScript
147 lines
4.5 KiB
JavaScript
describe("Zotero.FileHandlers", () => {
|
|
describe("open()", () => {
|
|
var win;
|
|
|
|
function clearPrefs() {
|
|
Zotero.Prefs.clear('fileHandler.pdf');
|
|
Zotero.Prefs.clear('fileHandler.epub');
|
|
Zotero.Prefs.clear('fileHandler.snapshot');
|
|
Zotero.Prefs.clear('openReaderInNewWindow');
|
|
}
|
|
|
|
before(async function () {
|
|
clearPrefs();
|
|
win = await loadZoteroPane();
|
|
});
|
|
|
|
afterEach(function () {
|
|
clearPrefs();
|
|
delete Zotero.FileHandlers._mockHandlers;
|
|
for (let reader of Zotero.Reader._readers) {
|
|
reader.close();
|
|
}
|
|
});
|
|
|
|
after(async function () {
|
|
win.close();
|
|
});
|
|
|
|
it("should open a PDF internally when no handler is set", async function () {
|
|
let pdf = await importFileAttachment('wonderland_short.pdf');
|
|
await Zotero.FileHandlers.open(pdf, {
|
|
location: { pageIndex: 2 }
|
|
});
|
|
let reader = Zotero.Reader.getByTabID(win.Zotero_Tabs.selectedID);
|
|
assert.ok(reader);
|
|
|
|
let notifierPromise = waitForNotifierEvent('add', 'setting');
|
|
await reader._waitForReader();
|
|
await notifierPromise;
|
|
|
|
// Check that the reader navigated to the correct page
|
|
assert.equal(pdf.getAttachmentLastPageIndex(), 2);
|
|
});
|
|
|
|
it("should open a PDF in a new window when no handler is set and openInWindow is passed", async function () {
|
|
let pdf = await importFileAttachment('wonderland_short.pdf');
|
|
await Zotero.FileHandlers.open(pdf, {
|
|
location: { pageIndex: 2 },
|
|
openInWindow: true
|
|
});
|
|
assert.notOk(Zotero.Reader.getByTabID(win.Zotero_Tabs.selectedID));
|
|
assert.isNotEmpty(Zotero.Reader.getWindowStates());
|
|
});
|
|
|
|
it("should use matching handler", async function () {
|
|
let pdf = await importFileAttachment('wonderland_short.pdf');
|
|
let wasRun = false;
|
|
let readerOpenSpy = sinon.spy(Zotero.Reader, 'open');
|
|
Zotero.FileHandlers._mockHandlers = {
|
|
pdf: [
|
|
{
|
|
name: /mock/,
|
|
async open() {
|
|
wasRun = true;
|
|
}
|
|
}
|
|
]
|
|
};
|
|
Zotero.Prefs.set('fileHandler.pdf', 'mock');
|
|
|
|
await Zotero.FileHandlers.open(pdf);
|
|
assert.isTrue(wasRun);
|
|
assert.isFalse(readerOpenSpy.called);
|
|
assert.notOk(Zotero.Reader.getByTabID(win.Zotero_Tabs.selectedID));
|
|
assert.isEmpty(Zotero.Reader.getWindowStates());
|
|
|
|
readerOpenSpy.restore();
|
|
});
|
|
|
|
it("should fall back to fallback handler when location is passed", async function () {
|
|
let pdf = await importFileAttachment('wonderland_short.pdf');
|
|
let wasRun = false;
|
|
let readerOpenSpy = sinon.spy(Zotero.Reader, 'open');
|
|
Zotero.FileHandlers._mockHandlers = {
|
|
pdf: [
|
|
{
|
|
name: /mock/,
|
|
fallback: true,
|
|
async open(appPath) {
|
|
assert.notOk(appPath); // appPath won't be set when called as fallback
|
|
wasRun = true;
|
|
}
|
|
}
|
|
]
|
|
};
|
|
|
|
// Set our custom handler to something nonexistent,
|
|
// and stub the system handler to something nonexistent as well
|
|
Zotero.Prefs.set('fileHandler.pdf', 'some nonexistent tool');
|
|
let getSystemHandlerStub = sinon.stub(Zotero.FileHandlers, '_getSystemHandler');
|
|
getSystemHandlerStub.returns('some other nonexistent tool');
|
|
|
|
await Zotero.FileHandlers.open(pdf, { location: {} });
|
|
assert.isTrue(wasRun);
|
|
assert.isFalse(readerOpenSpy.called);
|
|
assert.notOk(Zotero.Reader.getByTabID(win.Zotero_Tabs.selectedID));
|
|
assert.isEmpty(Zotero.Reader.getWindowStates());
|
|
|
|
readerOpenSpy.restore();
|
|
getSystemHandlerStub.restore();
|
|
});
|
|
|
|
it("should fall back when handler is set to system and we can't retrieve the system handler", async function () {
|
|
let pdf = await importFileAttachment('wonderland_short.pdf');
|
|
let wasRun = false;
|
|
let readerOpenSpy = sinon.spy(Zotero.Reader, 'open');
|
|
let launchFileStub = sinon.stub(Zotero, 'launchFile');
|
|
Zotero.FileHandlers._mockHandlers = {
|
|
pdf: [
|
|
{
|
|
name: new RegExp(''),
|
|
async open() {
|
|
wasRun = true;
|
|
}
|
|
}
|
|
]
|
|
};
|
|
|
|
// Set our custom handler to something nonexistent,
|
|
// and stub the system handler to something nonexistent as well
|
|
Zotero.Prefs.set('fileHandler.pdf', 'system');
|
|
let getSystemHandlerStub = sinon.stub(Zotero.FileHandlers, '_getSystemHandler');
|
|
getSystemHandlerStub.returns(false);
|
|
|
|
await Zotero.FileHandlers.open(pdf, { location: {} });
|
|
assert.isFalse(wasRun);
|
|
assert.isFalse(readerOpenSpy.called);
|
|
assert.isTrue(launchFileStub.called);
|
|
assert.notOk(Zotero.Reader.getByTabID(win.Zotero_Tabs.selectedID));
|
|
assert.isEmpty(Zotero.Reader.getWindowStates());
|
|
|
|
readerOpenSpy.restore();
|
|
launchFileStub.restore();
|
|
getSystemHandlerStub.restore();
|
|
});
|
|
});
|
|
});
|