/
filterLogHook.ts
64 lines (59 loc) · 1.4 KB
/
filterLogHook.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import { type Log } from '@pnpm/core-loggers'
import { toOutput$ } from '@pnpm/default-reporter'
import { logger, createStreamParser } from '@pnpm/logger'
test('logger with filterLog hook', (done) => {
const output$ = toOutput$({
context: {
argv: ['install'],
config: {
hooks: {
filterLog: [(log: Log) => {
if (log.level === 'debug') {
return false
}
if (log.level === 'warn') {
if (log.message === 'aaa') {
return false
}
if (log.prefix === '/tmp') {
return false
}
}
return true
}],
},
} as any, // eslint-disable-line
},
streamParser: createStreamParser(),
})
// debug level is filtered out
logger.debug({
message: 'debug message',
})
// message equals to 'aaa' is filtered out
logger.warn({
message: 'aaa',
prefix: '/root',
})
logger.warn({
message: 'bbb',
prefix: '/root',
})
// prefix equals to '/tmp' is filtered out
logger.warn({
message: 'ccc',
prefix: '/tmp',
})
expect.assertions(1)
const subscription = output$.subscribe({
complete: () => done(),
error: done,
next: (msg) => {
expect(msg).toEqual(expect.stringContaining('bbb'))
},
})
setTimeout(() => {
done()
subscription.unsubscribe()
}, 10)
})