Skip to content

Commit

Permalink
[FTR](search_oss) update common serverless api tests to use api keys (#…
Browse files Browse the repository at this point in the history
…185030)

## Summary
- update api tests in
`x-pack/test_serverless/api_integration/test_suites/common/search_oss/`



Contributes to: #180834

---------

Co-authored-by: Kibana Machine <[email protected]>
  • Loading branch information
wayneseymour and kibanamachine authored Jun 20, 2024
1 parent 5259fa6 commit f05416e
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 17 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import request from 'superagent';
import { inflateResponse } from '@kbn/bfetch-plugin/public/streaming';
import { ELASTIC_HTTP_VERSION_HEADER } from '@kbn/core-http-common';
import { BFETCH_ROUTE_VERSION_LATEST } from '@kbn/bfetch-plugin/common';
import { RoleCredentials } from '../../../../shared/services';
import type { FtrProviderContext } from '../../../ftr_provider_context';
import { painlessErrReq } from './painless_err_req';
import { verifyErrorResponse } from './verify_error';
Expand All @@ -24,18 +25,28 @@ function parseBfetchResponse(resp: request.Response, compressed: boolean = false
}

export default function ({ getService }: FtrProviderContext) {
const supertest = getService('supertest');
const esArchiver = getService('esArchiver');
const svlCommonApi = getService('svlCommonApi');

const svlUserManager = getService('svlUserManager');
const supertestWithoutAuth = getService('supertestWithoutAuth');
let roleAuthc: RoleCredentials;

describe('bsearch', () => {
before(async () => {
roleAuthc = await svlUserManager.createApiKeyForRole('admin');
});
after(async () => {
await svlUserManager.invalidateApiKeyForRole(roleAuthc);
});
describe('post', () => {
it('should return 200 a single response', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/bsearch`)
.set(ELASTIC_HTTP_VERSION_HEADER, BFETCH_ROUTE_VERSION_LATEST)
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
batch: [
{
Expand Down Expand Up @@ -66,11 +77,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return 200 a single response from compressed', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/bsearch?compress=true`)
.set(ELASTIC_HTTP_VERSION_HEADER, BFETCH_ROUTE_VERSION_LATEST)
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
batch: [
{
Expand Down Expand Up @@ -101,11 +113,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return a batch of successful responses', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/bsearch`)
.set(ELASTIC_HTTP_VERSION_HEADER, BFETCH_ROUTE_VERSION_LATEST)
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
batch: [
{
Expand Down Expand Up @@ -146,11 +159,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return error for not found strategy', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/bsearch`)
.set(ELASTIC_HTTP_VERSION_HEADER, BFETCH_ROUTE_VERSION_LATEST)
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
batch: [
{
Expand Down Expand Up @@ -179,11 +193,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return 400 when index type is provided in "es" strategy', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/bsearch`)
.set(ELASTIC_HTTP_VERSION_HEADER, BFETCH_ROUTE_VERSION_LATEST)
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
batch: [
{
Expand Down Expand Up @@ -221,11 +236,12 @@ export default function ({ getService }: FtrProviderContext) {
await esArchiver.unload('test/functional/fixtures/es_archiver/logstash_functional');
});
it('should return 400 "search_phase_execution_exception" for Painless error in "es" strategy', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/bsearch`)
.set(ELASTIC_HTTP_VERSION_HEADER, BFETCH_ROUTE_VERSION_LATEST)
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
batch: [
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,17 +7,27 @@

import { ELASTIC_HTTP_VERSION_HEADER } from '@kbn/core-http-common';
import expect from '@kbn/expect';
import { RoleCredentials } from '../../../../shared/services';
import type { FtrProviderContext } from '../../../ftr_provider_context';
import { painlessErrReq } from './painless_err_req';
import { verifyErrorResponse } from './verify_error';

export default function ({ getService }: FtrProviderContext) {
const supertest = getService('supertest');
const esArchiver = getService('esArchiver');
const svlCommonApi = getService('svlCommonApi');
const kibanaServer = getService('kibanaServer');

const svlUserManager = getService('svlUserManager');
const supertestWithoutAuth = getService('supertestWithoutAuth');
let roleAuthc: RoleCredentials;

describe('search', () => {
before(async () => {
roleAuthc = await svlUserManager.createApiKeyForRole('admin');
});
after(async () => {
await svlUserManager.invalidateApiKeyForRole(roleAuthc);
});
before(async () => {
// TODO: emptyKibanaIndex fails in Serverless with
// "index_not_found_exception: no such index [.kibana_ingest]",
Expand All @@ -31,11 +41,12 @@ export default function ({ getService }: FtrProviderContext) {
});
describe('post', () => {
it('should return 200 when correctly formatted searches are provided', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/search/es`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
params: {
body: {
Expand All @@ -55,11 +66,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return 200 if terminated early', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/search/es`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
params: {
terminateAfter: 1,
Expand All @@ -82,11 +94,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return 404 when if no strategy is provided', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/search`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
body: {
query: {
Expand All @@ -100,11 +113,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return 404 when if unknown strategy is provided', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/search/banana`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
body: {
query: {
Expand All @@ -120,11 +134,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return 400 with illegal ES argument', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/search/es`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
params: {
timeout: 1, // This should be a time range string!
Expand All @@ -143,11 +158,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return 400 with a bad body', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/search/es`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send({
params: {
body: {
Expand All @@ -162,11 +178,12 @@ export default function ({ getService }: FtrProviderContext) {
});

it('should return 400 for a painless error', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.post(`/internal/search/es`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send(painlessErrReq)
.expect(400);

Expand All @@ -176,22 +193,24 @@ export default function ({ getService }: FtrProviderContext) {

describe('delete', () => {
it('should return 404 when no search id provided', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.delete(`/internal/search/es`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send()
.expect(404);
verifyErrorResponse(resp.body, 404);
});

it('should return 400 when trying a delete on a non supporting strategy', async () => {
const resp = await supertest
const resp = await supertestWithoutAuth
.delete(`/internal/search/es/123`)
.set(ELASTIC_HTTP_VERSION_HEADER, '1')
// TODO: API requests in Serverless require internal request headers
.set(svlCommonApi.getInternalRequestHeader())
.set(roleAuthc.apiKeyHeader)
.send()
.expect(400);
verifyErrorResponse(resp.body, 400);
Expand Down

0 comments on commit f05416e

Please sign in to comment.