From 5d61de793b12030fbc72beaaeee60cda97f0f1d7 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Mon, 4 May 2020 12:15:11 -0700 Subject: [PATCH 1/4] convert tests to typescript --- .../{chromium_tests.js => chromium_tests.ts} | 6 ++- .../api/{constants.js => constants.ts} | 0 .../api/generate/{index.js => index.ts} | 5 ++- ...{generation_urls.js => generation_urls.ts} | 0 .../test/reporting/api/{usage.js => usage.ts} | 8 ++-- .../index.js => ftr_provider_context.d.ts} | 6 ++- x-pack/test/reporting/services/index.ts | 15 ++++++++ .../{reporting_api.js => reporting_api.ts} | 38 +++++++++++-------- 8 files changed, 55 insertions(+), 23 deletions(-) rename x-pack/test/reporting/api/{chromium_tests.js => chromium_tests.ts} (77%) rename x-pack/test/reporting/api/{constants.js => constants.ts} (100%) rename x-pack/test/reporting/api/generate/{index.js => index.ts} (68%) rename x-pack/test/reporting/api/{generation_urls.js => generation_urls.ts} (100%) rename x-pack/test/reporting/api/{usage.js => usage.ts} (96%) rename x-pack/test/reporting/{services/index.js => ftr_provider_context.d.ts} (56%) create mode 100644 x-pack/test/reporting/services/index.ts rename x-pack/test/reporting/services/{reporting_api.js => reporting_api.ts} (74%) diff --git a/x-pack/test/reporting/api/chromium_tests.js b/x-pack/test/reporting/api/chromium_tests.ts similarity index 77% rename from x-pack/test/reporting/api/chromium_tests.js rename to x-pack/test/reporting/api/chromium_tests.ts index 2d5a31bb40da3..75e8e3e70b5a5 100644 --- a/x-pack/test/reporting/api/chromium_tests.js +++ b/x-pack/test/reporting/api/chromium_tests.ts @@ -4,9 +4,11 @@ * you may not use this file except in compliance with the Elastic License. */ -import { OSS_KIBANA_ARCHIVE_PATH, OSS_DATA_ARCHIVE_PATH } from './constants'; +import { OSS_DATA_ARCHIVE_PATH, OSS_KIBANA_ARCHIVE_PATH } from './constants'; +import { FtrProviderContext } from '../ftr_provider_context'; -export default function({ loadTestFile, getService }) { +// eslint-disable-next-line import/no-default-export +export default function({ loadTestFile, getService }: FtrProviderContext) { const esArchiver = getService('esArchiver'); const kibanaServer = getService('kibanaServer'); diff --git a/x-pack/test/reporting/api/constants.js b/x-pack/test/reporting/api/constants.ts similarity index 100% rename from x-pack/test/reporting/api/constants.js rename to x-pack/test/reporting/api/constants.ts diff --git a/x-pack/test/reporting/api/generate/index.js b/x-pack/test/reporting/api/generate/index.ts similarity index 68% rename from x-pack/test/reporting/api/generate/index.js rename to x-pack/test/reporting/api/generate/index.ts index 3e5f2d1fc1eb3..262fbf0635432 100644 --- a/x-pack/test/reporting/api/generate/index.js +++ b/x-pack/test/reporting/api/generate/index.ts @@ -4,7 +4,10 @@ * you may not use this file except in compliance with the Elastic License. */ -export default function({ loadTestFile }) { +import { FtrProviderContext } from '../../../common/ftr_provider_context'; + +// eslint-disable-next-line import/no-default-export +export default function({ loadTestFile }: FtrProviderContext) { describe('CSV', function() { this.tags('ciGroup2'); loadTestFile(require.resolve('./csv_saved_search')); diff --git a/x-pack/test/reporting/api/generation_urls.js b/x-pack/test/reporting/api/generation_urls.ts similarity index 100% rename from x-pack/test/reporting/api/generation_urls.js rename to x-pack/test/reporting/api/generation_urls.ts diff --git a/x-pack/test/reporting/api/usage.js b/x-pack/test/reporting/api/usage.ts similarity index 96% rename from x-pack/test/reporting/api/usage.js rename to x-pack/test/reporting/api/usage.ts index c1005c441f463..e13d77c251502 100644 --- a/x-pack/test/reporting/api/usage.js +++ b/x-pack/test/reporting/api/usage.ts @@ -6,18 +6,20 @@ import expect from '@kbn/expect'; import * as GenerationUrls from './generation_urls'; +import { FtrProviderContext } from '../ftr_provider_context'; -export default function({ getService }) { +// eslint-disable-next-line import/no-default-export +export default function({ getService }: FtrProviderContext) { const esArchiver = getService('esArchiver'); const reportingAPI = getService('reportingAPI'); - const usageAPI = getService('usageAPI'); + const usageAPI = getService('usageAPI' as any); describe('reporting usage', () => { before(() => reportingAPI.deleteAllReportingIndexes()); afterEach(() => reportingAPI.deleteAllReportingIndexes()); describe('initial state', () => { - let usage; + let usage: any; before(async () => { usage = await usageAPI.getUsageStats(); diff --git a/x-pack/test/reporting/services/index.js b/x-pack/test/reporting/ftr_provider_context.d.ts similarity index 56% rename from x-pack/test/reporting/services/index.js rename to x-pack/test/reporting/ftr_provider_context.d.ts index d181e24442d2d..e3add3748f56d 100644 --- a/x-pack/test/reporting/services/index.js +++ b/x-pack/test/reporting/ftr_provider_context.d.ts @@ -4,4 +4,8 @@ * you may not use this file except in compliance with the Elastic License. */ -export { ReportingAPIProvider } from './reporting_api'; +import { GenericFtrProviderContext } from '@kbn/test/types/ftr'; + +import { services } from './services'; + +export type FtrProviderContext = GenericFtrProviderContext; diff --git a/x-pack/test/reporting/services/index.ts b/x-pack/test/reporting/services/index.ts new file mode 100644 index 0000000000000..9684f2a8abc6c --- /dev/null +++ b/x-pack/test/reporting/services/index.ts @@ -0,0 +1,15 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { ReportingAPIProvider } from './reporting_api'; +import { services as xpackServices } from '../../functional/services'; + +export const services = { + ...xpackServices, + reportingAPI: ReportingAPIProvider, +}; + +export { ReportingAPIProvider }; diff --git a/x-pack/test/reporting/services/reporting_api.js b/x-pack/test/reporting/services/reporting_api.ts similarity index 74% rename from x-pack/test/reporting/services/reporting_api.js rename to x-pack/test/reporting/services/reporting_api.ts index e81f02c8a8ae4..e5ae88d8ac9ba 100644 --- a/x-pack/test/reporting/services/reporting_api.js +++ b/x-pack/test/reporting/services/reporting_api.ts @@ -5,28 +5,34 @@ */ import expect from '@kbn/expect'; +// @ts-ignore no module definition import { indexTimestamp } from '../../../legacy/plugins/reporting/server/lib/esqueue/helpers/index_timestamp'; +import { FtrProviderContext } from '../ftr_provider_context'; -function removeWhitespace(str) { +function removeWhitespace(str: string) { return str.replace(/\s/g, ''); } -export function ReportingAPIProvider({ getService }) { +interface UsageStats { + reporting: any; // FIXME after https://github.com/elastic/kibana/pull/64841 is merged use ReportingUsageType +} + +export function ReportingAPIProvider({ getService }: FtrProviderContext) { const log = getService('log'); const supertest = getService('supertest'); const esSupertest = getService('esSupertest'); return { - async waitForJobToFinish(downloadReportPath) { + async waitForJobToFinish(downloadReportPath: string) { log.debug(`Waiting for job to finish: ${downloadReportPath}`); const JOB_IS_PENDING_CODE = 503; const statusCode = await new Promise(resolve => { const intervalId = setInterval(async () => { - const response = await supertest + const response = (await supertest .get(downloadReportPath) .responseType('blob') - .set('kbn-xsrf', 'xxx'); + .set('kbn-xsrf', 'xxx')) as any; log.debug(`Report at path ${downloadReportPath} returned code ${response.statusCode}`); if (response.statusCode !== JOB_IS_PENDING_CODE) { clearInterval(intervalId); @@ -38,7 +44,7 @@ export function ReportingAPIProvider({ getService }) { expect(statusCode).to.be(200); }, - async expectAllJobsToFinishSuccessfully(jobPaths) { + async expectAllJobsToFinishSuccessfully(jobPaths: string[]) { await Promise.all( jobPaths.map(async path => { await this.waitForJobToFinish(path); @@ -46,7 +52,7 @@ export function ReportingAPIProvider({ getService }) { ); }, - async postJob(apiPath) { + async postJob(apiPath: string) { log.debug(`ReportingAPI.postJob(${apiPath})`); const { body } = await supertest .post(removeWhitespace(apiPath)) @@ -59,7 +65,7 @@ export function ReportingAPIProvider({ getService }) { * * @return {Promise} A function to call to clean up the index alias that was added. */ - async coerceReportsIntoExistingIndex(indexName) { + async coerceReportsIntoExistingIndex(indexName: string) { log.debug(`ReportingAPI.coerceReportsIntoExistingIndex(${indexName})`); // Adding an index alias coerces the report to be generated on an existing index which means any new @@ -96,38 +102,38 @@ export function ReportingAPIProvider({ getService }) { await esSupertest.delete('/.reporting*').expect(200); }, - expectRecentPdfAppStats(stats, app, count) { + expectRecentPdfAppStats(stats: UsageStats, app: string, count: number) { expect(stats.reporting.last_day.printable_pdf.app[app]).to.be(count); expect(stats.reporting.last_7_days.printable_pdf.app[app]).to.be(count); }, - expectAllTimePdfAppStats(stats, app, count) { + expectAllTimePdfAppStats(stats: UsageStats, app: string, count: number) { expect(stats.reporting.printable_pdf.app[app]).to.be(count); }, - expectRecentPdfLayoutStats(stats, layout, count) { + expectRecentPdfLayoutStats(stats: UsageStats, layout: string, count: number) { expect(stats.reporting.last_day.printable_pdf.layout[layout]).to.be(count); expect(stats.reporting.last_7_days.printable_pdf.layout[layout]).to.be(count); }, - expectAllTimePdfLayoutStats(stats, layout, count) { + expectAllTimePdfLayoutStats(stats: UsageStats, layout: string, count: number) { expect(stats.reporting.printable_pdf.layout[layout]).to.be(count); }, - expectRecentJobTypeTotalStats(stats, jobType, count) { + expectRecentJobTypeTotalStats(stats: UsageStats, jobType: string, count: number) { expect(stats.reporting.last_day[jobType].total).to.be(count); expect(stats.reporting.last_7_days[jobType].total).to.be(count); }, - expectAllTimeJobTypeTotalStats(stats, jobType, count) { + expectAllTimeJobTypeTotalStats(stats: UsageStats, jobType: string, count: number) { expect(stats.reporting[jobType].total).to.be(count); }, - getCompletedReportCount(stats) { + getCompletedReportCount(stats: UsageStats) { return stats.reporting.status.completed; }, - expectCompletedReportCount(stats, count) { + expectCompletedReportCount(stats: UsageStats, count: number) { expect(this.getCompletedReportCount(stats)).to.be(count); }, }; From 9ba4ef4851958f163461dc8f655307be6e2b65c3 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Mon, 4 May 2020 12:29:39 -0700 Subject: [PATCH 2/4] comment note --- x-pack/test/reporting/api/usage.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x-pack/test/reporting/api/usage.ts b/x-pack/test/reporting/api/usage.ts index e13d77c251502..6473168f03200 100644 --- a/x-pack/test/reporting/api/usage.ts +++ b/x-pack/test/reporting/api/usage.ts @@ -19,7 +19,7 @@ export default function({ getService }: FtrProviderContext) { afterEach(() => reportingAPI.deleteAllReportingIndexes()); describe('initial state', () => { - let usage: any; + let usage: any; // FIXME after https://github.com/elastic/kibana/pull/64841 is merged use ReportingUsageType before(async () => { usage = await usageAPI.getUsageStats(); From 7b40fef208b250d6783f8859018b946a16cb8850 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Mon, 4 May 2020 16:43:17 -0700 Subject: [PATCH 3/4] add type for api integration test --- x-pack/test/reporting/api/usage.ts | 11 +++++-- .../test/reporting/services/reporting_api.ts | 30 ++++++++++++++++--- 2 files changed, 34 insertions(+), 7 deletions(-) diff --git a/x-pack/test/reporting/api/usage.ts b/x-pack/test/reporting/api/usage.ts index 6473168f03200..427dfe33e58b7 100644 --- a/x-pack/test/reporting/api/usage.ts +++ b/x-pack/test/reporting/api/usage.ts @@ -5,8 +5,13 @@ */ import expect from '@kbn/expect'; -import * as GenerationUrls from './generation_urls'; import { FtrProviderContext } from '../ftr_provider_context'; +import { ReportingUsageStats } from '../services/reporting_api'; +import * as GenerationUrls from './generation_urls'; + +interface UsageStats { + reporting: ReportingUsageStats; +} // eslint-disable-next-line import/no-default-export export default function({ getService }: FtrProviderContext) { @@ -19,10 +24,10 @@ export default function({ getService }: FtrProviderContext) { afterEach(() => reportingAPI.deleteAllReportingIndexes()); describe('initial state', () => { - let usage: any; // FIXME after https://github.com/elastic/kibana/pull/64841 is merged use ReportingUsageType + let usage: UsageStats; before(async () => { - usage = await usageAPI.getUsageStats(); + usage = (await usageAPI.getUsageStats()) as UsageStats; }); it('shows reporting as available and enabled', async () => { diff --git a/x-pack/test/reporting/services/reporting_api.ts b/x-pack/test/reporting/services/reporting_api.ts index 212dc2800c0f8..1fa5fd7135708 100644 --- a/x-pack/test/reporting/services/reporting_api.ts +++ b/x-pack/test/reporting/services/reporting_api.ts @@ -7,15 +7,37 @@ import expect from '@kbn/expect'; // @ts-ignore no module definition import { indexTimestamp } from '../../../legacy/plugins/reporting/server/lib/esqueue/helpers/index_timestamp'; -import { ReportingUsageType } from '../../../legacy/plugins/reporting/server/usage/types'; import { FtrProviderContext } from '../ftr_provider_context'; -function removeWhitespace(str: string) { - return str.replace(/\s/g, ''); +interface PDFAppCounts { + app: { + [appName: string]: number; + }; + layout: { + [layoutType: string]: number; + }; +} + +export interface ReportingUsageStats { + available: boolean; + enabled: boolean; + total: number; + last_7_days: { + total: number; + printable_pdf: PDFAppCounts; + [jobType: string]: any; + }; + printable_pdf: PDFAppCounts; + status: any; + [jobType: string]: any; } interface UsageStats { - reporting: ReportingUsageType; + reporting: ReportingUsageStats; +} + +function removeWhitespace(str: string) { + return str.replace(/\s/g, ''); } export function ReportingAPIProvider({ getService }: FtrProviderContext) { From 5cbf3c704c5a7f50206cea86004479e5c481d4f6 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Mon, 4 May 2020 21:06:24 -0700 Subject: [PATCH 4/4] fix import --- x-pack/test/reporting/api/generate/index.ts | 2 +- x-pack/test/reporting/api/usage.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/x-pack/test/reporting/api/generate/index.ts b/x-pack/test/reporting/api/generate/index.ts index 262fbf0635432..b9db0d465d005 100644 --- a/x-pack/test/reporting/api/generate/index.ts +++ b/x-pack/test/reporting/api/generate/index.ts @@ -4,7 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ -import { FtrProviderContext } from '../../../common/ftr_provider_context'; +import { FtrProviderContext } from '../../ftr_provider_context'; // eslint-disable-next-line import/no-default-export export default function({ loadTestFile }: FtrProviderContext) { diff --git a/x-pack/test/reporting/api/usage.ts b/x-pack/test/reporting/api/usage.ts index 427dfe33e58b7..e3ebcf9d3bab0 100644 --- a/x-pack/test/reporting/api/usage.ts +++ b/x-pack/test/reporting/api/usage.ts @@ -17,7 +17,7 @@ interface UsageStats { export default function({ getService }: FtrProviderContext) { const esArchiver = getService('esArchiver'); const reportingAPI = getService('reportingAPI'); - const usageAPI = getService('usageAPI' as any); + const usageAPI = getService('usageAPI' as any); // NOTE Usage API service is not Typescript describe('reporting usage', () => { before(() => reportingAPI.deleteAllReportingIndexes());