Skip to content

Commit

Permalink
[FTR] Enhance log wrapper for page objects (elastic#199810)
Browse files Browse the repository at this point in the history
## Summary

This small improvement reports the spent time for a given page object
using the `logWrapper`.
  • Loading branch information
dej611 authored and paulinashakirova committed Nov 26, 2024
1 parent 18e9754 commit 70f4c33
Showing 1 changed file with 37 additions and 5 deletions.
42 changes: 37 additions & 5 deletions x-pack/test/functional/page_objects/log_wrapper.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,10 @@

import { ToolingLog } from '@kbn/tooling-log';

function isPromise<T>(value: unknown): value is Promise<T> {
return value instanceof Promise;
}

/**
* Wraps the specified object instance with debug log statements of all method calls.
*
Expand All @@ -19,17 +23,45 @@ export function logWrapper<T extends Record<string, Function>>(
log: ToolingLog,
instance: T
): T {
const logger = prepareLogger(log, prefix);
return Object.keys(instance).reduce((acc, prop) => {
const baseFn = acc[prop];
(acc as Record<string, Function>)[prop] = (...args: unknown[]) => {
logMethodCall(log, prefix, prop, args);
return baseFn.apply(instance, args);
logger.start(prop, args);
const result = baseFn.apply(instance, args);
if (isPromise(result)) {
result.then(logger.end, logger.end);
} else {
logger.end();
}
return result;
};
return acc;
}, instance);
}

function logMethodCall(log: ToolingLog, prefix: string, prop: string, args: unknown[]) {
const argsStr = args.map((arg) => (typeof arg === 'string' ? `'${arg}'` : arg)).join(', ');
log.debug(`${prefix}.${prop}(${argsStr})`);
function prepareLogger(log: ToolingLog, prefix: string) {
let now = Date.now();
let currentContext = '';

return {
start: (prop: string, args: unknown[]) => {
if (prop === '') {
return;
}
currentContext = `${prop}(${args
.map((arg) => (typeof arg === 'string' ? `'${arg}'` : JSON.stringify(arg)))
.join(', ')})`;
log.debug(`${prefix}.${currentContext}`);
now = Date.now();
},
end: () => {
if (currentContext === '') {
return;
}
log.debug(`${prefix}.${currentContext} - (Took ${Date.now() - now} ms)`);
now = Date.now();
currentContext = '';
},
};
}

0 comments on commit 70f4c33

Please sign in to comment.