This repository has been archived by the owner on Mar 31, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlogger.test.js
94 lines (74 loc) · 2.26 KB
/
logger.test.js
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/* eslint-disable */
describe('usage', () => {
let winston = null
beforeEach(() => {
jest.resetModules()
jest.mock('winston')
winston = require('winston')
winston.createLogger = jest.fn(() => {
return {
info: jest.fn(),
add: jest.fn()
}
})
winston.format = {
combine: jest.fn(),
timestamp: jest.fn(),
printf: jest.fn(),
}
winston.__transports = jest.fn()
winston.transports = winston.__transports
winston.transports.Console = jest.fn()
winston.__transports.__File = jest.fn()
winston.transports.File = winston.__transports.__File
})
test('sets correct log format - no alias', done => {
delete process.env.PROGRAM_ALIAS
winston.format.printf.mockImplementationOnce(print => {
const msg = print({
timestamp: 'time',
level: 'level',
message: 'message',
})
expect(msg).toBe(':time:level: message')
done()
})
require('./logger')
expect(winston.format.printf).toBeCalled()
})
test('sets correct log format', done => {
process.env.PROGRAM_ALIAS = 'alias'
winston.format.printf.mockImplementationOnce(print => {
const msg = print({
timestamp: 'time',
level: 'level',
message: 'message',
})
expect(msg).toBe('alias:time:level: message')
done()
})
require('./logger')
expect(winston.format.printf).toBeCalled()
})
test('sets logging level - debug', () => {
process.env.LOG_LEVEL = 'debug'
process.env.LOG_FILE = 'false'
require('./logger')
expect(winston.createLogger).toBeCalled()
expect(winston.createLogger.mock.calls[0][0].level).toBe('debug')
})
test('sets logging level - info', () => {
process.env.LOG_LEVEL = 'info'
process.env.LOG_FILE = 'false'
require('./logger')
expect(winston.createLogger).toBeCalled()
expect(winston.createLogger.mock.calls[0][0].level).toBe('info')
})
test('sets logging level - info', () => {
process.env.LOG_LEVEL = 'info'
process.env.LOG_FILE = 'true'
require('./logger')
expect(winston.__transports.__File).toBeCalledWith({ filename: 'error.log', level: 'error' })
expect(winston.__transports.__File).toBeCalledWith({ filename: 'combined.log' })
})
})