123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- import {DifferentialFlamegraph} from 'sentry/utils/profiling/differentialFlamegraph';
- import {Flamegraph} from 'sentry/utils/profiling/flamegraph';
- import {FlamegraphTheme} from 'sentry/utils/profiling/flamegraph/flamegraphTheme';
- import {EventedProfile} from 'sentry/utils/profiling/profile/eventedProfile';
- import {createFrameIndex} from 'sentry/utils/profiling/profile/utils';
- const makeEvent = (times: number, frame: number): Profiling.Event[] => {
- return new Array(times * 2).fill(0).map((_, i) => {
- return {type: i % 2 === 0 ? 'O' : 'C', at: i, frame};
- });
- };
- const baseProfile: Profiling.EventedProfile = {
- name: 'profile',
- startValue: 0,
- endValue: 1000,
- unit: 'milliseconds',
- threadID: 0,
- type: 'evented',
- events: [],
- };
- const makeFlamegraph = (profile: Profiling.EventedProfile) => {
- return new Flamegraph(
- EventedProfile.FromProfile(
- profile,
- createFrameIndex([{name: 'f0'}, {name: 'f1'}, {name: 'f2'}, {name: 'f3'}])
- ),
- 0,
- {
- inverted: false,
- leftHeavy: false,
- }
- );
- };
- const THEME = {
- COLORS: {
- DIFFERENTIAL_DECREASE: [0, 0, 1],
- DIFFERENTIAL_INCREASE: [1, 0, 0],
- },
- } as FlamegraphTheme;
- describe('differentialFlamegraph', () => {
- it('INCREASE: color encodes new frames red', () => {
- const from = makeFlamegraph({
- ...baseProfile,
- events: [],
- });
- const to = makeFlamegraph({
- ...baseProfile,
- events: [...makeEvent(1, 0)],
- });
- const flamegraph = DifferentialFlamegraph.Diff(from, to, THEME);
- expect(flamegraph.colors?.get('f0')).toEqual([1, 0, 0, 1]);
- });
- it('INCREASE: color encodes relative increase in red', () => {
- const from = makeFlamegraph({
- ...baseProfile,
- events: [...makeEvent(2, 0)],
- });
- const to = makeFlamegraph({
- ...baseProfile,
- events: [...makeEvent(3, 0)],
- });
- const flamegraph = DifferentialFlamegraph.Diff(from, to, THEME);
- expect(flamegraph.colors?.get('f0')).toEqual([1, 0, 0, 0.5]);
- });
- it('DECREASE: color encodes relative decrease in blue', () => {
- const from = makeFlamegraph({
- ...baseProfile,
- events: [...makeEvent(4, 0)],
- });
- const to = makeFlamegraph({
- ...baseProfile,
- events: [...makeEvent(2, 0)],
- });
- const flamegraph = DifferentialFlamegraph.Diff(from, to, THEME);
- expect(flamegraph.colors?.get('f0')).toEqual([0, 0, 1, 0.5]);
- });
- it('No change: no color is set', () => {
- const from = makeFlamegraph({
- ...baseProfile,
- events: [...makeEvent(2, 0)],
- });
- const to = makeFlamegraph({
- ...baseProfile,
- events: [...makeEvent(2, 0)],
- });
- const flamegraph = DifferentialFlamegraph.Diff(from, to, THEME);
- expect(flamegraph.colors?.get('f0')).toBe(undefined);
- });
- });
|