* Added client helpers * Updated test * The search helper should return only the documents * Added code comments * Fixed bug * Updated test * Removed bulkSize and added flushBytes * Updated test * Added concurrency * Updated test * Added support for 429 handling in the scroll search helper * Updated test * Updated stats count * Updated test * Fix test * Use client maxRetries as default * Updated type definitions * Refactored bulk helper to be more consistent with the client api * Updated test * Improved error handling, added refreshOnCompletion option and forward additinal options to the bulk api * Updated type definitions * Updated test * Fixed test on Node v8 * Updated test * Added TODO * Updated docs * Added Node v8 note * Updated scripts * Removed useless files * Added helpers to integration test * Fix cli argument position * Moar fixes * Test run elasticsearch in github actions * Use master action version * Add vm.max_map_count step * Test new action setup * Added Configure sysctl limits step * Updated action to latest version * Don't run helpers integration test in jenkins * Run helpers integratino test also with Node v10 * Updated docs * Updated docs * Updated helpers type definitions * Added test for helpers type definitions * Added license header
34 lines
918 B
JavaScript
34 lines
918 B
JavaScript
// Licensed to Elasticsearch B.V under one or more agreements.
|
|
// Elasticsearch B.V licenses this file to you under the Apache 2.0 License.
|
|
// See the LICENSE file in the project root for more information
|
|
|
|
'use strict'
|
|
|
|
const { promisify } = require('util')
|
|
const sleep = promisify(setTimeout)
|
|
const buildServer = require('./buildServer')
|
|
const buildCluster = require('./buildCluster')
|
|
const connection = require('./MockConnection')
|
|
|
|
async function waitCluster (client, waitForStatus = 'green', timeout = '50s', times = 0) {
|
|
if (!client) {
|
|
throw new Error('waitCluster helper: missing client instance')
|
|
}
|
|
try {
|
|
await client.cluster.health({ waitForStatus, timeout })
|
|
} catch (err) {
|
|
if (++times < 10) {
|
|
await sleep(5000)
|
|
return waitCluster(client, waitForStatus, timeout, times)
|
|
}
|
|
throw err
|
|
}
|
|
}
|
|
|
|
module.exports = {
|
|
buildServer,
|
|
buildCluster,
|
|
connection,
|
|
waitCluster
|
|
}
|