-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCreaterequestTest.php
More file actions
123 lines (106 loc) · 3.9 KB
/
CreaterequestTest.php
File metadata and controls
123 lines (106 loc) · 3.9 KB
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
<?php
use App\Models\User;
use App\Models\VirtualAccount;
use Tests\TestCase;
class WalletRequestControllerCreaterequestTest extends TestCase{
public function test_create_request_success(){
// Create a user and authenticate
$user = User::factory()->create();
$this->actingAs($user);
// Create a virtual account
$virtualAccount = VirtualAccount::factory()->create();
// Call api endpoint
$response = $this->postJson("/transfer/request/", [
'debit_account_number' => $virtualAccount->account_number,
'amount' => 1000
]);
// Assert the response
$response->assertStatus(201);
$response->assertJson([
'success' => true,
'message' => 'Wallet Request Created',
'data' => [
'wallet_id' => $user->wallet->id,
'debit_account_number' => $virtualAccount->account_number,
'credit_account_number' => $virtualAccount->account_number,
'amount' => 1000,
'status' => 'pending'
]
]);
}
public function test_create_request_with_negative_amount(){
// Create a user and authenticate
$user = User::factory()->create();
$this->actingAs($user);
// Create a virtual account
$virtualAccount = VirtualAccount::factory()->create();
// Call api endpoint
$response = $this->postJson("/transfer/request/", [
'debit_account_number' => $virtualAccount->account_number,
'amount' => -1000
]);
// Assert the response
$response->assertStatus(400);
$response->assertJson([
'success' => false,
'message' => 'Invalid amount passed',
'data' => [
'debit_account_number' => $virtualAccount->account_number,
'amount' => -1000
]
]);
}
public function test_create_request_with_invalid_debit_account_number(){
// Create a user and authenticate
$user = User::factory()->create();
$this->actingAs($user);
// Call api endpoint
$response = $this->postJson("/transfer/request/", [
'debit_account_number' => 'INVALID_NUMBER',
'amount' => 1000
]);
// Assert the response
$response->assertStatus(400);
$response->assertJson([
'success' => false,
'message' => 'The selected debit account number is invalid.',
'data' => [
'debit_account_number' => 'INVALID_NUMBER',
'amount' => 1000
]
]);
}
public function test_create_request_with_same_debit_and_credit_account_number(){
// Create a user and authenticate
$user = User::factory()->create();
$this->actingAs($user);
// Create a virtual account
$virtualAccount = VirtualAccount::factory()->create();
// Call api endpoint
$response = $this->postJson("/transfer/request/", [
'debit_account_number' => $virtualAccount->account_number,
'amount' => 1000
]);
// Assert the response
$response->assertStatus(400);
$response->assertJson([
'success' => false,
'message' => 'You can not transfer to the same account ',
'data' => []
]);
}
public function test_create_request_without_authentication(){
// Create a virtual account
$virtualAccount = VirtualAccount::factory()->create();
// Call api endpoint
$response = $this->postJson("/transfer/request/", [
'debit_account_number' => $virtualAccount->account_number,
'amount' => 1000
]);
// Assert the response
$response->assertStatus(401);
$response->assertJson([
'message' => 'Unauthenticated.'
]);
}
}