From a8554f11114f8bf98a924a580df50a8cb8d07fc2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alejandro=20Fern=C3=A1ndez=20Haro?= Date: Fri, 11 Aug 2023 16:28:48 +0200 Subject: [PATCH] [Flaky test #131192] HTTP SSL Redirects --- .buildkite/ftr_configs.yml | 2 +- .eslintrc.js | 1 + test/server_integration/http/platform/cache.ts | 2 +- .../http/platform/config.status.ts | 1 - test/server_integration/http/platform/config.ts | 1 - test/server_integration/http/platform/headers.ts | 1 - test/server_integration/http/platform/status.ts | 1 - .../http/ssl_redirect/{config.js => config.ts} | 3 ++- .../http/ssl_redirect/{index.js => index.ts} | 12 ++++++++---- 9 files changed, 13 insertions(+), 11 deletions(-) rename test/server_integration/http/ssl_redirect/{config.js => config.ts} (93%) rename test/server_integration/http/ssl_redirect/{index.js => index.ts} (65%) diff --git a/.buildkite/ftr_configs.yml b/.buildkite/ftr_configs.yml index e6eb1cec755c..2e19b903cc8d 100644 --- a/.buildkite/ftr_configs.yml +++ b/.buildkite/ftr_configs.yml @@ -149,7 +149,7 @@ enabled: - test/plugin_functional/config.ts - test/server_integration/http/platform/config.status.ts - test/server_integration/http/platform/config.ts - - test/server_integration/http/ssl_redirect/config.js + - test/server_integration/http/ssl_redirect/config.ts - test/server_integration/http/ssl_with_p12_intermediate/config.js - test/server_integration/http/ssl_with_p12/config.js - test/server_integration/http/ssl/config.js diff --git a/.eslintrc.js b/.eslintrc.js index 515fbef1f2e4..ddd39ed00747 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -596,6 +596,7 @@ module.exports = { 'test/*/config_open.ts', 'test/*/*.config.ts', 'test/*/{tests,test_suites,apis,apps}/**/*', + 'test/server_integration/**/*.ts', 'x-pack/test/*/{tests,test_suites,apis,apps}/**/*', 'x-pack/test/*/*config.*ts', 'x-pack/test/saved_object_api_integration/*/apis/**/*', diff --git a/test/server_integration/http/platform/cache.ts b/test/server_integration/http/platform/cache.ts index 2c1aa90e963e..6e1cd8ab39db 100644 --- a/test/server_integration/http/platform/cache.ts +++ b/test/server_integration/http/platform/cache.ts @@ -7,7 +7,7 @@ */ import { FtrProviderContext } from '../../services/types'; -// eslint-disable-next-line import/no-default-export + export default function ({ getService }: FtrProviderContext) { const supertest = getService('supertest'); diff --git a/test/server_integration/http/platform/config.status.ts b/test/server_integration/http/platform/config.status.ts index 456756aa7926..638d850a8f75 100644 --- a/test/server_integration/http/platform/config.status.ts +++ b/test/server_integration/http/platform/config.status.ts @@ -17,7 +17,6 @@ import { FtrConfigProviderContext, findTestPluginPaths } from '@kbn/test'; * and installing plugins against built Kibana. This test must be run against source only in order to build the * fixture plugins */ -// eslint-disable-next-line import/no-default-export export default async function ({ readConfigFile }: FtrConfigProviderContext) { const httpConfig = await readConfigFile(require.resolve('../../config.base.js')); diff --git a/test/server_integration/http/platform/config.ts b/test/server_integration/http/platform/config.ts index 028ff67b4302..e78525cb8da6 100644 --- a/test/server_integration/http/platform/config.ts +++ b/test/server_integration/http/platform/config.ts @@ -8,7 +8,6 @@ import { FtrConfigProviderContext } from '@kbn/test'; -// eslint-disable-next-line import/no-default-export export default async function ({ readConfigFile }: FtrConfigProviderContext) { const httpConfig = await readConfigFile(require.resolve('../../config.base.js')); diff --git a/test/server_integration/http/platform/headers.ts b/test/server_integration/http/platform/headers.ts index 309dfbc71b5f..1a8e9fd61067 100644 --- a/test/server_integration/http/platform/headers.ts +++ b/test/server_integration/http/platform/headers.ts @@ -14,7 +14,6 @@ import { FtrProviderContext } from '../../services/types'; const delay = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms)); const oneSec = 1_000; -// eslint-disable-next-line import/no-default-export export default function ({ getService }: FtrProviderContext) { const config = getService('config'); diff --git a/test/server_integration/http/platform/status.ts b/test/server_integration/http/platform/status.ts index 48006576128c..50c136bfa102 100644 --- a/test/server_integration/http/platform/status.ts +++ b/test/server_integration/http/platform/status.ts @@ -12,7 +12,6 @@ import { FtrProviderContext } from '../../services/types'; type ServiceStatusSerialized = Omit & { level: string }; -// eslint-disable-next-line import/no-default-export export default function ({ getService }: FtrProviderContext) { const supertest = getService('supertest'); const retry = getService('retry'); diff --git a/test/server_integration/http/ssl_redirect/config.js b/test/server_integration/http/ssl_redirect/config.ts similarity index 93% rename from test/server_integration/http/ssl_redirect/config.js rename to test/server_integration/http/ssl_redirect/config.ts index 47568b16bf6b..8f8db0e9aae0 100644 --- a/test/server_integration/http/ssl_redirect/config.js +++ b/test/server_integration/http/ssl_redirect/config.ts @@ -9,10 +9,11 @@ import Url from 'url'; import { readFileSync } from 'fs'; import { CA_CERT_PATH, KBN_CERT_PATH, KBN_KEY_PATH } from '@kbn/dev-utils'; +import { FtrConfigProviderContext } from '@kbn/test'; import { createKibanaSupertestProvider } from '../../services'; -export default async function ({ readConfigFile }) { +export default async function ({ readConfigFile }: FtrConfigProviderContext) { const httpConfig = await readConfigFile(require.resolve('../../config.base.js')); const certificateAuthorities = [readFileSync(CA_CERT_PATH)]; diff --git a/test/server_integration/http/ssl_redirect/index.js b/test/server_integration/http/ssl_redirect/index.ts similarity index 65% rename from test/server_integration/http/ssl_redirect/index.js rename to test/server_integration/http/ssl_redirect/index.ts index 07ae0eb4bb56..6e4e7cfb7dec 100644 --- a/test/server_integration/http/ssl_redirect/index.js +++ b/test/server_integration/http/ssl_redirect/index.ts @@ -6,19 +6,23 @@ * Side Public License, v 1. */ -export default function ({ getService }) { +import { FtrProviderContext } from '../../services/types'; + +export default function ({ getService }: FtrProviderContext) { const supertest = getService('supertest'); - // Failing: See https://github.com/elastic/kibana/issues/131192 - // Failing: See https://github.com/elastic/kibana/issues/131192 - describe.skip('kibana server with ssl', () => { + describe('kibana server with ssl', () => { it('redirects http requests at redirect port to https', async () => { const host = process.env.TEST_KIBANA_HOST || 'localhost'; const port = process.env.TEST_KIBANA_PORT || '5620'; const url = `https://${host}:${port}/`; await supertest.get('/').expect('location', url).expect(302); + }); + // Skips because the current version of supertest cannot follow redirects + // Can be unskipped once https://github.com/elastic/kibana/pull/163716 is merged + it.skip('does not boot-loop (2nd redirect points to the landing page)', async () => { await supertest.get('/').redirects(1).expect('location', '/spaces/enter').expect(302); }); });