Package Data | |
---|---|
Maintainer Username: | Sti3bas |
Maintainer Contact: | sti3bas@gmail.com (Laurynas Geigalas) |
Package Create Date: | 2019-08-25 |
Package Last Update: | 2024-10-26 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-16 03:03:19 |
Package Statistics | |
---|---|
Total Downloads: | 893,838 |
Monthly Downloads: | 18,005 |
Daily Downloads: | 1,335 |
Total Stars: | 89 |
Total Watchers: | 1 |
Total Forks: | 8 |
Total Open Issues: | 5 |
This package adds array
driver to Laravel Scout and provides custom PHPUnit assertions to make testing search related functionality easier.
Install the package via Composer:
composer require sti3bas/laravel-scout-array-driver --dev
Set Scout driver to array
in .env.testing
file:
SCOUT_DRIVER=array
or in phpunit.xml
file:
<env name="SCOUT_DRIVER" value="array"/>
The Search
facade provides the following methods and assertions:
Checks if model exists in the search index.
$user = factory(User::class)->create([
'name' => 'Oliver',
]);
$user2 = User::withoutSyncingToSearch(function () {
return factory(User::class)->create([
'name' => 'John',
]);
});
Search::assertContains($user) // passes
->assertContains($user2) // fails
->assertContains($user, function ($record) { // passes
return $record['name'] === 'Oliver';
})
->assertContains($user, function ($record) { // fails
return $record['name'] === 'John';
})
->assertContains($user2, function ($record) { // fails
return $record['name'] === 'John';
});
Checks if model doesn't exist in the search index.
$user = factory(User::class)->create([
'name' => 'Oliver',
]);
$user2 = User::withoutSyncingToSearch(function () {
return factory(User::class)->create([
'name' => 'John',
]);
});
Search::assertNotContains($user) // fails
->assertNotContains($user2) // passes
->assertNotContains($user, function ($record) { // fails
return $record['name'] === 'Oliver';
})
->assertNotContains($user, function ($record) { // passes
return $record['name'] === 'John';
})
->assertNotContains($user2, function ($record) { // passes
return $record['name'] === 'John';
});
Checks if model exists in custom search index.
$user = factory(User::class)->create([
'name' => 'Oliver',
]);
Search::assertContainsIn('users', $user) // passes
->assertContainsIn('non_existing_index', $user) // fails
->assertContainsIn('users', $user, function ($record) { // passes
return $record['name'] === 'Oliver';
})
->assertContainsIn('users', $user, function ($record) { // fails
return $record['name'] === 'John';
});
Checks if model doesn't exist in custom search index.
$user = factory(User::class)->create([
'name' => 'Oliver',
]);
Search::assertNotContainsIn('users', $user) // fails
->assertNotContainsIn('non_existing_index', $user) // passes
->assertNotContainsIn('users', $user, function ($record) { // fails
return $record['name'] === 'Oliver';
})
->assertNotContainsIn('users', $user, function ($record) { // passes
return $record['name'] === 'John';
});
Checks if all search indexes are empty.
Search::assertEmpty(); // passes
factory(User::class)->create();
Search::assertEmpty(); // fails
Checks if search index is empty.
Search::assertEmptyIn('users'); // passes
factory(User::class)->create();
Search::assertEmptyIn('users'); // fails
Checks if there is at least one record in any of search indexes.
Search::assertNotEmpty(); // fails
factory(User::class)->create();
Search::assertNotEmpty(); // passes
Checks if search index is not empty.
Search::assertNotEmptyIn('users'); // fails
factory(User::class)->create();
Search::assertNotEmptyIn('users'); // passes
Checks if model was synced to search index. This assertion checks every record of the given model which was synced during the request.
$user = factory(User::class)->create([
'name' => 'Peter',
]);
Search::assertSynced($user); // passes
$user->update(['name' => 'John']);
$user->delete();
Search::assertContains($user) // fails
->assertSynced($user) // passes
->assertSynced($user, function ($record) { // passes
return $record['name'] === 'Peter';
})
->assertSynced($user, function ($record) { // passes
return $record['name'] === 'John';
})
->assertSynced($user, function ($record) { // fails
return $record['name'] === 'Oliver';
});
Checks if model wasn't synced to search index. This assertion checks every record of the given model which was synced during the request.
$user = factory(User::class)->create([
'name' => 'Peter',
]);
Search::assertNotSynced($user); // fails
$user->update(['name' => 'John']);
$user->delete();
Search::assertContains($user) // fails
->assertNotSynced($user); // fails
Search::assertNotSynced($user, function ($record) { // fails
return $record['name'] === 'Peter';
})
->assertNotSynced($user, function ($record) { // fails
return $record['name'] === 'John';
})
->assertNotSynced($user, function ($record) { // passes
return $record['name'] === 'Oliver';
});
Checks if model was synced to custom search index. This assertion checks every record of the given model which was synced during the request.
$user = factory(User::class)->create([
'name' => 'Peter',
]);
Search::assertSyncedTo('users', $user); // passes
$user->update(['name' => 'John']);
$user->delete();
Search::assertContains($user) // fails
->assertSyncedTo('users', $user) // passes
->assertSyncedTo('users', $user, function ($record) {
return $record['name'] === 'Peter'; // passes
})
->assertSyncedTo('users', $user, function ($record) {
return $record['name'] === 'John'; // passes
})
->assertSyncedTo('non_existing_index', $user, function ($record) {
return $record['name'] === 'John'; // fails
});
Checks if model wasn't synced to custom search index. This assertion checks every record of the given model which was synced during the request.
$user = factory(User::class)->create([
'name' => 'Peter',
]);
Search::assertNotSyncedTo('users', $user) // fails
->assertNotSyncedTo('not_existing_index', $user); // passes
$user->update(['name' => 'John']);
$user->delete();
Search::assertContains($user) // fails
->assertNotSyncedTo('users', $user) // fails
->assertNotSyncedTo('users', $user, function ($record) {
return $record['name'] === 'Peter'; // fails
})
->assertNotSyncedTo('users', $user, function ($record) {
return $record['name'] === 'Oliver'; // passes
});
Checks if model was synced expected number of times. This assertion checks every record of the given model which was synced during the request.
$user = User::withoutSyncingToSearch(function () {
return factory(User::class)->create([
'name' => 'Peter',
]);
});
Search::assertSyncedTimes($user, 0) // passes
->assertSyncedTimes($user, 1); // fails
$user->searchable();
$user->update(['name' => 'John']);
$user->delete();
Search::assertContains($user) // fails
->assertSyncedTimes($user, 2) // passes
->assertSyncedTimes($user, 1, function ($record) {
return $record['name'] === 'Peter'; // passes
})
->assertSyncedTimes($user, 1, function ($record) {
return $record['name'] === 'John'; // passes
})
->assertSyncedTimes($user, 1, function ($record) {
return $record['name'] === 'Oliver'; // fails
});
Checks if model was synced to custom search index expected number of times. This assertion checks every record of the given model which was synced during the request.
$user = User::withoutSyncingToSearch(function () {
return factory(User::class)->create([
'name' => 'Peter',
]);
});
Search::assertSyncedTimesTo('users', $user, 0) // passes
->assertSyncedTimesTo('non_existing_index', $user, 1); // fails
$user->searchable();
$user->update(['name' => 'John']);
$user->delete();
Search::assertContains($user) // fails
->assertSyncedTimesTo('users', $user, 2) // passes
->assertSyncedTimesTo('users', $user, 1, function ($record) {
return $record['name'] === 'Peter'; // passes
})
->assertSyncedTimesTo('non_existing_index', 1, function ($record) {
return $record['name'] === 'John'; // fails
});
Checks if nothing was synced to any of search indexes. This assertion checks every record which was synced during the request.
Search::assertNothingSynced(); // passes
factory(User::class)->create();
Search::assertNothingSynced(); // fails
Checks if nothing was synced to custom search index. This assertion checks every record which was synced during the request.
Search::assertNothingSyncedTo('users'); // passes
factory(User::class)->create();
Search::assertNothingSyncedTo('users'); // fails
This method allows to fake search index record of the model. It will not affect assertions.
$user = factory(User::class)->create([
'id' => 123,
'name' => 'Peter',
'email' => 'peter@example.com',
]);
Search::fakeRecord($user, [
'name' => 'John',
]);
$record = User::search()->where('id', 123)->raw()['hits'][0];
$this->assertEquals('Peter', $record['name']); // fails
$this->assertEquals('John', $record['name']); // passes
$this->assertEquals('peter@example.com', $record['email']); // passes
Search::fakeRecord($user, [
'id' => 123,
'name' => 'John',
], false);
$record = User::search()->where('id', 123)->raw()['hits'][0];
$this->assertEquals('Peter', $record['name']); // fails
$this->assertEquals('John', $record['name']); // passes
$this->assertTrue(!isset($record['email'])); // passes
The MIT License (MIT). Please see License File for more information.