https://github.com/angular/angular
Raw File
Tip revision: 56e085f3f840290440a7fc32911160c21f231ba5 authored by Kristiyan Kostadinov on 10 October 2023, 16:57:09 UTC
build: remove Windows CI check (#52140) (#55527)
Tip revision: 56e085f
logger.service.spec.ts
import { ErrorHandler, Injector } from '@angular/core';
import { Logger } from './logger.service';

describe('logger service', () => {
  let logSpy: jasmine.Spy;
  let warnSpy: jasmine.Spy;
  let logger: Logger;
  let errorHandler: ErrorHandler;

  beforeEach(() => {
    logSpy = spyOn(console, 'log');
    warnSpy = spyOn(console, 'warn');
    const injector = Injector.create({providers: [
      { provide: Logger, deps: [ErrorHandler] },
      { provide: ErrorHandler, useClass: MockErrorHandler, deps: [] }
    ]});
    logger = injector.get(Logger);
    errorHandler = injector.get(ErrorHandler);
  });

  describe('log', () => {
    it('should delegate to console.log', () => {
      logger.log('param1', 'param2', 'param3');
      expect(logSpy).toHaveBeenCalledWith('param1', 'param2', 'param3');
    });
  });

  describe('warn', () => {
    it('should delegate to console.warn', () => {
      logger.warn('param1', 'param2', 'param3');
      expect(warnSpy).toHaveBeenCalledWith('param1', 'param2', 'param3');
    });
  });

  describe('error', () => {
    it('should delegate to ErrorHandler', () => {
      const err = new Error('some error message');
      logger.error(err);
      expect(errorHandler.handleError).toHaveBeenCalledWith(err);
    });
  });
});


class MockErrorHandler implements ErrorHandler {
  handleError = jasmine.createSpy('handleError');
}
back to top