Logs: Improve log level guess (#22094)

Fixes #22075
This commit is contained in:
Emil Tullstedt 2020-03-04 09:48:21 +01:00 committed by GitHub
parent 5166073f98
commit 3c6a7a51bf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 5 deletions

View File

@ -35,6 +35,7 @@ describe('getLoglevel()', () => {
it('returns first log level found', () => {
expect(getLogLevel('WARN this could be a debug message')).toBe(LogLevel.warn);
expect(getLogLevel('WARN this is a non-critical message')).toBe(LogLevel.warn);
});
});

View File

@ -20,16 +20,21 @@ export function getLogLevel(line: string): LogLevel {
if (!line) {
return LogLevel.unknown;
}
let level = LogLevel.unknown;
let currentIndex: number | undefined = undefined;
for (const key of Object.keys(LogLevel)) {
const regexp = new RegExp(`\\b${key}\\b`, 'i');
if (regexp.test(line)) {
const level = (LogLevel as any)[key];
if (level) {
return level;
const result = regexp.exec(line);
if (result) {
if (currentIndex === undefined || result.index < currentIndex) {
level = (LogLevel as any)[key];
currentIndex = result.index;
}
}
}
return LogLevel.unknown;
return level;
}
export function getLogLevelFromKey(key: string): LogLevel {