From cdc13e4bb14b429fe0b9bb63b45b135476685a36 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Wed, 29 Apr 2020 14:17:58 -0700 Subject: [PATCH 1/6] Stricter types for Reporting Usage data --- .../server/usage/get_reporting_usage.ts | 46 ++++++++++--------- .../plugins/reporting/server/usage/types.d.ts | 41 ++++++++++++----- 2 files changed, 54 insertions(+), 33 deletions(-) diff --git a/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts b/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts index 2c3bb8f4bf71c..02b6f113379ee 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts +++ b/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts @@ -16,6 +16,7 @@ import { JobTypes, KeyCountBucket, RangeStats, + ReportingUsageType, SearchResponse, StatusByAppBucket, } from './types'; @@ -73,6 +74,7 @@ function getAggStats(aggs: AggregationResultBuckets): RangeStats { const pdfAppBuckets = get(aggs[OBJECT_TYPES_KEY], '.pdf.buckets', []); const pdfLayoutBuckets = get(aggs[LAYOUT_TYPES_KEY], '.pdf.buckets', []); pdfJobs.app = getKeyCount(pdfAppBuckets) as { + 'canvas workpad': number; visualization: number; dashboard: number; }; @@ -177,25 +179,27 @@ export async function getReportingUsage( return callCluster('search', params) .then((response: SearchResponse) => handleResponse(response)) - .then((usage: RangeStatSets) => { - // Allow this to explicitly throw an exception if/when this config is deprecated, - // because we shouldn't collect browserType in that case! - const browserType = config.get('capture', 'browser', 'type'); - - const exportTypesHandler = getExportTypesHandler(exportTypesRegistry); - const availability = exportTypesHandler.getAvailability( - xpackMainInfo - ) as FeatureAvailabilityMap; - - const { lastDay, last7Days, ...all } = usage; - - return { - available: true, - browser_type: browserType, - enabled: true, - lastDay: decorateRangeStats(lastDay, availability), - last7Days: decorateRangeStats(last7Days, availability), - ...decorateRangeStats(all, availability), - }; - }); + .then( + (usage: RangeStatSets): ReportingUsageType => { + // Allow this to explicitly throw an exception if/when this config is deprecated, + // because we shouldn't collect browserType in that case! + const browserType = config.get('capture', 'browser', 'type'); + + const exportTypesHandler = getExportTypesHandler(exportTypesRegistry); + const availability = exportTypesHandler.getAvailability( + xpackMainInfo + ) as FeatureAvailabilityMap; + + const { lastDay, last7Days, ...all } = usage; + + return { + available: true, + browser_type: browserType, + enabled: true, + lastDay: decorateRangeStats(lastDay, availability), + last7Days: decorateRangeStats(last7Days, availability), + ...decorateRangeStats(all, availability), + }; + } + ); } diff --git a/x-pack/legacy/plugins/reporting/server/usage/types.d.ts b/x-pack/legacy/plugins/reporting/server/usage/types.d.ts index 83f1701863355..eaa8bad373b51 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/types.d.ts +++ b/x-pack/legacy/plugins/reporting/server/usage/types.d.ts @@ -59,12 +59,13 @@ export interface AvailableTotal { total: number; } -type BaseJobTypeKeys = 'csv' | 'PNG'; -export type JobTypes = { [K in BaseJobTypeKeys]: AvailableTotal } & { +type BaseJobTypes = 'csv' | 'PNG' | 'printable_pdf'; +export type JobTypes = { [K in BaseJobTypes]: AvailableTotal } & { printable_pdf: AvailableTotal & { app: { - visualization: number; + 'canvas workpad': number; dashboard: number; + visualization: number; }; layout: { print: number; @@ -73,17 +74,26 @@ export type JobTypes = { [K in BaseJobTypeKeys]: AvailableTotal } & { }; }; -interface StatusCounts { - [statusType: string]: number; -} +export type Statuses = + | 'cancelled' + | 'completed' + | 'completed_with_warnings' + | 'failed' + | 'pending' + | 'processing'; +type StatusCounts = { + [S in Statuses]?: number; +}; -interface StatusByAppCounts { - [statusType: string]: { - [jobType: string]: { - [appName: string]: number; +export type ExportType = 'csv' | 'printable_pdf' | 'PNG'; +export type AppNames = 'canvas workpad' | 'dashboard' | 'visualization'; +type StatusByAppCounts = { + [S in Statuses]?: { + [J in BaseJobTypes]?: { + [A in AppNames]: number; }; }; -} +}; export type RangeStats = JobTypes & { _all: number; @@ -91,5 +101,12 @@ export type RangeStats = JobTypes & { statuses: StatusByAppCounts; }; -export type ExportType = 'csv' | 'printable_pdf' | 'PNG'; +export type ReportingUsageType = RangeStats & { + available: boolean; + browser_type: string; + enabled: boolean; + lastDay: RangeStats; + last7Days: RangeStats; +}; + export type FeatureAvailabilityMap = { [F in ExportType]: boolean }; From 4313953e130c7a2e19a2a5f2f7e1bfaad5445619 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Wed, 29 Apr 2020 14:36:04 -0700 Subject: [PATCH 2/6] Allow more type inference --- .../server/usage/get_reporting_usage.ts | 44 +++++++++---------- .../plugins/reporting/server/usage/types.d.ts | 24 +++++----- 2 files changed, 33 insertions(+), 35 deletions(-) diff --git a/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts b/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts index 02b6f113379ee..2619b59287011 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts +++ b/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts @@ -19,6 +19,8 @@ import { ReportingUsageType, SearchResponse, StatusByAppBucket, + AppCounts, + LayoutCounts, } from './types'; type XPackInfo = XPackMainPlugin['info']; @@ -37,8 +39,11 @@ const DEFAULT_TERMS_SIZE = 10; const PRINTABLE_PDF_JOBTYPE = 'printable_pdf'; // indexes some key/count buckets by the "key" property -const getKeyCount = (buckets: KeyCountBucket[]): { [key: string]: number } => - buckets.reduce((accum, { key, doc_count: count }) => ({ ...accum, [key]: count }), {}); +const getKeyCount = (buckets: KeyCountBucket[]): BucketType => + buckets.reduce( + (accum, { key, doc_count: count }) => ({ ...accum, [key]: count }), + {} as BucketType + ); // indexes some key/count buckets by statusType > jobType > appName: statusCount const getAppStatuses = (buckets: StatusByAppBucket[]) => @@ -59,7 +64,7 @@ const getAppStatuses = (buckets: StatusByAppBucket[]) => }; }, {}); -function getAggStats(aggs: AggregationResultBuckets): RangeStats { +function getAggStats(aggs: AggregationResultBuckets): Partial { const { buckets: jobBuckets } = aggs[JOB_TYPES_KEY]; const jobTypes = jobBuckets.reduce( (accum: JobTypes, { key, doc_count: count }: { key: string; doc_count: number }) => { @@ -73,18 +78,11 @@ function getAggStats(aggs: AggregationResultBuckets): RangeStats { if (pdfJobs) { const pdfAppBuckets = get(aggs[OBJECT_TYPES_KEY], '.pdf.buckets', []); const pdfLayoutBuckets = get(aggs[LAYOUT_TYPES_KEY], '.pdf.buckets', []); - pdfJobs.app = getKeyCount(pdfAppBuckets) as { - 'canvas workpad': number; - visualization: number; - dashboard: number; - }; - pdfJobs.layout = getKeyCount(pdfLayoutBuckets) as { - print: number; - preserve_layout: number; - }; + pdfJobs.app = getKeyCount(pdfAppBuckets); + pdfJobs.layout = getKeyCount(pdfLayoutBuckets); } - const all = aggs.doc_count as number; + const all = aggs.doc_count; let statusTypes = {}; const statusBuckets = get(aggs[STATUS_TYPES_KEY], 'buckets', []); if (statusBuckets) { @@ -102,23 +100,21 @@ function getAggStats(aggs: AggregationResultBuckets): RangeStats { type SearchAggregation = SearchResponse['aggregations']['ranges']['buckets']; -type RangeStatSets = Partial< - RangeStats & { - lastDay: RangeStats; - last7Days: RangeStats; - } ->; +type RangeStatSets = Partial & { + lastDay: Partial; + last7Days: Partial; +}; -async function handleResponse(response: SearchResponse): Promise { +async function handleResponse(response: SearchResponse): Promise> { const buckets = get(response, 'aggregations.ranges.buckets'); if (!buckets) { return {}; } const { lastDay, last7Days, all } = buckets; - const lastDayUsage = lastDay ? getAggStats(lastDay) : ({} as RangeStats); - const last7DaysUsage = last7Days ? getAggStats(last7Days) : ({} as RangeStats); - const allUsage = all ? getAggStats(all) : ({} as RangeStats); + const lastDayUsage = lastDay ? getAggStats(lastDay) : {}; + const last7DaysUsage = last7Days ? getAggStats(last7Days) : {}; + const allUsage = all ? getAggStats(all) : {}; return { last7Days: last7DaysUsage, @@ -180,7 +176,7 @@ export async function getReportingUsage( return callCluster('search', params) .then((response: SearchResponse) => handleResponse(response)) .then( - (usage: RangeStatSets): ReportingUsageType => { + (usage: Partial): ReportingUsageType => { // Allow this to explicitly throw an exception if/when this config is deprecated, // because we shouldn't collect browserType in that case! const browserType = config.get('capture', 'browser', 'type'); diff --git a/x-pack/legacy/plugins/reporting/server/usage/types.d.ts b/x-pack/legacy/plugins/reporting/server/usage/types.d.ts index eaa8bad373b51..f88959e813dd2 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/types.d.ts +++ b/x-pack/legacy/plugins/reporting/server/usage/types.d.ts @@ -60,6 +60,10 @@ export interface AvailableTotal { } type BaseJobTypes = 'csv' | 'PNG' | 'printable_pdf'; +export interface LayoutCounts { + print: number; + preserve_layout: number; +} export type JobTypes = { [K in BaseJobTypes]: AvailableTotal } & { printable_pdf: AvailableTotal & { app: { @@ -67,14 +71,16 @@ export type JobTypes = { [K in BaseJobTypes]: AvailableTotal } & { dashboard: number; visualization: number; }; - layout: { - print: number; - preserve_layout: number; - }; + layout: LayoutCounts; }; }; -export type Statuses = +type AppNames = 'canvas workpad' | 'dashboard' | 'visualization'; +export type AppCounts = { + [A in AppNames]: number; +}; + +type Statuses = | 'cancelled' | 'completed' | 'completed_with_warnings' @@ -84,14 +90,9 @@ export type Statuses = type StatusCounts = { [S in Statuses]?: number; }; - -export type ExportType = 'csv' | 'printable_pdf' | 'PNG'; -export type AppNames = 'canvas workpad' | 'dashboard' | 'visualization'; type StatusByAppCounts = { [S in Statuses]?: { - [J in BaseJobTypes]?: { - [A in AppNames]: number; - }; + [J in BaseJobTypes]?: AppCounts; }; }; @@ -109,4 +110,5 @@ export type ReportingUsageType = RangeStats & { last7Days: RangeStats; }; +export type ExportType = 'csv' | 'printable_pdf' | 'PNG'; export type FeatureAvailabilityMap = { [F in ExportType]: boolean }; From 67b29bde35f52d2a59641f837bc76503a00a0da2 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Thu, 30 Apr 2020 14:06:06 -0700 Subject: [PATCH 3/6] remove lastDay filter --- .../reporting/server/usage/get_reporting_usage.ts | 9 ++------- x-pack/legacy/plugins/reporting/server/usage/types.d.ts | 2 -- 2 files changed, 2 insertions(+), 9 deletions(-) diff --git a/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts b/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts index 2619b59287011..eb907d52c5f96 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts +++ b/x-pack/legacy/plugins/reporting/server/usage/get_reporting_usage.ts @@ -101,7 +101,6 @@ function getAggStats(aggs: AggregationResultBuckets): Partial { type SearchAggregation = SearchResponse['aggregations']['ranges']['buckets']; type RangeStatSets = Partial & { - lastDay: Partial; last7Days: Partial; }; @@ -110,15 +109,13 @@ async function handleResponse(response: SearchResponse): Promise Date: Thu, 30 Apr 2020 14:27:50 -0700 Subject: [PATCH 4/6] update ts and add test --- .../usage/reporting_usage_collector.test.ts | 108 +++++++++++++++++- .../plugins/reporting/server/usage/types.d.ts | 17 ++- 2 files changed, 114 insertions(+), 11 deletions(-) diff --git a/x-pack/legacy/plugins/reporting/server/usage/reporting_usage_collector.test.ts b/x-pack/legacy/plugins/reporting/server/usage/reporting_usage_collector.test.ts index 61b736a3e4d8c..eac27302e37be 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/reporting_usage_collector.test.ts +++ b/x-pack/legacy/plugins/reporting/server/usage/reporting_usage_collector.test.ts @@ -12,7 +12,7 @@ import { getReportingUsageCollector, } from './reporting_usage_collector'; import { ReportingConfig } from '../types'; -import { SearchResponse } from './types'; +import { SearchResponse, ReportingUsageType } from './types'; const exportTypesRegistry = getExportTypesRegistry(); @@ -345,6 +345,112 @@ describe('data modeling', () => { const usageStats = await fetch(callClusterMock as any); expect(usageStats).toMatchSnapshot(); }); + + test('Cast various example data to the TypeScript definition', () => { + // cd x-pack ; node ../scripts/es_archiver load reporting/archived_reports + const documentary: ReportingUsageType = { + PNG: { available: true, total: 7 }, + _all: 21, + available: true, + browser_type: 'chromium', + csv: { available: true, total: 4 }, + enabled: true, + last7Days: { + PNG: { available: true, total: 0 }, + _all: 0, + csv: { available: true, total: 0 }, + printable_pdf: { + app: { dashboard: 0, visualization: 0 }, + available: true, + layout: { preserve_layout: 0, print: 0 }, + total: 0, + }, + status: { completed: 0, failed: 0 }, + statuses: {}, + }, + printable_pdf: { + app: { 'canvas workpad': 3, dashboard: 3, visualization: 4 }, + available: true, + layout: { preserve_layout: 7, print: 3 }, + total: 10, + }, + status: { completed: 21, failed: 0 }, + statuses: { + completed: { + PNG: { dashboard: 3, visualization: 4 }, + csv: {}, + printable_pdf: { 'canvas workpad': 3, dashboard: 3, visualization: 4 }, + }, + }, + }; + + const testimonial: ReportingUsageType = { + PNG: { available: true, total: 3 }, + _all: 4, + available: true, + browser_type: 'chromium', + csv: { available: true, total: 0 }, + enabled: true, + last7Days: { + PNG: { available: true, total: 3 }, + _all: 4, + csv: { available: true, total: 0 }, + printable_pdf: { + app: { 'canvas workpad': 1, dashboard: 0, visualization: 0 }, + available: true, + layout: { preserve_layout: 1, print: 0 }, + total: 1, + }, + status: { completed: 4, failed: 0 }, + statuses: { + completed: { PNG: { visualization: 3 }, printable_pdf: { 'canvas workpad': 1 } }, + }, + }, + printable_pdf: { + app: { 'canvas workpad': 1, dashboard: 0, visualization: 0 }, + available: true, + layout: { preserve_layout: 1, print: 0 }, + total: 1, + }, + status: { completed: 4, failed: 0 }, + statuses: { + completed: { PNG: { visualization: 3 }, printable_pdf: { 'canvas workpad': 1 } }, + }, + }; + const physical: ReportingUsageType = { + available: true, + browser_type: 'chromium', + enabled: true, + last7Days: { + _all: 0, + status: { completed: 0, failed: 0 }, + statuses: {}, + printable_pdf: { + available: true, + total: 0, + app: { dashboard: 0, visualization: 0 }, + layout: { preserve_layout: 0, print: 0 }, + }, + csv: { available: true, total: 0 }, + PNG: { available: true, total: 0 }, + }, + _all: 0, + status: { completed: 0, failed: 0 }, + statuses: {}, + printable_pdf: { + available: true, + total: 0, + app: { dashboard: 0, visualization: 0 }, + layout: { preserve_layout: 0, print: 0 }, + }, + csv: { available: true, total: 0 }, + PNG: { available: true, total: 0 }, + }; + + expect(typeof documentary).toMatchInlineSnapshot(); + expect(typeof testimonial).toMatchInlineSnapshot(); + expect(typeof physical).toMatchInlineSnapshot(); + }); }); describe('Ready for collection observable', () => { diff --git a/x-pack/legacy/plugins/reporting/server/usage/types.d.ts b/x-pack/legacy/plugins/reporting/server/usage/types.d.ts index 0801864f2b1ad..4d7a1a33239b2 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/types.d.ts +++ b/x-pack/legacy/plugins/reporting/server/usage/types.d.ts @@ -63,22 +63,19 @@ export interface LayoutCounts { print: number; preserve_layout: number; } + +type AppNames = 'canvas workpad' | 'dashboard' | 'visualization'; +export type AppCounts = { + [A in AppNames]?: number; +}; + export type JobTypes = { [K in BaseJobTypes]: AvailableTotal } & { printable_pdf: AvailableTotal & { - app: { - 'canvas workpad': number; - dashboard: number; - visualization: number; - }; + app: AppCounts; layout: LayoutCounts; }; }; -type AppNames = 'canvas workpad' | 'dashboard' | 'visualization'; -export type AppCounts = { - [A in AppNames]: number; -}; - type Statuses = | 'cancelled' | 'completed' From d4635de2a143c6b838511546c599e85df43bb036 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Thu, 30 Apr 2020 14:53:35 -0700 Subject: [PATCH 5/6] fix tests --- .../reporting_usage_collector.test.ts.snap | 103 ------------------ .../usage/reporting_usage_collector.test.ts | 23 ++-- 2 files changed, 11 insertions(+), 115 deletions(-) diff --git a/x-pack/legacy/plugins/reporting/server/usage/__snapshots__/reporting_usage_collector.test.ts.snap b/x-pack/legacy/plugins/reporting/server/usage/__snapshots__/reporting_usage_collector.test.ts.snap index aa22c3f66df18..ed2637d7a1bcb 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/__snapshots__/reporting_usage_collector.test.ts.snap +++ b/x-pack/legacy/plugins/reporting/server/usage/__snapshots__/reporting_usage_collector.test.ts.snap @@ -42,34 +42,6 @@ Object { }, "statuses": Object {}, }, - "lastDay": Object { - "PNG": Object { - "available": true, - "total": 0, - }, - "_all": 0, - "csv": Object { - "available": true, - "total": 0, - }, - "printable_pdf": Object { - "app": Object { - "dashboard": 0, - "visualization": 0, - }, - "available": true, - "layout": Object { - "preserve_layout": 0, - "print": 0, - }, - "total": 0, - }, - "status": Object { - "completed": 0, - "failed": 0, - }, - "statuses": Object {}, - }, "printable_pdf": Object { "app": Object { "dashboard": 0, @@ -139,41 +111,6 @@ Object { }, }, }, - "lastDay": Object { - "PNG": Object { - "available": true, - "total": 1, - }, - "_all": 1, - "csv": Object { - "available": true, - "total": 0, - }, - "printable_pdf": Object { - "app": Object { - "dashboard": 0, - "visualization": 0, - }, - "available": true, - "layout": Object { - "preserve_layout": 0, - "print": 0, - }, - "total": 0, - }, - "status": Object { - "completed": 0, - "completed_with_warnings": 1, - "failed": 0, - }, - "statuses": Object { - "completed_with_warnings": Object { - "PNG": Object { - "dashboard": 1, - }, - }, - }, - }, "printable_pdf": Object { "app": Object { "canvas workpad": 6, @@ -270,46 +207,6 @@ Object { }, }, }, - "lastDay": Object { - "PNG": Object { - "available": true, - "total": 1, - }, - "_all": 4, - "csv": Object { - "available": true, - "total": 1, - }, - "printable_pdf": Object { - "app": Object { - "canvas workpad": 1, - "dashboard": 1, - "visualization": 0, - }, - "available": true, - "layout": Object { - "preserve_layout": 2, - "print": 0, - }, - "total": 2, - }, - "status": Object { - "completed": 4, - "failed": 0, - }, - "statuses": Object { - "completed": Object { - "PNG": Object { - "dashboard": 1, - }, - "csv": Object {}, - "printable_pdf": Object { - "canvas workpad": 1, - "dashboard": 1, - }, - }, - }, - }, "printable_pdf": Object { "app": Object { "canvas workpad": 1, diff --git a/x-pack/legacy/plugins/reporting/server/usage/reporting_usage_collector.test.ts b/x-pack/legacy/plugins/reporting/server/usage/reporting_usage_collector.test.ts index eac27302e37be..8509eb8b5c47a 100644 --- a/x-pack/legacy/plugins/reporting/server/usage/reporting_usage_collector.test.ts +++ b/x-pack/legacy/plugins/reporting/server/usage/reporting_usage_collector.test.ts @@ -347,8 +347,12 @@ describe('data modeling', () => { }); test('Cast various example data to the TypeScript definition', () => { - // cd x-pack ; node ../scripts/es_archiver load reporting/archived_reports - const documentary: ReportingUsageType = { + const check = (obj: ReportingUsageType) => { + return typeof obj; + }; + + // just check that the example objects can be cast to ReportingUsageType + check({ PNG: { available: true, total: 7 }, _all: 21, available: true, @@ -382,9 +386,8 @@ describe('data modeling', () => { printable_pdf: { 'canvas workpad': 3, dashboard: 3, visualization: 4 }, }, }, - }; - - const testimonial: ReportingUsageType = { + }); + check({ PNG: { available: true, total: 3 }, _all: 4, available: true, @@ -416,8 +419,8 @@ describe('data modeling', () => { statuses: { completed: { PNG: { visualization: 3 }, printable_pdf: { 'canvas workpad': 1 } }, }, - }; - const physical: ReportingUsageType = { + }); + check({ available: true, browser_type: 'chromium', enabled: true, @@ -445,11 +448,7 @@ describe('data modeling', () => { }, csv: { available: true, total: 0 }, PNG: { available: true, total: 0 }, - }; - - expect(typeof documentary).toMatchInlineSnapshot(); - expect(typeof testimonial).toMatchInlineSnapshot(); - expect(typeof physical).toMatchInlineSnapshot(); + }); }); }); From 8996eaab3bdc08b0984b26870719f6e43b34c3f1 Mon Sep 17 00:00:00 2001 From: Timothy Sullivan Date: Mon, 4 May 2020 11:25:11 -0700 Subject: [PATCH 6/6] fix test --- x-pack/test/reporting/services/reporting_api.js | 3 --- 1 file changed, 3 deletions(-) diff --git a/x-pack/test/reporting/services/reporting_api.js b/x-pack/test/reporting/services/reporting_api.js index e81f02c8a8ae4..82fe6aea08ac3 100644 --- a/x-pack/test/reporting/services/reporting_api.js +++ b/x-pack/test/reporting/services/reporting_api.js @@ -97,7 +97,6 @@ export function ReportingAPIProvider({ getService }) { }, expectRecentPdfAppStats(stats, app, count) { - 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); }, @@ -106,7 +105,6 @@ export function ReportingAPIProvider({ getService }) { }, expectRecentPdfLayoutStats(stats, layout, count) { - 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); }, @@ -115,7 +113,6 @@ export function ReportingAPIProvider({ getService }) { }, expectRecentJobTypeTotalStats(stats, jobType, count) { - expect(stats.reporting.last_day[jobType].total).to.be(count); expect(stats.reporting.last_7_days[jobType].total).to.be(count); },