mirror of https://github.com/grafana/grafana
Fix deduplication results displaying wrong data (#15755)
The log rows were mutated in the store, what resulted in wrong deduplication results as well as made the selector memoization quirky - for "the same results" the selector was running twice.pull/15918/head
parent
90a3bc2203
commit
a853e2c36e
@ -0,0 +1,108 @@ |
|||||||
|
import { deduplicatedLogsSelector } from './selectors'; |
||||||
|
import { LogsDedupStrategy } from 'app/core/logs_model'; |
||||||
|
import { ExploreItemState } from 'app/types'; |
||||||
|
|
||||||
|
const state = { |
||||||
|
logsResult: { |
||||||
|
rows: [ |
||||||
|
{ |
||||||
|
entry: '2019-03-05T11:00:56Z sntpc sntpc[1]: offset=-0.033938, delay=0.000649', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T11:00:26Z sntpc sntpc[1]: offset=-0.033730, delay=0.000581', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T10:59:56Z sntpc sntpc[1]: offset=-0.034184, delay=0.001089', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T10:59:26Z sntpc sntpc[1]: offset=-0.033972, delay=0.000582', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T10:58:56Z sntpc sntpc[1]: offset=-0.033955, delay=0.000606', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T10:58:26Z sntpc sntpc[1]: offset=-0.034067, delay=0.000616', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T10:57:56Z sntpc sntpc[1]: offset=-0.034155, delay=0.001021', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T10:57:26Z sntpc sntpc[1]: offset=-0.035797, delay=0.000883', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T10:56:56Z sntpc sntpc[1]: offset=-0.046818, delay=0.000605', |
||||||
|
}, |
||||||
|
{ |
||||||
|
entry: '2019-03-05T10:56:26Z sntpc sntpc[1]: offset=-0.049200, delay=0.000584', |
||||||
|
}, |
||||||
|
], |
||||||
|
}, |
||||||
|
hiddenLogLevels: undefined, |
||||||
|
dedupStrategy: LogsDedupStrategy.none, |
||||||
|
}; |
||||||
|
|
||||||
|
describe('Deduplication selector', () => { |
||||||
|
it('should correctly deduplicate log rows when changing strategy multiple times', () => { |
||||||
|
// Simulating sequence of UI actions that was causing a problem with deduplication counter being visible when unnecessary.
|
||||||
|
// The sequence was changing dedup strategy: (none -> exact -> numbers -> signature -> none) *2 -> exact. After that the first
|
||||||
|
// row contained information that was deduped, while it shouldn't be.
|
||||||
|
// Problem was caused by mutating the log results entries in redux state. The memoisation hash for deduplicatedLogsSelector
|
||||||
|
// was changing depending on duplicates information from log row state, while should be dependand on log row only.
|
||||||
|
|
||||||
|
let dedups = deduplicatedLogsSelector(state as ExploreItemState); |
||||||
|
expect(dedups.rows.length).toBe(10); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.none, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.exact, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.numbers, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.signature, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.none, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.exact, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.numbers, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.signature, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.none, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
dedups = deduplicatedLogsSelector({ |
||||||
|
...state, |
||||||
|
dedupStrategy: LogsDedupStrategy.exact, |
||||||
|
} as ExploreItemState); |
||||||
|
|
||||||
|
// Expecting that no row has duplicates now
|
||||||
|
expect(dedups.rows.reduce((acc, row) => acc + row.duplicates, 0)).toBe(0); |
||||||
|
}); |
||||||
|
}); |
||||||
Loading…
Reference in new issue