diff --git a/tests/lib/Search/Query/Location/CriterionVisitor/Location/IsBookmarkedTest.php b/tests/lib/Search/Query/Location/CriterionVisitor/Location/IsBookmarkedTest.php new file mode 100644 index 00000000..aa242b96 --- /dev/null +++ b/tests/lib/Search/Query/Location/CriterionVisitor/Location/IsBookmarkedTest.php @@ -0,0 +1,108 @@ +permissionResolver = $this->createMock(PermissionResolver::class); + $this->visitor = new IsBookmarked($this->permissionResolver); + } + + /** + * @dataProvider provideDataForTestCanVisit + */ + public function testCanVisit( + bool $expected, + Criterion $criterion + ): void { + self::assertSame( + $expected, + $this->visitor->canVisit($criterion) + ); + } + + /** + * @return iterable + */ + public function provideDataForTestCanVisit(): iterable + { + yield 'Not supported criterion' => [ + false, + new Criterion\ContentId(123), + ]; + + yield 'Supported criterion' => [ + true, + new Criterion\Location\IsBookmarked(), + ]; + } + + /** + * @dataProvider provideDataForTestVisit + */ + public function testVisit( + string $expected, + Criterion $criterion + ): void { + $this->mockPermissionResolverGetCurrentUserReference(); + + self::assertSame( + $expected, + $this->visitor->visit($criterion) + ); + } + + /** + * @return iterable + */ + public function provideDataForTestVisit(): iterable + { + yield 'Query for bookmarked locations' => [ + 'location_bookmarked_user_ids_mid:"123"', + new Criterion\Location\IsBookmarked(), + ]; + + yield 'Query for not bookmarked locations' => [ + 'NOT location_bookmarked_user_ids_mid:"123"', + new Criterion\Location\IsBookmarked(false), + ]; + } + + private function mockPermissionResolverGetCurrentUserReference(): void + { + $this->permissionResolver + ->method('getCurrentUserReference') + ->willReturn(new UserReference(self::USER_ID)); + } +}