Skip to content
Snippets Groups Projects
Select Git revision
  • aabb3abf9ab691fb22816aa0e33d4b379e831efd
  • main default protected
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • next
  • revert-31645-feat/rename-gradle-wrapper-validation-action
  • renovate/main-redis-5.x
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • fix/36615-branch-reuse-bug
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • fix/32307-global-extends-merging
  • 41.30.4
  • 41.30.3
  • 41.30.2
  • 41.30.1
  • 41.30.0
  • 41.29.1
  • 41.29.0
  • 41.28.2
  • 41.28.1
  • 41.28.0
  • 41.27.1
  • 41.27.0
  • 41.26.2
  • 41.26.1
  • 41.26.0
  • 41.25.1
  • 41.25.0
  • 41.24.0
  • 41.23.5
  • 41.23.4
41 results

index.ts

Blame
  • err-serializer.spec.ts 2.68 KiB
    import * as httpMock from '../../test/http-mock';
    import { partial } from '../../test/util';
    import * as hostRules from '../util/host-rules';
    import { Http } from '../util/http';
    import errSerializer from './err-serializer';
    import { sanitizeValue } from './utils';
    
    describe('logger/err-serializer', () => {
      it('expands errors', () => {
        const err = partial<Error & Record<string, unknown>>({
          a: 1,
          b: 2,
          message: 'some message',
          response: {
            body: 'some response body',
            url: 'some/path',
          },
          options: {
            headers: {
              authorization: 'Bearer testtoken',
            },
          },
        });
        expect(errSerializer(err)).toEqual({
          a: 1,
          b: 2,
          message: 'some message',
          response: {
            body: 'some response body',
            url: 'some/path',
          },
          options: {
            headers: {
              authorization: 'Bearer testtoken',
            },
          },
        });
      });
      it('handles missing fields', () => {
        const err = partial<Error & Record<string, unknown>>({
          a: 1,
          stack: 'foo',
          body: 'some body',
        });
        expect(errSerializer(err)).toEqual({
          a: 1,
          stack: 'foo',
          body: 'some body',
        });
      });
    
      describe('got', () => {
        const baseUrl = 'https://github.com';
    
        beforeEach(() => {
          // reset module
          jest.resetAllMocks();
          // clean up hostRules
          hostRules.clear();
          hostRules.add({
            hostType: 'any',
            matchHost: baseUrl,
            token: 'token',
          });
        });
    
        it('handles http error', async () => {
          httpMock
            .scope(baseUrl)
            .post('/api')
            .reply(412, { err: { message: 'failed' } });
          let err: any;
          try {
            await new Http('any').postJson('https://:token@github.com/api');
          } catch (error) {
            err = errSerializer(error);
          }
    
          expect(err).toBeDefined();
          expect(err.response.body).toBeDefined();
          expect(err.options).toBeDefined();
        });
    
        it('sanitize http error', async () => {
          httpMock
            .scope(baseUrl)
            .post('/api')
            .reply(412, { err: { message: 'failed' } });
          let err: any;
          try {
            await new Http('any').postJson('https://:token@github.com/api');
          } catch (error) {
            err = error;
          }
    
          expect(err).toBeDefined();
    
          // remove platform related props
          delete err.timings;
          delete err.stack;
    
          // sanitize like Bunyan
          expect(sanitizeValue(err)).toMatchSnapshot({
            name: 'HTTPError',
            options: {
              method: 'POST',
              password: '***********',
              url: 'https://:**redacted**@github.com/api',
              username: '',
            },
          });
        });
      });
    });