From 07c04a622cf9a7465341846eeb5b93c8f5ca8d5c Mon Sep 17 00:00:00 2001 From: Aron Rotteveel Date: Tue, 26 Oct 2021 19:02:12 +0200 Subject: [PATCH] Fixed Mockery expectations + faulty paginator (#7) --- src/Engines/ArrayEngine.php | 2 +- tests/Engines/ArrayEngineTest.php | 17 ++++++++++++----- 2 files changed, 13 insertions(+), 6 deletions(-) diff --git a/src/Engines/ArrayEngine.php b/src/Engines/ArrayEngine.php index 58b4bdc..a0d324c 100644 --- a/src/Engines/ArrayEngine.php +++ b/src/Engines/ArrayEngine.php @@ -132,7 +132,7 @@ protected function performSearch(Builder $builder, array $options = []) $matches = Collection::make($matches); return [ - 'hits' => (isset($options['perPage']) ? $matches->slice(($options['page'] ?? 1) - 1, $options['perPage']) : $matches)->values()->all(), + 'hits' => (isset($options['perPage']) ? $matches->slice((($options['page'] ?? 1) - 1) * $options['perPage'], $options['perPage']) : $matches)->values()->all(), 'total' => $matches->count(), ]; } diff --git a/tests/Engines/ArrayEngineTest.php b/tests/Engines/ArrayEngineTest.php index e6c0ac9..baa99fd 100644 --- a/tests/Engines/ArrayEngineTest.php +++ b/tests/Engines/ArrayEngineTest.php @@ -19,6 +19,7 @@ class ArrayEngineTest extends TestCase protected function setUp(): void { Config::shouldReceive('get')->with('scout.after_commit', Mockery::any())->andReturn(false); + Config::shouldReceive('get')->with('scout.soft_delete', Mockery::any())->andReturn(false); } protected function tearDown(): void @@ -272,14 +273,20 @@ public function it_can_paginate_results() $engine->update(Collection::make([ new SearchableModel(['foo' => 'bar', 'scoutKey' => 1]), new SearchableModel(['foo' => 'bar', 'scoutKey' => 2]), - new SearchableModel(['foo' => 'bar', 'scoutKey' => 3]) + new SearchableModel(['foo' => 'bar', 'scoutKey' => 3]), + new SearchableModel(['foo' => 'bar', 'scoutKey' => 4]), + new SearchableModel(['foo' => 'bar', 'scoutKey' => 5]), + new SearchableModel(['foo' => 'bar', 'scoutKey' => 6]), + new SearchableModel(['foo' => 'bar', 'scoutKey' => 7]), + new SearchableModel(['foo' => 'bar', 'scoutKey' => 8]), ])); - $results = $engine->paginate(new Builder(new SearchableModel(), 'bar'), 1, 3); + $results = $engine->paginate(new Builder(new SearchableModel(), 'bar'), 2, 3); - $this->assertCount(1, $results['hits']); - $this->assertEquals(3, $results['total']); - $this->assertEquals(1, $results['hits'][0]['scoutKey']); + $this->assertCount(2, $results['hits']); + $this->assertEquals(8, $results['total']); + $this->assertEquals(4, $results['hits'][0]['scoutKey']); + $this->assertEquals(3, $results['hits'][1]['scoutKey']); } /** @test */