* 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
151 lines
3.6 KiB
JavaScript
151 lines
3.6 KiB
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 assert = require('assert')
|
|
const { Connection } = require('../../index')
|
|
const { TimeoutError } = require('../../lib/errors')
|
|
const intoStream = require('into-stream')
|
|
|
|
class MockConnection extends Connection {
|
|
request (params, callback) {
|
|
var aborted = false
|
|
const stream = intoStream(JSON.stringify({ hello: 'world' }))
|
|
stream.statusCode = setStatusCode(params.path)
|
|
stream.headers = {
|
|
'content-type': 'application/json;utf=8',
|
|
date: new Date().toISOString(),
|
|
connection: 'keep-alive',
|
|
'content-length': '17'
|
|
}
|
|
process.nextTick(() => {
|
|
if (!aborted) {
|
|
callback(null, stream)
|
|
}
|
|
})
|
|
return {
|
|
abort: () => { aborted = true }
|
|
}
|
|
}
|
|
}
|
|
|
|
class MockConnectionTimeout extends Connection {
|
|
request (params, callback) {
|
|
var aborted = false
|
|
process.nextTick(() => {
|
|
if (!aborted) {
|
|
callback(new TimeoutError('Request timed out', params), null)
|
|
}
|
|
})
|
|
return {
|
|
abort: () => { aborted = true }
|
|
}
|
|
}
|
|
}
|
|
|
|
class MockConnectionError extends Connection {
|
|
request (params, callback) {
|
|
var aborted = false
|
|
process.nextTick(() => {
|
|
if (!aborted) {
|
|
callback(new Error('Kaboom'), null)
|
|
}
|
|
})
|
|
return {
|
|
abort: () => { aborted = true }
|
|
}
|
|
}
|
|
}
|
|
|
|
class MockConnectionSniff extends Connection {
|
|
request (params, callback) {
|
|
var aborted = false
|
|
const sniffResult = {
|
|
nodes: {
|
|
'node-1': {
|
|
http: {
|
|
publish_address: 'localhost:9200'
|
|
},
|
|
roles: ['master', 'data', 'ingest']
|
|
},
|
|
'node-2': {
|
|
http: {
|
|
publish_address: 'localhost:9201'
|
|
},
|
|
roles: ['master', 'data', 'ingest']
|
|
}
|
|
}
|
|
}
|
|
const stream = intoStream(JSON.stringify(sniffResult))
|
|
stream.statusCode = setStatusCode(params.path)
|
|
stream.headers = {
|
|
'content-type': 'application/json;utf=8',
|
|
date: new Date().toISOString(),
|
|
connection: 'keep-alive',
|
|
'content-length': '205'
|
|
}
|
|
process.nextTick(() => {
|
|
if (!aborted) {
|
|
if (params.headers.timeout) {
|
|
callback(new TimeoutError('Request timed out', params), null)
|
|
} else {
|
|
callback(null, stream)
|
|
}
|
|
}
|
|
})
|
|
return {
|
|
abort: () => { aborted = true }
|
|
}
|
|
}
|
|
}
|
|
|
|
function buildMockConnection (opts) {
|
|
assert(opts.onRequest, 'Missing required onRequest option')
|
|
|
|
class MockConnection extends Connection {
|
|
request (params, callback) {
|
|
var { body, statusCode } = opts.onRequest(params)
|
|
if (typeof body !== 'string') {
|
|
body = JSON.stringify(body)
|
|
}
|
|
var aborted = false
|
|
const stream = intoStream(body)
|
|
stream.statusCode = statusCode || 200
|
|
stream.headers = {
|
|
'content-type': 'application/json;utf=8',
|
|
date: new Date().toISOString(),
|
|
connection: 'keep-alive',
|
|
'content-length': Buffer.byteLength(body)
|
|
}
|
|
process.nextTick(() => {
|
|
if (!aborted) {
|
|
callback(null, stream)
|
|
}
|
|
})
|
|
return {
|
|
abort: () => { aborted = true }
|
|
}
|
|
}
|
|
}
|
|
|
|
return MockConnection
|
|
}
|
|
|
|
function setStatusCode (path) {
|
|
const statusCode = Number(path.slice(1))
|
|
if (Number.isInteger(statusCode)) {
|
|
return statusCode
|
|
}
|
|
return 200
|
|
}
|
|
|
|
module.exports = {
|
|
MockConnection,
|
|
MockConnectionTimeout,
|
|
MockConnectionError,
|
|
MockConnectionSniff,
|
|
buildMockConnection
|
|
}
|