Implement a basic unit test for the find controller
This commit shows that we can now unit test the find controller and that executing regular queries works. Note that this is only a first step and not a complete suite of unit tests for all possible options of the find controller. While writing this unit test, I found two smaller issues that I addressed directly. The first one is that in the previous find controller refactoring I forgot to rename some occurrences of a now private member variable. Fortunately this did not cause any bugs since we did have a public getter and the fetched value may be changed by reference, but it's nevertheless good to fix. The second issue is that some entries in the `test/unit/clitests.json` file were not correct, resulting in these tests not being executed on e.g., Travis CI.
This commit is contained in:
parent
f79fb88864
commit
1b402996cf
@ -25,8 +25,9 @@
|
||||
"network_utils_spec.js",
|
||||
"node_stream_spec.js",
|
||||
"parser_spec.js",
|
||||
"pdf_find_utils.js",
|
||||
"pdf_history.js",
|
||||
"pdf_find_controller_spec.js",
|
||||
"pdf_find_utils_spec.js",
|
||||
"pdf_history_spec.js",
|
||||
"primitives_spec.js",
|
||||
"stream_spec.js",
|
||||
"type1_parser_spec.js",
|
||||
|
@ -67,6 +67,7 @@ function initializePDFJS(callback) {
|
||||
'pdfjs-test/unit/network_spec',
|
||||
'pdfjs-test/unit/network_utils_spec',
|
||||
'pdfjs-test/unit/parser_spec',
|
||||
'pdfjs-test/unit/pdf_find_controller_spec',
|
||||
'pdfjs-test/unit/pdf_find_utils_spec',
|
||||
'pdfjs-test/unit/pdf_history_spec',
|
||||
'pdfjs-test/unit/primitives_spec',
|
||||
|
99
test/unit/pdf_find_controller_spec.js
Normal file
99
test/unit/pdf_find_controller_spec.js
Normal file
@ -0,0 +1,99 @@
|
||||
/* Copyright 2018 Mozilla Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
import { buildGetDocumentParams } from './test_utils';
|
||||
import { EventBus } from '../../web/ui_utils';
|
||||
import { getDocument } from '../../src/display/api';
|
||||
import { PDFFindController } from '../../web/pdf_find_controller';
|
||||
import { SimpleLinkService } from '../../web/pdf_link_service';
|
||||
|
||||
class MockLinkService extends SimpleLinkService {
|
||||
constructor() {
|
||||
super();
|
||||
|
||||
this._page = 1;
|
||||
this._pdfDocument = null;
|
||||
}
|
||||
|
||||
setDocument(pdfDocument) {
|
||||
this._pdfDocument = pdfDocument;
|
||||
}
|
||||
|
||||
get pagesCount() {
|
||||
return this._pdfDocument.numPages;
|
||||
}
|
||||
|
||||
get page() {
|
||||
return this._page;
|
||||
}
|
||||
|
||||
set page(value) {
|
||||
this._page = value;
|
||||
}
|
||||
}
|
||||
|
||||
describe('pdf_find_controller', function() {
|
||||
let eventBus;
|
||||
let pdfFindController;
|
||||
|
||||
beforeEach(function(done) {
|
||||
const loadingTask = getDocument(buildGetDocumentParams('tracemonkey.pdf'));
|
||||
loadingTask.promise.then(function(pdfDocument) {
|
||||
const linkService = new MockLinkService();
|
||||
linkService.setDocument(pdfDocument);
|
||||
|
||||
eventBus = new EventBus();
|
||||
|
||||
pdfFindController = new PDFFindController({
|
||||
linkService,
|
||||
eventBus,
|
||||
});
|
||||
pdfFindController.setDocument(pdfDocument);
|
||||
|
||||
eventBus.dispatch('pagesinit');
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
afterEach(function() {
|
||||
eventBus = null;
|
||||
pdfFindController = null;
|
||||
});
|
||||
|
||||
it('performs a basic search', function(done) {
|
||||
pdfFindController.executeCommand('find', { query: 'Dynamic', });
|
||||
|
||||
const matchesPerPage = [11, 5, 0, 3, 0, 0, 0, 1, 1, 1, 0, 3, 4, 4];
|
||||
const totalPages = matchesPerPage.length;
|
||||
const totalMatches = matchesPerPage.reduce((a, b) => {
|
||||
return a + b;
|
||||
});
|
||||
|
||||
eventBus.on('updatefindmatchescount',
|
||||
function onUpdateFindMatchesCount(evt) {
|
||||
if (pdfFindController.pageMatches.length !== totalPages) {
|
||||
return;
|
||||
}
|
||||
eventBus.off('updatefindmatchescount', onUpdateFindMatchesCount);
|
||||
|
||||
expect(evt.matchesCount.total).toBe(totalMatches);
|
||||
for (let i = 0; i < totalPages; i++) {
|
||||
expect(pdfFindController.pageMatches[i].length)
|
||||
.toEqual(matchesPerPage[i]);
|
||||
}
|
||||
done();
|
||||
});
|
||||
});
|
||||
});
|
@ -526,8 +526,8 @@ class PDFFindController {
|
||||
|
||||
if (found) {
|
||||
const previousPage = this._selected.pageIdx;
|
||||
this.selected.pageIdx = this._offset.pageIdx;
|
||||
this.selected.matchIdx = this._offset.matchIdx;
|
||||
this._selected.pageIdx = this._offset.pageIdx;
|
||||
this._selected.matchIdx = this._offset.matchIdx;
|
||||
state = (wrapped ? FindState.WRAPPED : FindState.FOUND);
|
||||
|
||||
// Update the currently selected page to wipe out any selected matches.
|
||||
|
Loading…
x
Reference in New Issue
Block a user