Commit aba27e28 authored by Phil Hughes's avatar Phil Hughes

Merge branch '4079-related-flakes' into 'master'

Resolve "Transient failure of related_issues_root_spec.js"

Closes #4079

See merge request gitlab-org/gitlab-ee!4568
parents 3ab12f71 1f2870c3
...@@ -140,12 +140,10 @@ describe('RelatedIssuesRoot', () => { ...@@ -140,12 +140,10 @@ describe('RelatedIssuesRoot', () => {
vm.onPendingFormSubmit(); vm.onPendingFormSubmit();
setTimeout(() => { setTimeout(() => {
Vue.nextTick(() => { expect(vm.state.pendingReferences.length).toEqual(0);
expect(vm.state.pendingReferences.length).toEqual(0); expect(vm.state.relatedIssues.length).toEqual(0);
expect(vm.state.relatedIssues.length).toEqual(0);
done(); done();
});
}); });
}); });
...@@ -167,15 +165,13 @@ describe('RelatedIssuesRoot', () => { ...@@ -167,15 +165,13 @@ describe('RelatedIssuesRoot', () => {
vm.onPendingFormSubmit(); vm.onPendingFormSubmit();
setTimeout(() => { setTimeout(() => {
Vue.nextTick(() => { expect(vm.state.pendingReferences.length).toEqual(0);
expect(vm.state.pendingReferences.length).toEqual(0); expect(vm.state.relatedIssues.length).toEqual(1);
expect(vm.state.relatedIssues.length).toEqual(1); expect(vm.state.relatedIssues[0].id).toEqual(issuable1.id);
expect(vm.state.relatedIssues[0].id).toEqual(issuable1.id);
Vue.http.interceptors = _.without(Vue.http.interceptors, interceptor); Vue.http.interceptors = _.without(Vue.http.interceptors, interceptor);
done(); done();
});
}); });
}); });
...@@ -197,16 +193,14 @@ describe('RelatedIssuesRoot', () => { ...@@ -197,16 +193,14 @@ describe('RelatedIssuesRoot', () => {
vm.onPendingFormSubmit(); vm.onPendingFormSubmit();
setTimeout(() => { setTimeout(() => {
Vue.nextTick(() => { expect(vm.state.pendingReferences.length).toEqual(0);
expect(vm.state.pendingReferences.length).toEqual(0); expect(vm.state.relatedIssues.length).toEqual(2);
expect(vm.state.relatedIssues.length).toEqual(2); expect(vm.state.relatedIssues[0].id).toEqual(issuable1.id);
expect(vm.state.relatedIssues[0].id).toEqual(issuable1.id); expect(vm.state.relatedIssues[1].id).toEqual(issuable2.id);
expect(vm.state.relatedIssues[1].id).toEqual(issuable2.id);
Vue.http.interceptors = _.without(Vue.http.interceptors, interceptor); Vue.http.interceptors = _.without(Vue.http.interceptors, interceptor);
done(); done();
});
}); });
}); });
}); });
...@@ -230,63 +224,46 @@ describe('RelatedIssuesRoot', () => { ...@@ -230,63 +224,46 @@ describe('RelatedIssuesRoot', () => {
}); });
describe('fetchRelatedIssues', () => { describe('fetchRelatedIssues', () => {
const interceptor = (request, next) => {
next(request.respondWith(JSON.stringify([issuable1, issuable2]), {
status: 200,
}));
};
beforeEach((done) => { beforeEach((done) => {
Vue.http.interceptors.push(interceptor);
vm = new RelatedIssuesRoot({ vm = new RelatedIssuesRoot({
propsData: defaultProps, propsData: defaultProps,
}).$mount(); }).$mount();
// wait for internal call to fetchRelatedIssues to resolve // wait for internal call to fetchRelatedIssues to resolve
setTimeout(() => Vue.nextTick(done)); setTimeout(done);
}); });
describe('when the network has not responded yet', () => { afterEach(() => {
it('should be fetching', (done) => { Vue.http.interceptors = _.without(Vue.http.interceptors, interceptor);
vm.fetchRelatedIssues();
expect(vm.isFetching).toEqual(true);
setTimeout(() => Vue.nextTick(done));
});
}); });
describe('when the network responds', () => { it('sets isFetching while fetching', (done) => {
const interceptor = (request, next) => { vm.fetchRelatedIssues();
next(request.respondWith(JSON.stringify([issuable1, issuable2]), {
status: 200,
}));
};
beforeEach(() => {
Vue.http.interceptors.push(interceptor);
});
afterEach(() => {
Vue.http.interceptors = _.without(Vue.http.interceptors, interceptor);
});
it('should be done fetching', (done) => { expect(vm.isFetching).toEqual(true);
vm.fetchRelatedIssues();
setTimeout(() => { setTimeout(() => {
Vue.nextTick(() => { expect(vm.isFetching).toEqual(false);
expect(vm.isFetching).toEqual(false);
done(); done();
});
});
}); });
});
it('should fetch related issues', (done) => { it('should fetch related issues', (done) => {
vm.fetchRelatedIssues(); Vue.nextTick(() => {
expect(vm.state.relatedIssues.length).toEqual(2);
setTimeout(() => { expect(vm.state.relatedIssues[0].id).toEqual(issuable1.id);
Vue.nextTick(() => { expect(vm.state.relatedIssues[1].id).toEqual(issuable2.id);
expect(vm.state.relatedIssues.length).toEqual(2);
expect(vm.state.relatedIssues[0].id).toEqual(issuable1.id);
expect(vm.state.relatedIssues[1].id).toEqual(issuable2.id);
done(); done();
});
});
}); });
}); });
}); });
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment