Skip to content

Commit d26ccae

Browse files
authored
fix: Fix logger crashing on restart (#22565)
1 parent 989f667 commit d26ccae

File tree

3 files changed

+16
-20
lines changed

3 files changed

+16
-20
lines changed

lib/controller.ts

+1
Original file line numberDiff line numberDiff line change
@@ -60,6 +60,7 @@ export class Controller {
6060
private extensionArgs: ExtensionArgs;
6161

6262
constructor(restartCallback: () => void, exitCallback: (code: number, restart: boolean) => void) {
63+
logger.init();
6364
zhSetLogger(logger);
6465
zhcSetLogger(logger);
6566
this.eventBus = new EventBus();

lib/util/logger.ts

+5-5
Original file line numberDiff line numberDiff line change
@@ -12,13 +12,13 @@ type LogLevel = typeof LOG_LEVELS[number];
1212

1313
class Logger {
1414
private level: LogLevel;
15-
private readonly output: string[];
16-
private readonly directory: string;
17-
private readonly logger: winston.Logger;
18-
private readonly fileTransport: winston.transports.FileTransportInstance;
15+
private output: string[];
16+
private directory: string;
17+
private logger: winston.Logger;
18+
private fileTransport: winston.transports.FileTransportInstance;
1919
private debugNamespaceIgnoreRegex?: RegExp;
2020

21-
constructor() {
21+
public init(): void {
2222
// What transports to enable
2323
this.output = settings.get().advanced.log_output;
2424
// Directory to log to

test/logger.test.js

+10-15
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,8 @@ const {rimrafSync} = require('rimraf');
99
const Transport = require('winston-transport');
1010

1111
describe('Logger', () => {
12+
let logger;
13+
1214
beforeEach(async () => {
1315
data.writeDefaultConfiguration();
1416
jest.resetModules();
@@ -17,21 +19,20 @@ describe('Logger', () => {
1719
settings.reRead();
1820
stdOutWriteOriginal = console._stdout.write;
1921
console._stdout.write = () => {};
22+
logger = require('../lib/util/logger').default;
23+
logger.init();
2024
});
2125

2226
afterEach(async () => {
2327
console._stdout.write = stdOutWriteOriginal;
2428
});
2529

2630
it('Create log directory', () => {
27-
const logger = require('../lib/util/logger').default;
2831
const dirs = fs.readdirSync(dir.name);
2932
expect(dirs.length).toBe(1);
3033
});
3134

3235
it('Should cleanup', () => {
33-
const logger = require('../lib/util/logger').default;
34-
3536
for (const d of fs.readdirSync(dir.name)) {
3637
rimrafSync(path.join(dir.name, d));
3738
}
@@ -46,7 +47,6 @@ describe('Logger', () => {
4647
})
4748

4849
it('Should not cleanup when there is no timestamp set', () => {
49-
const logger = require('../lib/util/logger').default;
5050
for (let i = 30; i < 40; i++) {
5151
fs.mkdirSync(path.join(dir.name, `log_${i}`));
5252
}
@@ -58,7 +58,6 @@ describe('Logger', () => {
5858
})
5959

6060
it('Set and get log level', () => {
61-
const logger = require('../lib/util/logger').default;
6261
logger.setLevel('debug');
6362
expect(logger.getLevel()).toBe('debug');
6463
logger.setLevel('info');
@@ -74,7 +73,7 @@ describe('Logger', () => {
7473
it('Set warning when log level is warn', () => {
7574
settings.set(['advanced', 'log_level'], 'warn');
7675
settings.reRead();
77-
const logger = require('../lib/util/logger').default;
76+
logger.init();
7877
expect(logger.level).toBe('warning');// getLevel() reports old Z2M level to match display/value
7978
settings.set(['advanced', 'log_level'], 'info');
8079
settings.reRead();
@@ -86,7 +85,6 @@ describe('Logger', () => {
8685
}
8786
}
8887

89-
const logger = require('../lib/util/logger').default;
9088
expect(logger.winston.transports.length).toBe(2);
9189
const transport = new DummyTransport();
9290
logger.addTransport(transport);
@@ -96,7 +94,6 @@ describe('Logger', () => {
9694
});
9795

9896
it('Logger should be console and file by default', () => {
99-
const logger = require('../lib/util/logger').default;
10097
const pipes = logger.winston._readableState.pipes;
10198
expect(pipes.length).toBe(2);
10299
expect(pipes[0].constructor.name).toBe('Console');
@@ -107,7 +104,7 @@ describe('Logger', () => {
107104

108105
it('Logger can be file only', () => {
109106
settings.set(['advanced', 'log_output'], ['file']);
110-
const logger = require('../lib/util/logger').default;
107+
logger.init();
111108
const pipes = logger.winston._readableState.pipes;
112109
expect(pipes.length).toBe(2);
113110
expect(pipes[0].constructor.name).toBe('Console');
@@ -118,23 +115,23 @@ describe('Logger', () => {
118115

119116
it('Logger can be console only', () => {
120117
settings.set(['advanced', 'log_output'], ['console']);
121-
const logger = require('../lib/util/logger').default;
118+
logger.init();
122119
const pipes = logger.winston._readableState.pipes;
123120
expect(pipes.constructor.name).toBe('Console');
124121
expect(pipes.silent).toBe(false);
125122
});
126123

127124
it('Logger can be nothing', () => {
128125
settings.set(['advanced', 'log_output'], []);
129-
const logger = require('../lib/util/logger').default;
126+
logger.init();
130127
const pipes = logger.winston._readableState.pipes;
131128
expect(pipes.constructor.name).toBe('Console');
132129
expect(pipes.silent).toBe(true);
133130
});
134131

135132
it('Should allow to disable log rotation', () => {
136133
settings.set(['advanced', 'log_rotation'], false);
137-
const logger = require('../lib/util/logger').default;
134+
logger.init();
138135
const pipes = logger.winston._readableState.pipes;
139136
expect(pipes[1].constructor.name).toBe('File');
140137
expect(pipes[1].maxFiles).toBeNull();
@@ -144,15 +141,14 @@ describe('Logger', () => {
144141

145142
it('Should allow to symlink logs to current directory', () => {
146143
settings.set(['advanced', 'log_symlink_current'], true);
147-
let logger = require('../lib/util/logger').default;
144+
logger.init();
148145
expect(fs.readdirSync(dir.name).includes('current')).toBeTruthy()
149146

150147
jest.resetModules();
151148
logger = require('../lib/util/logger').default;
152149
});
153150

154151
it('Log', () => {
155-
const logger = require('../lib/util/logger').default;
156152
logger.setLevel('debug');
157153

158154
const debug = jest.spyOn(logger.winston, 'debug');
@@ -221,7 +217,6 @@ describe('Logger', () => {
221217
]
222218
],
223219
])('Sets namespace ignore for debug level %s', (ignore, expected, tests) => {
224-
const logger = require('../lib/util/logger').default;
225220
logger.setLevel('debug');
226221
const debugSpy = jest.spyOn(logger.winston, 'debug');
227222
logger.setDebugNamespaceIgnore(ignore);

0 commit comments

Comments
 (0)