IF YOU WOULD LIKE TO GET AN ACCOUNT, please write an email to s dot adaszewski at gmail dot com. User accounts are meant only to report issues and/or generate pull requests. This is a purpose-specific Git hosting for ADARED projects. Thank you for your understanding!
Browse Source

Request ordering implemented and seems to be working but decreases responsiveness, perhaps better to manage ordering within components.

pull/1/head
parent
commit
d955e5b1ee
3 changed files with 74 additions and 17 deletions
  1. +1
    -2
      frontend/src/js/component/wb-collection-listing.js
  2. +7
    -15
      frontend/src/js/misc/make-arvados-request.js
  3. +66
    -0
      frontend/src/js/misc/wb-apply-request-ordering.js

+ 1
- 2
frontend/src/js/component/wb-collection-listing.js View File

@@ -66,8 +66,7 @@ class WBCollectionListing extends Component {
let prom = makeArvadosRequest(arvHost, arvToken, let prom = makeArvadosRequest(arvHost, arvToken,
'/arvados/v1/collections?filters=' + encodeURIComponent(JSON.stringify(filters)) + '/arvados/v1/collections?filters=' + encodeURIComponent(JSON.stringify(filters)) +
'&limit=' + encodeURIComponent(itemsPerPage) + '&limit=' + encodeURIComponent(itemsPerPage) +
'&offset=' + encodeURIComponent(itemsPerPage * activePage),
{ 'orderStream': this.state.orderStream });
'&offset=' + encodeURIComponent(itemsPerPage * activePage));
let collections; let collections;
let numPages let numPages


+ 7
- 15
frontend/src/js/misc/make-arvados-request.js View File

@@ -1,4 +1,4 @@
const requestOrdering = {};
import wbApplyRequestOrdering from 'wb-apply-request-ordering';
function makeArvadosRequest(arvHost, arvToken, endpoint, params={}) { function makeArvadosRequest(arvHost, arvToken, endpoint, params={}) {
const defaultParams = { const defaultParams = {
@@ -7,22 +7,12 @@ function makeArvadosRequest(arvHost, arvToken, endpoint, params={}) {
'contentType': 'application/json;charset=utf-8', 'contentType': 'application/json;charset=utf-8',
'responseType': 'json', 'responseType': 'json',
'useSsl': true, 'useSsl': true,
'requireToken': true,
'orderStream': null
'requireToken': true
}; };
Object.keys(defaultParams).map(k => (params[k] = Object.keys(defaultParams).map(k => (params[k] =
(k in params ? params[k] : defaultParams[k]))); (k in params ? params[k] : defaultParams[k])));
let { method, data, contentType, responseType, useSsl, requireToken, orderStream } = params;
let orderId;
if (orderStream) {
if (!(orderStream in requestOrdering))
requestOrdering[orderStream] = { 'counter': 0, 'started': [], 'completed': [] };
requestOrdering[orderStream].counter += 1;
orderId = requestOrdering[orderStream].counter;
requestOrdering[orderStream].started.push(orderId);
}
let { method, data, contentType, responseType, useSsl, requireToken } = params;
if (!(arvHost && (arvToken || !requireToken))) if (!(arvHost && (arvToken || !requireToken)))
return new Promise((accept, reject) => reject()); return new Promise((accept, reject) => reject());
@@ -35,7 +25,7 @@ function makeArvadosRequest(arvHost, arvToken, endpoint, params={}) {
xhr.setRequestHeader('Content-Type', contentType); xhr.setRequestHeader('Content-Type', contentType);
xhr.responseType = responseType; xhr.responseType = responseType;
let res = new Promise((accept, reject) => {
let prom = new Promise((accept, reject) => {
xhr.onreadystatechange = () => { xhr.onreadystatechange = () => {
if (xhr.readyState !== 4) if (xhr.readyState !== 4)
return; return;
@@ -47,7 +37,9 @@ function makeArvadosRequest(arvHost, arvToken, endpoint, params={}) {
xhr.send(data); xhr.send(data);
}); });
return res;
// prom = wbApplyRequestOrdering(prom);
return prom;
} }
export default makeArvadosRequest; export default makeArvadosRequest;

+ 66
- 0
frontend/src/js/misc/wb-apply-request-ordering.js View File

@@ -0,0 +1,66 @@
const defaultOrderRegistry = {};
function wbApplyRequestOrdering(prom, orderRegistry) {
let orderId;
if (!orderRegistry)
orderRegistry = defaultOrderRegistry;
if (Object.keys(orderRegistry).length === 0) {
orderRegistry.started = 0;
orderRegistry.pendingCompletion = {};
orderRegistry.completed = { 0: true };
}
orderRegistry.started += 1;
orderId = orderRegistry.started;
// console.log('New orderId: ' + orderId);
const orderCallback = ((isCatch, payload) => {
// console.log('orderId: ' + orderId +
// ', pendingCompletion: ' + Object.keys(orderRegistry.pendingCompletion) +
// ', completed: ' + Object.keys(orderRegistry.completed));
if ((orderId - 1) in orderRegistry.completed) {
// console.log('Running: ' + orderId);
orderRegistry.completed[orderId] = true;
delete orderRegistry.pendingCompletion[orderId];
const keys = Object.keys(orderRegistry.pendingCompletion);
keys.sort((a, b) => (a - b));
keys.map(k => {
if ((k - 1) in orderRegistry.completed) {
// console.log('Running: ' + k);
orderRegistry.pendingCompletion[k]();
orderRegistry.completed[k] = true;
delete orderRegistry.pendingCompletion[k];
}
});
if (orderRegistry.started in orderRegistry.completed) {
// console.log('Garbage collect');
orderRegistry.started = 0;
orderRegistry.completed = { 0: true };
}
if (isCatch)
throw payload;
else
return payload;
}
const prom_1 = new Promise((accept, reject) => {
orderRegistry.pendingCompletion[orderId] = (() =>
(isCatch ? reject(payload) : accept(payload)));
});
return prom_1;
});
prom = prom.then(xhr => orderCallback(false, xhr));
prom = prom.catch(e => orderCallback(true, e));
return prom;
}
export default wbApplyRequestOrdering;

Loading…
Cancel
Save