|
1 /* Any copyright is dedicated to the Public Domain. |
|
2 * http://creativecommons.org/publicdomain/zero/1.0/ */ |
|
3 |
|
4 const RELATIVE_DIR = "browser/extensions/pdfjs/test/"; |
|
5 const TESTROOT = "http://example.com/browser/" + RELATIVE_DIR; |
|
6 |
|
7 function test() { |
|
8 var tab; |
|
9 |
|
10 let handlerService = Cc["@mozilla.org/uriloader/handler-service;1"].getService(Ci.nsIHandlerService); |
|
11 let mimeService = Cc["@mozilla.org/mime;1"].getService(Ci.nsIMIMEService); |
|
12 let handlerInfo = mimeService.getFromTypeAndExtension('application/pdf', 'pdf'); |
|
13 |
|
14 // Make sure pdf.js is the default handler. |
|
15 is(handlerInfo.alwaysAskBeforeHandling, false, 'pdf handler defaults to always-ask is false'); |
|
16 is(handlerInfo.preferredAction, Ci.nsIHandlerInfo.handleInternally, 'pdf handler defaults to internal'); |
|
17 |
|
18 info('Pref action: ' + handlerInfo.preferredAction); |
|
19 |
|
20 waitForExplicitFinish(); |
|
21 registerCleanupFunction(function() { |
|
22 gBrowser.removeTab(tab); |
|
23 }); |
|
24 |
|
25 tab = gBrowser.addTab(TESTROOT + "file_pdfjs_test.pdf"); |
|
26 var newTabBrowser = gBrowser.getBrowserForTab(tab); |
|
27 newTabBrowser.addEventListener("load", function eventHandler() { |
|
28 newTabBrowser.removeEventListener("load", eventHandler, true); |
|
29 |
|
30 var document = newTabBrowser.contentDocument, |
|
31 window = newTabBrowser.contentWindow; |
|
32 |
|
33 // Runs tests after all 'load' event handlers have fired off |
|
34 window.addEventListener("documentload", function() { |
|
35 runTests(document, window, finish); |
|
36 }, false, true); |
|
37 }, true); |
|
38 } |
|
39 |
|
40 function runTests(document, window, callback) { |
|
41 // check that PDF is opened with internal viewer |
|
42 ok(document.querySelector('div#viewer'), "document content has viewer UI"); |
|
43 ok('PDFJS' in window.wrappedJSObject, "window content has PDFJS object"); |
|
44 |
|
45 //open sidebar |
|
46 var sidebar = document.querySelector('button#sidebarToggle'); |
|
47 var outerContainer = document.querySelector('div#outerContainer'); |
|
48 |
|
49 sidebar.click(); |
|
50 ok(outerContainer.classList.contains('sidebarOpen'), 'sidebar opens on click'); |
|
51 |
|
52 // check that thumbnail view is open |
|
53 var thumbnailView = document.querySelector('div#thumbnailView'); |
|
54 var outlineView = document.querySelector('div#outlineView'); |
|
55 |
|
56 is(thumbnailView.getAttribute('class'), null, 'Initial view is thumbnail view'); |
|
57 is(outlineView.getAttribute('class'), 'hidden', 'Outline view is hidden initially'); |
|
58 |
|
59 //switch to outline view |
|
60 var viewOutlineButton = document.querySelector('button#viewOutline'); |
|
61 viewOutlineButton.click(); |
|
62 |
|
63 is(outlineView.getAttribute('class'), '', 'Outline view is visible when selected'); |
|
64 is(thumbnailView.getAttribute('class'), 'hidden', 'Thumbnail view is hidden when outline is selected'); |
|
65 |
|
66 //switch back to thumbnail view |
|
67 var viewThumbnailButton = document.querySelector('button#viewThumbnail'); |
|
68 viewThumbnailButton.click(); |
|
69 |
|
70 is(thumbnailView.getAttribute('class'), '', 'Thumbnail view is visible when selected'); |
|
71 is(outlineView.getAttribute('class'), 'hidden', 'Outline view is hidden when thumbnail is selected'); |
|
72 |
|
73 sidebar.click(); |
|
74 |
|
75 callback(); |
|
76 } |