mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-26 20:12:33 +00:00 
			
		
		
		
	 f1dd770a8a
			
		
	
	
		f1dd770a8a
		
	
	
	
	
		
			
			The spec requires that invalid RegExp literals must cause a Syntax Error before the JavaScript is executed. See: https://tc39.es/ecma262/#sec-patterns-static-semantics-early-errors This is explicitly tested in the RegExp/property-escapes test262 tests. For example, see unsupported-property-Line_Break.js: $DONOTEVALUATE(); /\p{Line_Break}/u; That RegExp literal is invalid because Line_Break is not a supported Unicode property. $DONOTEVALUATE() just throws an exception when it is executed. The test expects that this file will fail to be parsed. Note that RegExp patterns can still be parsed at execution time by way of "new RegExp(...)".
		
			
				
	
	
		
			62 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| describe("errors", () => {
 | |
|     test("invalid pattern", () => {
 | |
|         expect(() => {
 | |
|             RegExp("[");
 | |
|         }).toThrowWithMessage(
 | |
|             SyntaxError,
 | |
|             "RegExp compile error: Error during parsing of regular expression:"
 | |
|         );
 | |
|     });
 | |
| 
 | |
|     test("invalid flag", () => {
 | |
|         expect(() => {
 | |
|             RegExp("", "x");
 | |
|         }).toThrowWithMessage(SyntaxError, "Invalid RegExp flag 'x'");
 | |
|     });
 | |
| 
 | |
|     test("repeated flag", () => {
 | |
|         expect(() => {
 | |
|             RegExp("", "gg");
 | |
|         }).toThrowWithMessage(SyntaxError, "Repeated RegExp flag 'g'");
 | |
|     });
 | |
| });
 | |
| 
 | |
| test("basic functionality", () => {
 | |
|     expect(RegExp().toString()).toBe("/(?:)/");
 | |
|     expect(RegExp(undefined).toString()).toBe("/(?:)/");
 | |
|     expect(RegExp("foo").toString()).toBe("/foo/");
 | |
|     expect(RegExp("foo", undefined).toString()).toBe("/foo/");
 | |
|     expect(RegExp("foo", "g").toString()).toBe("/foo/g");
 | |
|     expect(RegExp(undefined, "g").toString()).toBe("/(?:)/g");
 | |
| });
 | |
| 
 | |
| test("regexp object as pattern parameter", () => {
 | |
|     expect(RegExp(/foo/).toString()).toBe("/foo/");
 | |
|     expect(RegExp(/foo/g).toString()).toBe("/foo/g");
 | |
|     expect(RegExp(/foo/g, "").toString()).toBe("/foo/");
 | |
|     expect(RegExp(/foo/g, "y").toString()).toBe("/foo/y");
 | |
| 
 | |
|     var regex_like_object_without_flags = {
 | |
|         source: "foo",
 | |
|         [Symbol.match]: function () {},
 | |
|     };
 | |
|     expect(RegExp(regex_like_object_without_flags).toString()).toBe("/foo/");
 | |
|     expect(RegExp(regex_like_object_without_flags, "y").toString()).toBe("/foo/y");
 | |
| 
 | |
|     var regex_like_object_with_flags = {
 | |
|         source: "foo",
 | |
|         flags: "g",
 | |
|         [Symbol.match]: function () {},
 | |
|     };
 | |
|     expect(RegExp(regex_like_object_with_flags).toString()).toBe("/foo/g");
 | |
|     expect(RegExp(regex_like_object_with_flags, "").toString()).toBe("/foo/");
 | |
|     expect(RegExp(regex_like_object_with_flags, "y").toString()).toBe("/foo/y");
 | |
| });
 | |
| 
 | |
| test("regexp literals are re-useable", () => {
 | |
|     for (var i = 0; i < 2; ++i) {
 | |
|         const re = /test/;
 | |
|         expect(re.test("te")).toBeFalse();
 | |
|         expect(re.test("test")).toBeTrue();
 | |
|     }
 | |
| });
 |