-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathAuthControllerTest.php
70 lines (58 loc) · 1.77 KB
/
AuthControllerTest.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
<?php
namespace Tests\Feature\API;
use Tests\TestCase;
use Illuminate\Foundation\Testing\RefreshDatabase;
use App\Models\User;
class AuthControllerTest extends TestCase
{
use RefreshDatabase;
public function testAuthLostParams()
{
$params = [
'stage' => 'login',
'gw_id' => 'D4EE073700C2',
];
$response = $this->call('GET', '/auth/', $params);
$response->assertStatus(401);
$this->assertEquals('Auth: 0', $response->getContent());
}
public function grantToken()
{
$user = User::factory()->create();
return $user->createToken('wifidog', ['internet:access'])->plainTextToken;
}
public function testLoginSuccess()
{
$params = [
'stage' => 'login',
'token' => $this->grantToken(),
];
$response = $this->call('GET', '/auth', $params);
$response->assertStatus(200);
$this->assertEquals('Auth: 1', $response->getContent());
}
public function testLoginWithBadToken()
{
$params = [
'stage' => 'login',
'token' => 'thisIsABadToken',
];
$response = $this->call('GET', '/auth', $params);
$response->assertStatus(401);
$this->assertEquals('Auth: 0', $response->getContent());
}
public function testCount()
{
$params = [
'stage' => 'counters',
'token' => $this->grantToken(),
'incoming' => rand(1, 999),
'outgoing' => rand(1, 999),
'ip' => fake()->ipv4(),
'mac' => fake()->macAddress(),
];
$response = $this->call('GET', '/auth', $params);
$response->assertStatus(200);
$this->assertEquals('Auth: 1', $response->getContent());
}
}