Commit bfdb5059 authored by Filipa Lacerda's avatar Filipa Lacerda

Check if runners.online is true for stuck block

Adds runners.online check in stuck block in order
to show the correct message
parent 4cc00461
...@@ -201,7 +201,7 @@ ...@@ -201,7 +201,7 @@
<stuck-block <stuck-block
v-if="job.stuck" v-if="job.stuck"
class="js-job-stuck" class="js-job-stuck"
:has-no-runners-for-project="job.runners.available" :has-no-runners-for-project="job.runners.available && !job.runners.online"
:tags="job.tags" :tags="job.tags"
:runners-path="runnerSettingsUrl" :runners-path="runnerSettingsUrl"
/> />
......
...@@ -88,7 +88,9 @@ describe('Job App ', () => { ...@@ -88,7 +88,9 @@ describe('Job App ', () => {
describe('triggered job', () => { describe('triggered job', () => {
beforeEach(() => { beforeEach(() => {
mock.onGet(props.endpoint).replyOnce(200, Object.assign({}, job, { started: '2017-05-24T10:59:52.000+01:00' })); mock
.onGet(props.endpoint)
.replyOnce(200, Object.assign({}, job, { started: '2017-05-24T10:59:52.000+01:00' }));
vm = mountComponentWithStore(Component, { props, store }); vm = mountComponentWithStore(Component, { props, store });
}); });
...@@ -133,59 +135,106 @@ describe('Job App ', () => { ...@@ -133,59 +135,106 @@ describe('Job App ', () => {
}); });
describe('stuck block', () => { describe('stuck block', () => {
it('renders stuck block when there are no runners', done => { describe('without active runners availabl', () => {
mock.onGet(props.endpoint).replyOnce( it('renders stuck block when there are no runners', done => {
200, mock.onGet(props.endpoint).replyOnce(
Object.assign({}, job, { 200,
status: { Object.assign({}, job, {
group: 'pending', status: {
icon: 'status_pending', group: 'pending',
label: 'pending', icon: 'status_pending',
text: 'pending', label: 'pending',
details_path: 'path', text: 'pending',
}, details_path: 'path',
stuck: true, },
runners: { stuck: true,
available: false, runners: {
}, available: false,
}), online: false,
); },
vm = mountComponentWithStore(Component, { props, store }); tags: [],
}),
setTimeout(() => { );
expect(vm.$el.querySelector('.js-job-stuck')).not.toBeNull(); vm = mountComponentWithStore(Component, { props, store });
done(); setTimeout(() => {
}, 0); expect(vm.$el.querySelector('.js-job-stuck')).not.toBeNull();
expect(vm.$el.querySelector('.js-job-stuck').textContent).toContain(
"This job is stuck, because you don't have any active runners that can run this job.",
);
done();
}, 0);
});
}); });
it('renders tags in stuck block when there are no runners', done => { describe('when available runners can not run specified tag', () => {
mock.onGet(props.endpoint).replyOnce( it('renders tags in stuck block when there are no runners', done => {
200, mock.onGet(props.endpoint).replyOnce(
Object.assign({}, job, { 200,
status: { Object.assign({}, job, {
group: 'pending', status: {
icon: 'status_pending', group: 'pending',
label: 'pending', icon: 'status_pending',
text: 'pending', label: 'pending',
details_path: 'path', text: 'pending',
}, details_path: 'path',
stuck: true, },
runners: { stuck: true,
available: false, runners: {
}, available: false,
}), online: false,
); },
}),
);
vm = mountComponentWithStore(Component, { vm = mountComponentWithStore(Component, {
props, props,
store, store,
});
setTimeout(() => {
expect(vm.$el.querySelector('.js-job-stuck').textContent).toContain(job.tags[0]);
expect(vm.$el.querySelector('.js-job-stuck').textContent).toContain(
"This job is stuck, because you don't have any active runners online with any of these tags assigned to them:",
);
done();
}, 0);
}); });
});
setTimeout(() => { describe('when runners are offline and build has tags', () => {
expect(vm.$el.querySelector('.js-job-stuck').textContent).toContain(job.tags[0]); it('renders message about job being stuck because of no runners with the specified tags', done => {
done(); mock.onGet(props.endpoint).replyOnce(
}, 0); 200,
Object.assign({}, job, {
status: {
group: 'pending',
icon: 'status_pending',
label: 'pending',
text: 'pending',
details_path: 'path',
},
stuck: true,
runners: {
available: true,
online: true,
},
}),
);
vm = mountComponentWithStore(Component, {
props,
store,
});
setTimeout(() => {
expect(vm.$el.querySelector('.js-job-stuck').textContent).toContain(job.tags[0]);
expect(vm.$el.querySelector('.js-job-stuck').textContent).toContain(
"This job is stuck, because you don't have any active runners online with any of these tags assigned to them:",
);
done();
}, 0);
})
}); });
it('does not renders stuck block when there are no runners', done => { it('does not renders stuck block when there are no runners', done => {
...@@ -420,10 +469,11 @@ describe('Job App ', () => { ...@@ -420,10 +469,11 @@ describe('Job App ', () => {
vm.$store.state.trace = 'Update'; vm.$store.state.trace = 'Update';
setTimeout(() => { setTimeout(() => {
expect(vm.$el.querySelector('.js-build-trace').textContent.trim()).not.toContain('Update'); expect(vm.$el.querySelector('.js-build-trace').textContent.trim()).not.toContain(
expect(vm.$el.querySelector('.js-build-trace').textContent.trim()).toContain( 'Update',
'Different',
); );
expect(vm.$el.querySelector('.js-build-trace').textContent.trim()).toContain('Different');
done(); done();
}, 0); }, 0);
}); });
......
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