Fix searching via api
This commit is contained in:
parent
28c821eeaf
commit
e3a0ca7673
|
@ -5,8 +5,8 @@ namespace App\Form\Actions;
|
|||
use App\Form\FilterScope;
|
||||
use App\Form\Models\Form;
|
||||
use App\Form\Resources\FormApiResource;
|
||||
use Illuminate\Database\Eloquent\Collection;
|
||||
use Illuminate\Http\Resources\Json\AnonymousResourceCollection;
|
||||
use Illuminate\Pagination\LengthAwarePaginator;
|
||||
use Lorisleiva\Actions\ActionRequest;
|
||||
use Lorisleiva\Actions\Concerns\AsAction;
|
||||
|
||||
|
@ -15,15 +15,19 @@ class FormApiListAction
|
|||
use AsAction;
|
||||
|
||||
/**
|
||||
* @return Collection<int, Form>
|
||||
* @param array<string, mixed> $filter
|
||||
* @return LengthAwarePaginator<Form>
|
||||
*/
|
||||
public function handle(FilterScope $filter): Collection
|
||||
public function handle(string $filter, int $perPage): LengthAwarePaginator
|
||||
{
|
||||
return Form::withFilter($filter)->get();
|
||||
return FilterScope::fromRequest($filter)->getQuery()->paginate($perPage);
|
||||
}
|
||||
|
||||
public function asController(ActionRequest $request): AnonymousResourceCollection
|
||||
{
|
||||
return FormApiResource::collection($this->handle(FilterScope::fromRequest($request->input('filter', ''))));
|
||||
return FormApiResource::collection($this->handle(
|
||||
$request->input('filter', ''),
|
||||
$request->input('perPage', 10)
|
||||
));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,20 +1,25 @@
|
|||
<?php
|
||||
|
||||
namespace Tests\Feature\Form;
|
||||
namespace Tests\Feature\EndToEnd;
|
||||
|
||||
use App\Form\Models\Form;
|
||||
use App\Form\Models\Formtemplate;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||
use Illuminate\Support\Facades\Storage;
|
||||
use Tests\EndToEndTestCase;
|
||||
use Tests\Feature\Form\FormtemplateFieldRequest;
|
||||
use Tests\Feature\Form\FormtemplateSectionRequest;
|
||||
use Tests\TestCase;
|
||||
|
||||
class FormApiListActionTest extends TestCase
|
||||
class FormApiListActionTest extends EndToEndTestCase
|
||||
{
|
||||
|
||||
use DatabaseTransactions;
|
||||
|
||||
public function testItDisplaysForms(): void
|
||||
{
|
||||
Carbon::setTestNow(Carbon::parse('2023-03-02'));
|
||||
Storage::fake('temp');
|
||||
$this->loginNami()->withoutExceptionHandling();
|
||||
Formtemplate::factory()->name('tname')->sections([FormtemplateSectionRequest::new()->name('sname')])->create();
|
||||
|
@ -28,7 +33,8 @@ class FormApiListActionTest extends TestCase
|
|||
->sections([FormtemplateSectionRequest::new()->name('sname')->fields([FormtemplateFieldRequest::new()])])
|
||||
->create();
|
||||
|
||||
$this->get('/api/form')
|
||||
sleep(1);
|
||||
$this->get('/api/form?perPage=15')
|
||||
->assertOk()
|
||||
->assertJsonPath('data.0.name', 'lala 2')
|
||||
->assertJsonPath('data.0.config.sections.0.name', 'sname')
|
||||
|
@ -39,18 +45,38 @@ class FormApiListActionTest extends TestCase
|
|||
->assertJsonPath('data.0.image', $form->getMedia('headerImage')->first()->getFullUrl('square'))
|
||||
->assertJsonPath('data.0.dates', '05.05.2023 - 07.06.2023')
|
||||
->assertJsonPath('data.0.from_human', '05.05.2023')
|
||||
->assertJsonPath('data.0.to_human', '07.06.2023');
|
||||
->assertJsonPath('data.0.to_human', '07.06.2023')
|
||||
->assertJsonPath('meta.per_page', 15)
|
||||
->assertJsonPath('meta.total', 1);
|
||||
}
|
||||
|
||||
public function testItDisplaysDailyForms(): void
|
||||
{
|
||||
Carbon::setTestNow(Carbon::parse('2023-03-02'));
|
||||
$this->loginNami()->withoutExceptionHandling();
|
||||
Form::factory()
|
||||
->withImage('headerImage', 'lala-2.jpg')
|
||||
->from('2023-05-05')
|
||||
->to('2023-05-05')
|
||||
->create();
|
||||
|
||||
sleep(1);
|
||||
$this->get('/api/form')
|
||||
->assertJsonPath('data.0.dates', '05.05.2023');
|
||||
}
|
||||
|
||||
public function testItDisplaysPastEvents(): void
|
||||
{
|
||||
Carbon::setTestNow(Carbon::parse('2023-05-10'));
|
||||
$this->loginNami()->withoutExceptionHandling();
|
||||
Form::factory()
|
||||
->withImage('headerImage', 'lala-2.jpg')
|
||||
->from('2023-05-05')
|
||||
->to('2023-05-05')
|
||||
->create();
|
||||
|
||||
sleep(1);
|
||||
$this->get('/api/form?filter=' . $this->filterString(['past' => true]))
|
||||
->assertJsonCount(1, 'data');
|
||||
}
|
||||
}
|
|
@ -2,7 +2,12 @@
|
|||
|
||||
namespace Tests;
|
||||
|
||||
use App\Form\Models\Form;
|
||||
use App\Member\Member;
|
||||
use Laravel\Scout\Console\FlushCommand;
|
||||
use Laravel\Scout\Console\SyncIndexSettingsCommand;
|
||||
use Illuminate\Foundation\Testing\DatabaseMigrations;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
|
||||
abstract class EndToEndTestCase extends TestCase
|
||||
{
|
||||
|
@ -14,4 +19,15 @@ abstract class EndToEndTestCase extends TestCase
|
|||
|
||||
$this->useMeilisearch();
|
||||
}
|
||||
|
||||
|
||||
public function useMeilisearch(): self
|
||||
{
|
||||
config()->set('scout.driver', 'meilisearch');
|
||||
Artisan::call(FlushCommand::class, ['model' => Member::class]);
|
||||
Artisan::call(FlushCommand::class, ['model' => Form::class]);
|
||||
Artisan::call(SyncIndexSettingsCommand::class);
|
||||
|
||||
return $this;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -20,9 +20,17 @@ trait MakesHttpCalls
|
|||
public function filterUrl(string $routeName, array $filter): string
|
||||
{
|
||||
$params = [
|
||||
'filter' => base64_encode(rawurlencode(json_encode($filter))),
|
||||
'filter' => $this->filterString($filter),
|
||||
];
|
||||
|
||||
return route($routeName, $params);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, mixed> $filter
|
||||
*/
|
||||
public function filterString(array $filter): string
|
||||
{
|
||||
return base64_encode(rawurlencode(json_encode($filter)));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -16,9 +16,6 @@ use PHPUnit\Framework\Assert;
|
|||
use Tests\Lib\MakesHttpCalls;
|
||||
use Tests\Lib\TestsInertia;
|
||||
use Zoomyboy\LaravelNami\Authentication\Auth;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Scout\Console\FlushCommand;
|
||||
use Laravel\Scout\Console\SyncIndexSettingsCommand;
|
||||
|
||||
abstract class TestCase extends BaseTestCase
|
||||
{
|
||||
|
@ -94,15 +91,6 @@ abstract class TestCase extends BaseTestCase
|
|||
return $this;
|
||||
}
|
||||
|
||||
public function useMeilisearch(): self
|
||||
{
|
||||
config()->set('scout.driver', 'meilisearch');
|
||||
Artisan::call(FlushCommand::class, ['model' => Member::class]);
|
||||
Artisan::call(SyncIndexSettingsCommand::class);
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param <class-string> $class
|
||||
*/
|
||||
|
|
Loading…
Reference in New Issue