|
5 | 5 | inferValue, |
6 | 6 | extractRegexAndReplacement, |
7 | 7 | splitByNotEscapedDelimiter, |
| 8 | + splitByPipeRespectingRegex, |
8 | 9 | } from '../../src/helpers'; |
9 | 10 |
|
10 | 11 | describe('Test string utils', () => { |
@@ -527,4 +528,153 @@ describe('Test string utils', () => { |
527 | 528 | expect(result).toStrictEqual([',']); |
528 | 529 | }); |
529 | 530 | }); |
| 531 | + |
| 532 | + describe('splitByPipeRespectingRegex', () => { |
| 533 | + test('regexp with pipe character - issue #473', () => { |
| 534 | + const result = splitByPipeRespectingRegex('/(foo|bar)/'); |
| 535 | + expect(result).toStrictEqual(['/(foo|bar)/']); |
| 536 | + }); |
| 537 | + |
| 538 | + test('regexp with pipe and additional string argument', () => { |
| 539 | + const result = splitByPipeRespectingRegex('/(foo|bar)/|"test"'); |
| 540 | + expect(result).toStrictEqual([ |
| 541 | + '/(foo|bar)/', |
| 542 | + '"test"', |
| 543 | + ]); |
| 544 | + }); |
| 545 | + |
| 546 | + test('regexp with pipe and multiple string arguments', () => { |
| 547 | + const result = splitByPipeRespectingRegex('/(key|other)/|"test-value"|"prevent"'); |
| 548 | + expect(result).toStrictEqual([ |
| 549 | + '/(key|other)/', |
| 550 | + '"test-value"', |
| 551 | + '"prevent"', |
| 552 | + ]); |
| 553 | + }); |
| 554 | + |
| 555 | + test('multiple regexp patterns with pipes and string argument', () => { |
| 556 | + const result = splitByPipeRespectingRegex('/(a|b)/|/(#c|d)/|"string"'); |
| 557 | + expect(result).toStrictEqual([ |
| 558 | + '/(a|b)/', |
| 559 | + '/(#c|d)/', |
| 560 | + '"string"', |
| 561 | + ]); |
| 562 | + }); |
| 563 | + |
| 564 | + test('regexp with flags', () => { |
| 565 | + const result = splitByPipeRespectingRegex('/pattern/gi|123'); |
| 566 | + expect(result).toStrictEqual([ |
| 567 | + '/pattern/gi', |
| 568 | + '123', |
| 569 | + ]); |
| 570 | + }); |
| 571 | + |
| 572 | + test('regexp with escaped slash inside', () => { |
| 573 | + const result = splitByPipeRespectingRegex('/foo\\/bar/|"test"'); |
| 574 | + expect(result).toStrictEqual([ |
| 575 | + '/foo\\/bar/', |
| 576 | + '"test"', |
| 577 | + ]); |
| 578 | + }); |
| 579 | + |
| 580 | + test('Complex regex with multiple pipes and escaped slashes', () => { |
| 581 | + const result = splitByPipeRespectingRegex('/(a\\/b|c\\/d)/|"value"'); |
| 582 | + expect(result).toStrictEqual([ |
| 583 | + '/(a\\/b|c\\/d)/', |
| 584 | + '"value"', |
| 585 | + ]); |
| 586 | + }); |
| 587 | + |
| 588 | + test('No regex, only strings', () => { |
| 589 | + const result = splitByPipeRespectingRegex('"string1"|"string2"|"string3"'); |
| 590 | + expect(result).toStrictEqual([ |
| 591 | + '"string1"', |
| 592 | + '"string2"', |
| 593 | + '"string3"', |
| 594 | + ]); |
| 595 | + }); |
| 596 | + |
| 597 | + test('Empty string', () => { |
| 598 | + const result = splitByPipeRespectingRegex(''); |
| 599 | + expect(result).toStrictEqual(['']); |
| 600 | + }); |
| 601 | + |
| 602 | + test('String with no pipes', () => { |
| 603 | + const result = splitByPipeRespectingRegex('"single-value"'); |
| 604 | + expect(result).toStrictEqual(['"single-value"']); |
| 605 | + }); |
| 606 | + |
| 607 | + test('regexp at the end', () => { |
| 608 | + const result = splitByPipeRespectingRegex('"test"|/(a|b)/'); |
| 609 | + expect(result).toStrictEqual([ |
| 610 | + '"test"', |
| 611 | + '/(a|b)/', |
| 612 | + ]); |
| 613 | + }); |
| 614 | + |
| 615 | + test('regexp with all supported flags', () => { |
| 616 | + const result = splitByPipeRespectingRegex('/(test|value)/gimsu|"arg"'); |
| 617 | + expect(result).toStrictEqual([ |
| 618 | + '/(test|value)/gimsu', |
| 619 | + '"arg"', |
| 620 | + ]); |
| 621 | + }); |
| 622 | + |
| 623 | + test('Object notation with pipes', () => { |
| 624 | + const result = splitByPipeRespectingRegex('{"a":1}|{"b":2}'); |
| 625 | + expect(result).toStrictEqual([ |
| 626 | + '{"a":1}', |
| 627 | + '{"b":2}', |
| 628 | + ]); |
| 629 | + }); |
| 630 | + |
| 631 | + test('Mixed types: regex, object, string', () => { |
| 632 | + const result = splitByPipeRespectingRegex('/(a|b)/|{"key":"val"}|"string"'); |
| 633 | + expect(result).toStrictEqual([ |
| 634 | + '/(a|b)/', |
| 635 | + '{"key":"val"}', |
| 636 | + '"string"', |
| 637 | + ]); |
| 638 | + }); |
| 639 | + |
| 640 | + test('Pipe at start (empty first segment)', () => { |
| 641 | + const result = splitByPipeRespectingRegex('|"test"'); |
| 642 | + expect(result).toStrictEqual([ |
| 643 | + '', |
| 644 | + '"test"', |
| 645 | + ]); |
| 646 | + }); |
| 647 | + |
| 648 | + test('Pipe at end (empty last segment)', () => { |
| 649 | + const result = splitByPipeRespectingRegex('"test"|'); |
| 650 | + expect(result).toStrictEqual([ |
| 651 | + '"test"', |
| 652 | + '', |
| 653 | + ]); |
| 654 | + }); |
| 655 | + |
| 656 | + test('Consecutive pipes (empty segments)', () => { |
| 657 | + const result = splitByPipeRespectingRegex('"a"||"b"'); |
| 658 | + expect(result).toStrictEqual([ |
| 659 | + '"a"', |
| 660 | + '', |
| 661 | + '"b"', |
| 662 | + ]); |
| 663 | + }); |
| 664 | + |
| 665 | + test('regexp with no closing slash (stays in regex mode)', () => { |
| 666 | + const result = splitByPipeRespectingRegex('/incomplete|"test"'); |
| 667 | + expect(result).toStrictEqual([ |
| 668 | + '/incomplete|"test"', |
| 669 | + ]); |
| 670 | + }); |
| 671 | + |
| 672 | + test('Real-world example from localStorage.setItem', () => { |
| 673 | + const result = splitByPipeRespectingRegex('/key/|"test-value"'); |
| 674 | + expect(result).toStrictEqual([ |
| 675 | + '/key/', |
| 676 | + '"test-value"', |
| 677 | + ]); |
| 678 | + }); |
| 679 | + }); |
530 | 680 | }); |
0 commit comments