consul/ui-v2/app/routes/settings.js
John Cowen 5debc74fa2 ui: Enable blocking queries by default (#6194)
-Enable blocking queries by default
-Change assertion to check for the last PUT request, not just any request for session destruction from a node page.

Since we've now turned on blocking queries by default this means that a
second GET request is made after the PUT request that we are asserting
for but before the assertion itself, this meant the assertion failed. We
double checked this by turning off blocking queries for this test using

```
And settings from yaml
---
consul:client:
  blocking: 0
---
```

which made the test pass again.

As moving forwards blocking queries will be on by default, we didn't
want to disable blocking queries for this test, so we now assert the
last PUT request specifically. This means we continue to assert that the
session has been destroyed but means we don't get into problems of
ordering of requests here
2019-09-04 08:35:14 +00:00

38 lines
1004 B
JavaScript

import Route from '@ember/routing/route';
import { inject as service } from '@ember/service';
import { hash } from 'rsvp';
import { get, set } from '@ember/object';
export default Route.extend({
client: service('client/http'),
repo: service('settings'),
dcRepo: service('repository/dc'),
model: function(params) {
return hash({
item: get(this, 'repo').findAll(),
dcs: get(this, 'dcRepo').findAll(),
}).then(model => {
if (typeof get(model.item, 'client.blocking') === 'undefined') {
set(model, 'item.client', { blocking: true });
}
return hash({
...model,
...{
dc: get(this, 'dcRepo').getActive(null, model.dcs),
},
});
});
},
setupController: function(controller, model) {
controller.setProperties(model);
},
actions: {
update: function(item) {
if (!get(item, 'client.blocking')) {
get(this, 'client').abort();
}
get(this, 'repo').persist(item);
},
},
});