Improve observability (#834)

* API generation

* Added correlation id support

* Updated docs

* Updated test

* Updated code generation

* API generation

* Updated code generation

* Added support for client name and custom context object

* Updated docs

* Updated test

* Fix docs

* Updated docs

* Added id support also for sniffing

* Updated test

* Update docs/observability.asciidoc

Co-Authored-By: delvedor <delvedor@users.noreply.github.com>

* Update docs/observability.asciidoc

Co-Authored-By: delvedor <delvedor@users.noreply.github.com>

* Apply suggestions

* Update docs/configuration.asciidoc

Co-Authored-By: delvedor <delvedor@users.noreply.github.com>

* Update docs/configuration.asciidoc

Co-Authored-By: delvedor <delvedor@users.noreply.github.com>

* Update docs/observability.asciidoc

Co-Authored-By: delvedor <delvedor@users.noreply.github.com>

* Update docs/observability.asciidoc

Co-Authored-By: delvedor <delvedor@users.noreply.github.com>

* Update docs/observability.asciidoc

Co-Authored-By: delvedor <delvedor@users.noreply.github.com>

* Apply suggestions

* Updated README.md

* Fixed test

* Addressed suggestions
This commit is contained in:
Tomas Della Vedova
2019-05-03 17:23:40 +02:00
committed by delvedor
parent 9dacd9d9ee
commit b1458e3511
279 changed files with 2436 additions and 142 deletions

View File

@ -73,6 +73,47 @@ class MockConnectionError extends Connection {
}
}
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 setStatusCode (path) {
const statusCode = Number(path.slice(1))
if (Number.isInteger(statusCode)) {
@ -81,4 +122,9 @@ function setStatusCode (path) {
return 200
}
module.exports = { MockConnection, MockConnectionTimeout, MockConnectionError }
module.exports = {
MockConnection,
MockConnectionTimeout,
MockConnectionError,
MockConnectionSniff
}