92 lines
3.1 KiB
TypeScript
Raw Normal View History

/**
* Copyright (c) Microsoft Corporation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { ResourceSnapshot } from '../../../server/snapshot/snapshotTypes';
import { ActionTraceEvent } from '../../../server/trace/common/traceEvents';
import { ContextEntry, PageEntry } from '../../../server/trace/viewer/traceModel';
const contextSymbol = Symbol('context');
const pageSymbol = Symbol('context');
const nextSymbol = Symbol('next');
const eventsSymbol = Symbol('events');
export function indexModel(context: ContextEntry) {
for (const page of context.pages) {
(page as any)[contextSymbol] = context;
for (let i = 0; i < page.actions.length; ++i) {
const action = page.actions[i] as any;
action[contextSymbol] = context;
action[pageSymbol] = page;
action[nextSymbol] = page.actions[i + 1];
}
for (const event of page.events) {
(event as any)[contextSymbol] = context;
(event as any)[pageSymbol] = page;
}
}
}
export function context(action: ActionTraceEvent): ContextEntry {
return (action as any)[contextSymbol];
}
export function page(action: ActionTraceEvent): PageEntry {
return (action as any)[pageSymbol];
}
export function next(action: ActionTraceEvent): ActionTraceEvent {
return (action as any)[nextSymbol];
}
export function stats(action: ActionTraceEvent): { errors: number, warnings: number } {
let errors = 0;
let warnings = 0;
const p = page(action);
for (const event of eventsForAction(action)) {
if (event.metadata.method === 'console') {
const { guid } = event.metadata.params.message;
const type = p.objects[guid].type;
if (type === 'warning')
++warnings;
else if (type === 'error')
++errors;
}
if (event.metadata.method === 'pageError')
++errors;
}
return { errors, warnings };
}
export function eventsForAction(action: ActionTraceEvent): ActionTraceEvent[] {
let result: ActionTraceEvent[] = (action as any)[eventsSymbol];
if (result)
return result;
const nextAction = next(action);
result = page(action).events.filter(event => {
return event.metadata.startTime >= action.metadata.startTime && (!nextAction || event.metadata.startTime < nextAction.metadata.startTime);
});
(action as any)[eventsSymbol] = result;
return result;
}
export function resourcesForAction(action: ActionTraceEvent): ResourceSnapshot[] {
const nextAction = next(action);
return context(action).resources.filter(resource => {
return resource.timestamp > action.metadata.startTime && (!nextAction || resource.timestamp < nextAction.metadata.startTime);
});
}