Skip to content
Snippets Groups Projects
Select Git revision
  • 1fe7ab7b68b07b35e752d7273aff2aaa3145f39c
  • main default protected
  • renovate/main-renovatebot-github-action-43.x
  • next
  • feat/gnupg
  • fix/36615b-branch-reuse-no-cache
  • renovate/main-redis-5.x
  • chore/punycode
  • 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
  • fix/32307-global-extends-repositories
  • gh-readonly-queue/next/pr-35009-046ebf7cb84ab859f7fefceb5fa53a54ce9736f8
  • 41.45.0
  • 41.44.0
  • 41.43.7
  • 41.43.6
  • 41.43.5
  • 41.43.4
  • 41.43.3
  • 41.43.2
  • 41.43.1
  • 41.43.0
  • 41.42.12
  • 41.42.11
  • 41.42.10
  • 41.42.9
  • 41.42.8
  • 41.42.7
  • 41.42.6
  • 41.42.5
  • 41.42.4
  • 41.42.3
41 results

regex.spec.ts

Blame
  • user avatar
    Sergei Zharinov authored and GitHub committed
    de05ef05
    History
    regex.spec.ts 994 B
    import RE2 from 're2';
    import { CONFIG_VALIDATION } from '../constants/error-messages';
    import { regEx } from './regex';
    
    describe('util/regex', () => {
      beforeEach(() => {
        jest.resetModules();
      });
    
      it('uses RE2', () => {
        expect(regEx('foo')).toBeInstanceOf(RE2);
      });
    
      it('throws unsafe 2', () => {
        expect(() => regEx(`x++`)).toThrow(CONFIG_VALIDATION);
      });
    
      it('reuses flags from regex', () => {
        expect(regEx(/foo/i).flags).toBe('iu');
      });
    
      it('caches non-stateful regex', () => {
        expect(regEx('foo')).toBe(regEx('foo'));
        expect(regEx('foo', 'm')).toBe(regEx('foo', 'm'));
      });
    
      it('does not cache stateful regex', () => {
        expect(regEx('foo', 'g')).not.toBe(regEx('foo', 'g'));
        expect(regEx(/bar/g)).not.toBe(/bar/g);
      });
    
      it('Falls back to RegExp', async () => {
        jest.doMock('re2', () => {
          throw new Error();
        });
    
        const regex = await import('./regex');
        expect(regex.regEx('foo')).toBeInstanceOf(RegExp);
      });
    });