forked from bilfeldt/laravel-route-statistics
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRouteStatisticModelTest.php
97 lines (73 loc) · 3.29 KB
/
RouteStatisticModelTest.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<?php
namespace Bilfeldt\LaravelRouteStatistics\Tests\Unit;
use Bilfeldt\LaravelRouteStatistics\Jobs\CreateLog;
use Bilfeldt\LaravelRouteStatistics\Models\RouteStatistic;
use Bilfeldt\LaravelRouteStatistics\Tests\TestCase;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Queue;
class RouteStatisticModelTest extends TestCase
{
public function test_logs_sync_if_queued_config_disabled(): void
{
Config::set('route-statistics.queued', false);
Queue::fake();
$request = \Illuminate\Http\Request::create($route = 'home', 'GET');
$this->app['router']->get($route, fn () => 'Test route response');
$response = $this->app['router']->dispatch($request);
(new RouteStatistic)->log($request, $response, 1, 2);
Queue::assertNotPushed(CreateLog::class);
$this->markTestIncomplete('Mock the attributes and check that they are persisted in DB');
}
public function test_logs_queued_if_queued_config_enabled(): void
{
Config::set('route-statistics.queued', true);
Queue::fake();
$request = \Illuminate\Http\Request::create($route = 'home', 'GET');
$this->app['router']->get($route, fn () => 'Test route response');
$response = $this->app['router']->dispatch($request);
(new RouteStatistic)->log($request, $response, 1, 2);
Queue::assertPushed(CreateLog::class);
}
public function test_get_log_attributes(): void
{
$this->markTestIncomplete('Mock the request and response to ensture the correct attributes are returned');
}
public function test_logs_parameters_if_config_enabled(): void
{
Config::set('route-statistics.store_parameters', true);
$route = 'home';
$params = [
'param1' => 'one',
'param2' => 'two',
];
$request = \Illuminate\Http\Request::create($route.'/'.implode('/', $this->get_route_parameters($params)), 'GET');
$this->app['router']->get($route.'/'.implode('/', $this->get_route_keys($params)), fn () => 'Test route response');
$response = $this->app['router']->dispatch($request);
(new RouteStatistic)->log($request, $response, 1, 2);
$log = RouteStatistic::first();
$this->assertEquals(json_encode($params), $log->parameters);
}
public function test_logs_parameters_if_config_disabled(): void
{
Config::set('route-statistics.store_parameters', false);
$route = 'home';
$params = [
'param1' => 'one',
'param2' => 'two',
];
$request = \Illuminate\Http\Request::create($route.'/'.implode('/', $this->get_route_parameters($params)), 'GET');
$this->app['router']->get($route.'/'.implode('/', $this->get_route_keys($params)), fn () => 'Test route response');
$response = $this->app['router']->dispatch($request);
(new RouteStatistic)->log($request, $response, 1, 2);
$log = RouteStatistic::first();
$this->assertNull($log->parameters);
}
private function get_route_parameters(array $parameters): array
{
return array_values($parameters);
}
private function get_route_keys(array $parameters): array
{
return array_map(fn ($parameter) => '{'.$parameter.'}', array_keys($parameters));
}
}