Skip to content

Commit

Permalink
In the event the server also times out, show an error message
Browse files Browse the repository at this point in the history
  • Loading branch information
DingoEatingFuzz committed Feb 27, 2018
1 parent 5346f65 commit f61f2f7
Show file tree
Hide file tree
Showing 3 changed files with 76 additions and 6 deletions.
18 changes: 15 additions & 3 deletions ui/app/components/task-log.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,15 @@ export default Component.extend(WindowResizable, {
allocation: null,
task: null,

// When true, request logs from the server agent
useServer: false,

// When true, logs cannot be fetched from either the client or the server
noConnection: false,

clientTimeout: 1000,
serverTimeout: 5000,

didReceiveAttrs() {
if (this.get('allocation') && this.get('task')) {
this.send('toggleStream');
Expand Down Expand Up @@ -59,12 +66,17 @@ export default Component.extend(WindowResizable, {
logger: logger('logUrl', 'logParams', function logFetch() {
// If the log request can't settle in one second, the client
// must be unavailable and the server should be used instead
const timing = this.get('useServer') ? this.get('serverTimeout') : this.get('clientTimeout');
return url =>
RSVP.race([this.get('token').authorizedRequest(url), timeout(1000)]).then(
RSVP.race([this.get('token').authorizedRequest(url), timeout(timing)]).then(
response => response,
error => {
this.send('failoverToServer');
this.get('stream').perform();
if (this.get('useServer')) {
this.set('noConnection', true);
} else {
this.send('failoverToServer');
this.get('stream').perform();
}
throw error;
}
);
Expand Down
6 changes: 6 additions & 0 deletions ui/app/templates/components/task-log.hbs
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
{{#if noConnection}}
<div data-test-connection-error class="notification is-error">
<h3 class="title is-4">Cannot fetch logs</h3>
<p>The logs for this task are inaccessible. Check the condition of the node the allocation is on.</p>
</div>
{{/if}}
<div class="boxed-section-head">
<span>
<button data-test-log-action="stdout" class="button {{if (eq mode "stdout") "is-info"}}" {{action "setMode" "stdout"}}>stdout</button>
Expand Down
58 changes: 55 additions & 3 deletions ui/tests/integration/task-log-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import Pretender from 'pretender';
import { logEncode } from '../../mirage/data/logs';

const HOST = '1.1.1.1:1111';
const allowedConnectionTime = 100;
const commonProps = {
interval: 50,
allocation: {
Expand All @@ -16,6 +17,8 @@ const commonProps = {
},
},
task: 'task-name',
clientTimeout: allowedConnectionTime,
serverTimeout: allowedConnectionTime,
};

const logHead = ['HEAD'];
Expand Down Expand Up @@ -179,13 +182,23 @@ test('Clicking stderr switches the log to standard error', function(assert) {
});

test('When the client is inaccessible, task-log falls back to requesting logs through the server', function(assert) {
run.later(run, run.cancelTimers, 2000);
run.later(run, run.cancelTimers, allowedConnectionTime * 2);

// override client response to timeout
this.server.get(`http://${HOST}/v1/client/fs/logs/:allocation_id`, () => [400, {}, ''], 2000);
this.server.get(
`http://${HOST}/v1/client/fs/logs/:allocation_id`,
() => [400, {}, ''],
allowedConnectionTime * 2
);

this.setProperties(commonProps);
this.render(hbs`{{task-log allocation=allocation task=task}}`);
this.render(
hbs`{{task-log
allocation=allocation
task=task
clientTimeout=clientTimeout
serverTimeout=serverTimeout}}`
);

const clientUrlRegex = new RegExp(`${HOST}/v1/client/fs/logs/${commonProps.allocation.id}`);
assert.ok(
Expand All @@ -201,3 +214,42 @@ test('When the client is inaccessible, task-log falls back to requesting logs th
);
});
});

test('When both the client and the server are inaccessible, an error message is shown', function(assert) {
run.later(run, run.cancelTimers, allowedConnectionTime * 5);

// override client and server responses to timeout
this.server.get(
`http://${HOST}/v1/client/fs/logs/:allocation_id`,
() => [400, {}, ''],
allowedConnectionTime * 2
);
this.server.get(
'/v1/client/fs/logs/:allocation_id',
() => [400, {}, ''],
allowedConnectionTime * 2
);

this.setProperties(commonProps);
this.render(
hbs`{{task-log
allocation=allocation
task=task
clientTimeout=clientTimeout
serverTimeout=serverTimeout}}`
);

return wait().then(() => {
const clientUrlRegex = new RegExp(`${HOST}/v1/client/fs/logs/${commonProps.allocation.id}`);
assert.ok(
this.server.handledRequests.filter(req => clientUrlRegex.test(req.url)).length,
'Log request was initially made directly to the client'
);
const serverUrl = `/v1/client/fs/logs/${commonProps.allocation.id}`;
assert.ok(
this.server.handledRequests.filter(req => req.url.startsWith(serverUrl)).length,
'Log request was later made to the server'
);
assert.ok(find('[data-test-connection-error]'), 'An error message is shown');
});
});

0 comments on commit f61f2f7

Please sign in to comment.