mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-02 09:35:40 -05:00
* Fix initial build breaks from 1.67 merge (#2514) * Update yarn lock files * Update build scripts * Fix tsconfig * Build breaks * WIP * Update yarn lock files * Misc breaks * Updates to package.json * Breaks * Update yarn * Fix breaks * Breaks * Build breaks * Breaks * Breaks * Breaks * Breaks * Breaks * Missing file * Breaks * Breaks * Breaks * Breaks * Breaks * Fix several runtime breaks (#2515) * Missing files * Runtime breaks * Fix proxy ordering issue * Remove commented code * Fix breaks with opening query editor * Fix post merge break * Updates related to setup build and other breaks (#2516) * Fix bundle build issues * Update distro * Fix distro merge and update build JS files * Disable pipeline steps * Remove stats call * Update license name * Make new RPM dependencies a warning * Fix extension manager version checks * Update JS file * Fix a few runtime breaks * Fixes * Fix runtime issues * Fix build breaks * Update notebook tests (part 1) * Fix broken tests * Linting errors * Fix hygiene * Disable lint rules * Bump distro * Turn off smoke tests * Disable integration tests * Remove failing "activate" test * Remove failed test assertion * Disable other broken test * Disable query history tests * Disable extension unit tests * Disable failing tasks
66 lines
1.7 KiB
TypeScript
66 lines
1.7 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import { appendFileSync, writeFileSync } from 'fs';
|
|
import { format } from 'util';
|
|
import { EOL } from 'os';
|
|
|
|
export interface Logger {
|
|
log(message: string, ...args: any[]): void;
|
|
}
|
|
|
|
export class ConsoleLogger implements Logger {
|
|
|
|
log(message: string, ...args: any[]): void {
|
|
console.log('**', message, ...args);
|
|
}
|
|
}
|
|
|
|
export class FileLogger implements Logger {
|
|
|
|
constructor(private path: string) {
|
|
writeFileSync(path, '');
|
|
}
|
|
|
|
log(message: string, ...args: any[]): void {
|
|
const date = new Date().toISOString();
|
|
appendFileSync(this.path, `[${date}] ${format(message, ...args)}${EOL}`);
|
|
}
|
|
}
|
|
|
|
export class MultiLogger implements Logger {
|
|
|
|
constructor(private loggers: Logger[]) { }
|
|
|
|
log(message: string, ...args: any[]): void {
|
|
for (const logger of this.loggers) {
|
|
logger.log(message, ...args);
|
|
}
|
|
}
|
|
}
|
|
|
|
export async function measureAndLog<T>(promise: Promise<T>, name: string, logger: Logger): Promise<T> {
|
|
const now = Date.now();
|
|
|
|
logger.log(`Starting operation '${name}...`);
|
|
|
|
let res: T | undefined = undefined;
|
|
let e: unknown;
|
|
try {
|
|
res = await promise;
|
|
} catch (error) {
|
|
e = error;
|
|
}
|
|
|
|
if (e) {
|
|
logger.log(`Finished operation '${name}' with error ${e} after ${Date.now() - now}ms`);
|
|
throw e;
|
|
}
|
|
|
|
logger.log(`Finished operation '${name}' successfully after ${Date.now() - now}ms`);
|
|
|
|
return res as unknown as T;
|
|
}
|