CustomersTest.php
3.23 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
124
125
126
127
<?php
namespace Tests\Feature\Incomes;
use App\Models\Auth\User;
use App\Models\Income\Customer;
use Tests\Feature\FeatureTestCase;
class CustomersTest extends FeatureTestCase
{
public function testItShouldCreateOnlyCustomerWithoutUser()
{
$customer = $this->getCustomerData();
$this->loginAs()
->post(route("customers.store"), $customer)
->assertStatus(302)
->assertRedirect(route("customers.index"));
$this->assertFlashLevel("success");
}
public function testItShouldCreateCustomerWithUser()
{
$customerWithUser = $this->getCustomerDataWithUser();
$this->loginAs()
->post(route("customers.store"), $customerWithUser)
->assertStatus(302)
->assertRedirect(route("customers.index"));
$this->assertFlashLevel("success");
$user = User::where("email", $customerWithUser["email"])->first();
$this->assertNotNull($user);
$this->assertEquals($customerWithUser["email"], $user->email);
}
public function testItShouldNotCreateCustomerWithExistsUser()
{
$customerWithUser = $this->getCustomerDataWithUser();
User::create($customerWithUser);
$this->loginAs()
->post(route('customers.store'), $customerWithUser)
->assertSessionHasErrors(['email']);
}
public function testItShouldBeSeeTheCustomersPage()
{
$customer = Customer::create($this->getCustomerData());
$this
->loginAs()
->get(route('customers.index'))
->assertStatus(200)
->assertSee($customer->email);
}
public function testItShouldBeSeeTheEditCustomersPage()
{
$customer = Customer::create($this->getCustomerData());
$this
->loginAs()
->get(route('customers.edit', ['customer' => $customer->id]))
->assertStatus(200)
->assertSee($customer->email)
->assertSee($customer->name);
}
public function testItShouldUpdateTheCustomer()
{
$customerData = $this->getCustomerData();
$customer = Customer::create($customerData);
$customerData["name"] = $this->faker->name;
$this
->loginAs()
->patch(route('customers.update', $customer->id), $customerData)
->assertStatus(302)
->assertRedirect(route('customers.index'));
$this->assertFlashLevel('success');
}
public function testItShouldDeleteTheCustomer()
{
$customer = Customer::create($this->getCustomerData());
$this->loginAs()
->delete(route('customers.destroy', $customer->id))
->assertStatus(302)
->assertRedirect(route('customers.index'));
$this->assertFlashLevel('success');
}
public function testItShouldNotDeleteIfItHaveRelations()
{
$this->assertTrue(true);
//TODO : This will write after done invoice and revenues tests.
}
// Helpers
private function getCustomerData()
{
return [
'company_id' => $this->company->id,
'name' => $this->faker->name,
'email' => $this->faker->email,
'tax_number' => $this->faker->buildingNumber,
'phone' => $this->faker->phoneNumber,
'address' => $this->faker->streetAddress,
'website' => 'www.akaunting.com',
'currency_code' => $this->company->currencies()->first()->code,
'enabled' => $this->faker->boolean ? 1 : 0
];
}
private function getCustomerDataWithUser()
{
$password = $this->faker->password;
return $this->getCustomerData() + [
'create_user' => 1,
'locale' => 'en-GB',
'password' => $password,
'password_confirmation' => $password
];
}
}