Merge branch 'winh-fix-pdf-page-spec-timing' into 'master'
Remove waiting from PDF page component test See merge request gitlab-org/gitlab-ce!21365
This commit is contained in:
commit
29df3f1d3f
1 changed files with 27 additions and 35 deletions
|
@ -3,53 +3,45 @@ import pdfjsLib from 'vendor/pdf';
|
|||
import workerSrc from 'vendor/pdf.worker.min';
|
||||
|
||||
import PageComponent from '~/pdf/page/index.vue';
|
||||
import testPDF from '../fixtures/blob/pdf/test.pdf';
|
||||
|
||||
const Component = Vue.extend(PageComponent);
|
||||
import mountComponent from 'spec/helpers/vue_mount_component_helper';
|
||||
import testPDF from 'spec/fixtures/blob/pdf/test.pdf';
|
||||
|
||||
describe('Page component', () => {
|
||||
const Component = Vue.extend(PageComponent);
|
||||
let vm;
|
||||
let testPage;
|
||||
|
||||
beforeEach(done => {
|
||||
pdfjsLib.PDFJS.workerSrc = workerSrc;
|
||||
|
||||
const checkRendered = (done) => {
|
||||
if (vm.rendering) {
|
||||
setTimeout(() => {
|
||||
checkRendered(done);
|
||||
}, 100);
|
||||
} else {
|
||||
done();
|
||||
}
|
||||
};
|
||||
|
||||
beforeEach((done) => {
|
||||
pdfjsLib.getDocument(testPDF)
|
||||
pdfjsLib
|
||||
.getDocument(testPDF)
|
||||
.then(pdf => pdf.getPage(1))
|
||||
.then((page) => {
|
||||
.then(page => {
|
||||
testPage = page;
|
||||
done();
|
||||
})
|
||||
.catch((error) => {
|
||||
done.fail(error);
|
||||
});
|
||||
.then(done)
|
||||
.catch(done.fail);
|
||||
});
|
||||
|
||||
describe('render', () => {
|
||||
beforeEach((done) => {
|
||||
vm = new Component({
|
||||
propsData: {
|
||||
afterEach(() => {
|
||||
vm.$destroy();
|
||||
});
|
||||
|
||||
it('renders the page when mounting', done => {
|
||||
const promise = Promise.resolve();
|
||||
spyOn(testPage, 'render').and.callFake(() => promise);
|
||||
vm = mountComponent(Component, {
|
||||
page: testPage,
|
||||
number: 1,
|
||||
},
|
||||
});
|
||||
expect(vm.rendering).toBe(true);
|
||||
|
||||
vm.$mount();
|
||||
|
||||
checkRendered(done);
|
||||
});
|
||||
|
||||
it('renders first page', () => {
|
||||
expect(vm.$el.tagName).toBeDefined();
|
||||
});
|
||||
promise
|
||||
.then(() => {
|
||||
expect(testPage.render).toHaveBeenCalledWith(vm.renderContext);
|
||||
expect(vm.rendering).toBe(false);
|
||||
})
|
||||
.then(done)
|
||||
.catch(done.fail);
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Reference in a new issue