gitlab-org--gitlab-foss/spec/javascripts/pdf/page_spec.js

52 lines
1.2 KiB
JavaScript
Raw Normal View History

2017-04-11 22:44:22 -04:00
import Vue from 'vue';
import pdfjsLib from 'pdfjs-dist/build/pdf';
import workerSrc from 'pdfjs-dist/build/pdf.worker.min';
2017-04-11 22:44:22 -04:00
import mountComponent from 'spec/helpers/vue_mount_component_helper';
2019-04-25 08:22:00 -04:00
import { FIXTURES_PATH } from 'spec/test_constants';
import PageComponent from '~/pdf/page/index.vue';
2019-04-25 08:22:00 -04:00
const testPDF = `${FIXTURES_PATH}/blob/pdf/test.pdf`;
2017-04-11 22:44:22 -04:00
describe('Page component', () => {
const Component = Vue.extend(PageComponent);
2017-04-11 22:44:22 -04:00
let vm;
let testPage;
beforeEach(done => {
2019-03-13 08:59:15 -04:00
pdfjsLib.GlobalWorkerOptions.workerSrc = workerSrc;
pdfjsLib
.getDocument(testPDF)
.promise.then(pdf => pdf.getPage(1))
.then(page => {
2017-04-11 22:44:22 -04:00
testPage = page;
})
.then(done)
.catch(done.fail);
2017-04-11 22:44:22 -04:00
});
afterEach(() => {
vm.$destroy();
});
2017-04-11 22:44:22 -04:00
it('renders the page when mounting', done => {
const promise = Promise.resolve();
spyOn(testPage, 'render').and.returnValue({ promise });
vm = mountComponent(Component, {
page: testPage,
number: 1,
2017-04-11 22:44:22 -04:00
});
2018-10-09 14:03:09 -04:00
expect(vm.rendering).toBe(true);
2017-04-11 22:44:22 -04:00
promise
.then(() => {
expect(testPage.render).toHaveBeenCalledWith(vm.renderContext);
expect(vm.rendering).toBe(false);
})
.then(done)
.catch(done.fail);
2017-04-11 22:44:22 -04:00
});
});