Commit 1a707d90 authored by Natalia Tepluhina's avatar Natalia Tepluhina

Merge branch 'rp-simplify-custom-metric-form-validation-timeout' into 'master'

Simplify logic to timeout custom metric form validation request

See merge request gitlab-org/gitlab!27867
parents b727d035 c9d23185
...@@ -9,31 +9,25 @@ import statusCodes from '~/lib/utils/http_status'; ...@@ -9,31 +9,25 @@ import statusCodes from '~/lib/utils/http_status';
import { backOff } from '~/lib/utils/common_utils'; import { backOff } from '~/lib/utils/common_utils';
import { queryTypes, formDataValidator } from '../constants'; import { queryTypes, formDataValidator } from '../constants';
const MAX_REQUESTS = 4; const VALIDATION_REQUEST_TIMEOUT = 10000;
const axiosCancelToken = axios.CancelToken; const axiosCancelToken = axios.CancelToken;
let cancelTokenSource; let cancelTokenSource;
function backOffRequest(makeRequestCallback) { function backOffRequest(makeRequestCallback) {
let requestsCount = 0;
return backOff((next, stop) => { return backOff((next, stop) => {
makeRequestCallback() makeRequestCallback()
.then(resp => { .then(resp => {
if (resp.status === statusCodes.OK) { if (resp.status === statusCodes.OK) {
stop(resp); stop(resp);
} else { } else {
requestsCount += 1; next();
if (requestsCount < MAX_REQUESTS) {
next();
} else {
stop(resp);
}
} }
}) })
// If the request is cancelled by axios // If the request is cancelled by axios
// then consider it as noop so that its not // then consider it as noop so that its not
// caught by subsequent catches // caught by subsequent catches
.catch(thrown => (axios.isCancel(thrown) ? undefined : stop(thrown))); .catch(thrown => (axios.isCancel(thrown) ? undefined : stop(thrown)));
}); }, VALIDATION_REQUEST_TIMEOUT);
} }
export default { export default {
......
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