소스 검색

Merge branch 'SamuelToh-11780_wrong_repexp_in_series'

Torkel Ödegaard 6 년 전
부모
커밋
747aa82272
2개의 변경된 파일20개의 추가작업 그리고 0개의 파일을 삭제
  1. 15 0
      public/app/core/specs/kbn.test.ts
  2. 5 0
      public/app/core/utils/kbn.ts

+ 15 - 0
public/app/core/specs/kbn.test.ts

@@ -0,0 +1,15 @@
+import kbn from '../utils/kbn';
+
+describe('stringToJsRegex', () => {
+  it('should parse the valid regex value', () => {
+    const output = kbn.stringToJsRegex('/validRegexp/');
+    expect(output).toBeInstanceOf(RegExp);
+  });
+
+  it('should throw error on invalid regex value', () => {
+    const input = '/etc/hostname';
+    expect(() => {
+      kbn.stringToJsRegex(input);
+    }).toThrow();
+  });
+});

+ 5 - 0
public/app/core/utils/kbn.ts

@@ -234,6 +234,11 @@ kbn.stringToJsRegex = str => {
   }
 
   const match = str.match(new RegExp('^/(.*?)/(g?i?m?y?)$'));
+
+  if (!match) {
+    throw new Error(`'${str}' is not a valid regular expression.`);
+  }
+
   return new RegExp(match[1], match[2]);
 };