|
9 | 9 | use function PHPUnit\Framework\assertObjectHasProperty; |
10 | 10 |
|
11 | 11 | use Spatie\QueryBuilder\AllowedFilter; |
| 12 | +use Spatie\QueryBuilder\Enums\FilterOperator; |
12 | 13 | use Spatie\QueryBuilder\Exceptions\InvalidFilterQuery; |
13 | 14 | use Spatie\QueryBuilder\Filters\Filter as CustomFilter; |
14 | 15 | use Spatie\QueryBuilder\Filters\Filter as FilterInterface; |
@@ -657,3 +658,116 @@ public function __invoke(Builder $query, $value, string $property): Builder |
657 | 658 | ->get(); |
658 | 659 | expect($models->count())->toEqual(0); |
659 | 660 | }); |
| 661 | + |
| 662 | +it('can filter name with equal operator filter', function () { |
| 663 | + TestModel::create(['name' => 'John Doe']); |
| 664 | + |
| 665 | + $results = createQueryFromFilterRequest([ |
| 666 | + 'name' => 'John Doe', |
| 667 | + ]) |
| 668 | + ->allowedFilters(AllowedFilter::operator('name', FilterOperator::EQUAL)) |
| 669 | + ->get(); |
| 670 | + |
| 671 | + expect($results)->toHaveCount(1); |
| 672 | +}); |
| 673 | + |
| 674 | +it('can filter name with not equal operator filter', function () { |
| 675 | + TestModel::create(['name' => 'John Doe']); |
| 676 | + |
| 677 | + $results = createQueryFromFilterRequest([ |
| 678 | + 'name' => 'John Doe', |
| 679 | + ]) |
| 680 | + ->allowedFilters(AllowedFilter::operator('name', FilterOperator::NOT_EQUAL)) |
| 681 | + ->get(); |
| 682 | + |
| 683 | + expect($results)->toHaveCount(5); |
| 684 | +}); |
| 685 | + |
| 686 | +it('can filter salary with greater than operator filter', function () { |
| 687 | + TestModel::create(['salary' => 5000]); |
| 688 | + |
| 689 | + $results = createQueryFromFilterRequest([ |
| 690 | + 'salary' => 3000, |
| 691 | + ]) |
| 692 | + ->allowedFilters(AllowedFilter::operator('salary', FilterOperator::GREATER_THAN)) |
| 693 | + ->get(); |
| 694 | + |
| 695 | + expect($results)->toHaveCount(1); |
| 696 | +}); |
| 697 | + |
| 698 | +it('can filter salary with less than operator filter', function () { |
| 699 | + TestModel::create(['salary' => 5000]); |
| 700 | + |
| 701 | + $results = createQueryFromFilterRequest([ |
| 702 | + 'salary' => 7000, |
| 703 | + ]) |
| 704 | + ->allowedFilters(AllowedFilter::operator('salary', FilterOperator::LESS_THAN)) |
| 705 | + ->get(); |
| 706 | + |
| 707 | + expect($results)->toHaveCount(1); |
| 708 | +}); |
| 709 | + |
| 710 | +it('can filter salary with greater than or equal operator filter', function () { |
| 711 | + TestModel::create(['salary' => 5000]); |
| 712 | + |
| 713 | + $results = createQueryFromFilterRequest([ |
| 714 | + 'salary' => 3000, |
| 715 | + ]) |
| 716 | + ->allowedFilters(AllowedFilter::operator('salary', FilterOperator::GREATER_THAN_OR_EQUAL)) |
| 717 | + ->get(); |
| 718 | + |
| 719 | + expect($results)->toHaveCount(1); |
| 720 | +}); |
| 721 | + |
| 722 | +it('can filter salary with less than or equal operator filter', function () { |
| 723 | + TestModel::create(['salary' => 5000]); |
| 724 | + |
| 725 | + $results = createQueryFromFilterRequest([ |
| 726 | + 'salary' => 7000, |
| 727 | + ]) |
| 728 | + ->allowedFilters(AllowedFilter::operator('salary', FilterOperator::LESS_THAN_OR_EQUAL)) |
| 729 | + ->get(); |
| 730 | + |
| 731 | + expect($results)->toHaveCount(1); |
| 732 | +}); |
| 733 | + |
| 734 | +it('can filter array of names with equal operator filter', function () { |
| 735 | + TestModel::create(['name' => 'John Doe']); |
| 736 | + TestModel::create(['name' => 'Max Doe']); |
| 737 | + |
| 738 | + $results = createQueryFromFilterRequest([ |
| 739 | + 'name' => 'John Doe,Max Doe', |
| 740 | + ]) |
| 741 | + ->allowedFilters(AllowedFilter::operator('name', FilterOperator::EQUAL, 'or')) |
| 742 | + ->get(); |
| 743 | + |
| 744 | + expect($results)->toHaveCount(2); |
| 745 | +}); |
| 746 | + |
| 747 | +it('can filter salary with dynamic operator filter', function () { |
| 748 | + TestModel::create(['salary' => 5000]); |
| 749 | + TestModel::create(['salary' => 2000]); |
| 750 | + |
| 751 | + $results = createQueryFromFilterRequest([ |
| 752 | + 'salary' => '>2000', |
| 753 | + ]) |
| 754 | + ->allowedFilters(AllowedFilter::operator('salary', FilterOperator::DYNAMIC)) |
| 755 | + ->get(); |
| 756 | + |
| 757 | + expect($results)->toHaveCount(1); |
| 758 | +}); |
| 759 | + |
| 760 | +it('can filter salary with dynamic array operator filter', function () { |
| 761 | + TestModel::create(['salary' => 1000]); |
| 762 | + TestModel::create(['salary' => 2000]); |
| 763 | + TestModel::create(['salary' => 3000]); |
| 764 | + TestModel::create(['salary' => 4000]); |
| 765 | + |
| 766 | + $results = createQueryFromFilterRequest([ |
| 767 | + 'salary' => '>1000,<4000', |
| 768 | + ]) |
| 769 | + ->allowedFilters(AllowedFilter::operator('salary', FilterOperator::DYNAMIC)) |
| 770 | + ->get(); |
| 771 | + |
| 772 | + expect($results)->toHaveCount(2); |
| 773 | +}); |
0 commit comments