mirror of
https://github.com/elastic/kibana.git
synced 2025-06-30 12:03:21 -04:00
141 lines
5.3 KiB
TypeScript
141 lines
5.3 KiB
TypeScript
/*
|
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
* or more contributor license agreements. Licensed under the "Elastic License
|
|
* 2.0", the "GNU Affero General Public License v3.0 only", and the "Server Side
|
|
* Public License v 1"; you may not use this file except in compliance with, at
|
|
* your election, the "Elastic License 2.0", the "GNU Affero General Public
|
|
* License v3.0 only", or the "Server Side Public License, v 1".
|
|
*/
|
|
|
|
import expect from '@kbn/expect';
|
|
import { get } from 'lodash';
|
|
import { ANALYTICS_SAVED_OBJECT_INDEX } from '@kbn/core-saved-objects-server';
|
|
import { KQL_TELEMETRY_ROUTE_LATEST_VERSION } from '@kbn/data-plugin/common';
|
|
import {
|
|
ELASTIC_HTTP_VERSION_HEADER,
|
|
X_ELASTIC_INTERNAL_ORIGIN_REQUEST,
|
|
} from '@kbn/core-http-common';
|
|
import { FtrProviderContext } from '../../ftr_provider_context';
|
|
|
|
export default function ({ getService }: FtrProviderContext) {
|
|
const supertest = getService('supertest');
|
|
const kibanaServer = getService('kibanaServer');
|
|
const es = getService('es');
|
|
|
|
describe('telemetry API', () => {
|
|
before(async () => {
|
|
await kibanaServer.importExport.load(
|
|
'test/api_integration/fixtures/kbn_archiver/saved_objects/basic.json'
|
|
);
|
|
});
|
|
after(async () => {
|
|
await kibanaServer.importExport.unload(
|
|
'test/api_integration/fixtures/kbn_archiver/saved_objects/basic.json'
|
|
);
|
|
});
|
|
|
|
it('should increment the opt *in* counter in the .kibana_analytics/kql-telemetry document', async () => {
|
|
await supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana')
|
|
.send({ opt_in: true })
|
|
.expect(200);
|
|
|
|
return es
|
|
.search({
|
|
index: ANALYTICS_SAVED_OBJECT_INDEX,
|
|
q: 'type:kql-telemetry',
|
|
})
|
|
.then((response) => {
|
|
const optInCount = get(response, 'hits.hits[0]._source.kql-telemetry.optInCount');
|
|
expect(optInCount).to.be(1);
|
|
});
|
|
});
|
|
|
|
it('should increment the opt *out* counter in the .kibana_analytics/kql-telemetry document', async () => {
|
|
await supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana')
|
|
.send({ opt_in: false })
|
|
.expect(200);
|
|
|
|
return es
|
|
.search({
|
|
index: ANALYTICS_SAVED_OBJECT_INDEX,
|
|
q: 'type:kql-telemetry',
|
|
})
|
|
.then((response) => {
|
|
const optOutCount = get(response, 'hits.hits[0]._source.kql-telemetry.optOutCount');
|
|
expect(optOutCount).to.be(1);
|
|
});
|
|
});
|
|
|
|
it('should report success when opt *in* is incremented successfully', () => {
|
|
return supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana')
|
|
.send({ opt_in: true })
|
|
.expect('Content-Type', /json/)
|
|
.expect(200)
|
|
.then(({ body }) => {
|
|
expect(body.success).to.be(true);
|
|
});
|
|
});
|
|
|
|
it('should report success when opt *out* is incremented successfully', () => {
|
|
return supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana')
|
|
.send({ opt_in: false })
|
|
.expect('Content-Type', /json/)
|
|
.expect(200)
|
|
.then(({ body }) => {
|
|
expect(body.success).to.be(true);
|
|
});
|
|
});
|
|
|
|
it('should only accept literal boolean values for the opt_in POST body param', function () {
|
|
return Promise.all([
|
|
supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana')
|
|
.send({ opt_in: 'notabool' })
|
|
.expect(400),
|
|
supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.send({ opt_in: 0 })
|
|
.expect(400),
|
|
supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.send({ opt_in: null })
|
|
.expect(400),
|
|
supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.send({ opt_in: undefined })
|
|
.expect(400),
|
|
supertest
|
|
.post('/internal/kql_opt_in_stats')
|
|
.set('content-type', 'application/json')
|
|
.set(ELASTIC_HTTP_VERSION_HEADER, KQL_TELEMETRY_ROUTE_LATEST_VERSION)
|
|
.send({})
|
|
.expect(400),
|
|
]);
|
|
});
|
|
});
|
|
}
|