Skip to content

Commit

Permalink
Test coverage for alloc stats retrying
Browse files Browse the repository at this point in the history
  • Loading branch information
DingoEatingFuzz committed Apr 21, 2018
1 parent 07471e9 commit 191bf9e
Show file tree
Hide file tree
Showing 3 changed files with 95 additions and 3 deletions.
11 changes: 8 additions & 3 deletions ui/app/components/allocation-row.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import Ember from 'ember';
import { inject as service } from '@ember/service';
import Component from '@ember/component';
import { computed } from '@ember/object';
import { run } from '@ember/runloop';
import { lazyClick } from '../helpers/lazy-click';
import { task, timeout } from 'ember-concurrency';
Expand All @@ -17,10 +18,14 @@ export default Component.extend({
// Used to determine whether the row should mention the node or the job
context: null,

backoffSequence: computed(() => [500, 800, 1300, 2100, 3400, 5500]),

// Internal state
stats: null,
statsError: false,

enablePolling: computed(() => !Ember.testing),

onClick() {},

click(event) {
Expand Down Expand Up @@ -63,8 +68,8 @@ export default Component.extend({
},

fetchStats: task(function*(allocation) {
const maxTiming = 5500;
const backoffSequence = [500, 800, 1300, 2100, 3400];
const backoffSequence = this.get('backoffSequence').slice();
const maxTiming = backoffSequence.pop();

do {
try {
Expand All @@ -75,7 +80,7 @@ export default Component.extend({
this.set('statsError', true);
}
yield timeout(backoffSequence.shift() || maxTiming);
} while (!Ember.testing);
} while (this.get('enablePolling'));
}).drop(),
});

Expand Down
2 changes: 2 additions & 0 deletions ui/mirage/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,8 @@ export default function() {
return this.serialize(allocations.where({ nodeId: params.id }));
});

this.get('/allocations');

this.get('/allocation/:id');

this.get('/namespaces', function({ namespaces }) {
Expand Down
85 changes: 85 additions & 0 deletions ui/tests/integration/allocation-row-test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
import { getOwner } from '@ember/application';
import { test, moduleForComponent } from 'ember-qunit';
import wait from 'ember-test-helpers/wait';
import hbs from 'htmlbars-inline-precompile';
import generateResources from '../../mirage/data/generate-resources';
import { startMirage } from 'nomad-ui/initializers/ember-cli-mirage';
import Response from 'ember-cli-mirage/response';

moduleForComponent('allocation-row', 'Integration | Component | allocation row', {
integration: true,
beforeEach() {
this.store = getOwner(this).lookup('service:store');
this.server = startMirage();
this.server.create('namespace');
this.server.create('node');
this.server.create('job', { createAllocations: false });
},
afterEach() {
this.server.shutdown();
},
});

test('Allocation row polls for stats, even when it errors or has an invalid response', function(assert) {
const component = this;

let currentFrame = 0;
let frames = [
JSON.stringify({ ResourceUsage: generateResources() }),
JSON.stringify({ ResourceUsage: generateResources() }),
null,
'<Not>Valid JSON</Not>',
JSON.stringify({ ResourceUsage: generateResources() }),
];
const backoffSequence = [50];

this.server.get('/client/allocation/:id/stats', function() {
const response = frames[++currentFrame];

// Disable polling to stop the EC task in the component
if (currentFrame >= frames.length) {
component.set('enablePolling', false);
}

if (response) {
return response;
}
return new Response(500, {}, '');
});

this.server.create('allocation');
this.store.findAll('allocation');

let allocation;

return wait()
.then(() => {
allocation = this.store.peekAll('allocation').get('firstObject');

this.setProperties({
allocation,
backoffSequence,
context: 'job',
enablePolling: true,
});

this.render(hbs`
{{allocation-row
allocation=allocation
context=context
backoffSequence=backoffSequence
enablePolling=enablePolling}}
`);
return wait();
})
.then(() => {
assert.equal(
this.server.pretender.handledRequests.filterBy(
'url',
`/v1/client/allocation/${allocation.get('id')}/stats`
).length,
frames.length,
'Requests continue to be made after malformed responses and server errors'
);
});
});

0 comments on commit 191bf9e

Please sign in to comment.