mirror of
https://github.com/crater-invoice/crater.git
synced 2025-10-27 11:41:09 -04:00
Implement PHP CS Fixer and a coding standard to follow (#471)
* Create PHP CS Fixer config and add to CI workflow * Run php cs fixer on project * Add newline at end of file * Update to use PHP CS Fixer v3 * Run v3 config on project * Run seperate config in CI
This commit is contained in:
@ -1,4 +1,5 @@
|
||||
<?php
|
||||
|
||||
namespace Tests;
|
||||
|
||||
use Illuminate\Contracts\Console\Kernel;
|
||||
|
||||
@ -1,12 +1,13 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\FileDisk;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Illuminate\Support\Facades\Queue;
|
||||
use Crater\Jobs\CreateBackupJob;
|
||||
use function Pest\Laravel\{postJson, getJson};
|
||||
use Crater\Models\FileDisk;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Illuminate\Support\Facades\Queue;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -24,7 +25,7 @@ beforeEach(function () {
|
||||
|
||||
test('get backups', function () {
|
||||
$disk = FileDisk::factory()->create([
|
||||
'set_as_default' => true
|
||||
'set_as_default' => true,
|
||||
]);
|
||||
|
||||
$response = getJson("/api/v1/backups?disk={$disk->driver}&&file_disk_id={$disk->id}");
|
||||
@ -50,7 +51,7 @@ test('create backup', function () {
|
||||
|
||||
$response->assertStatus(200)->assertJson([
|
||||
"disks" => [
|
||||
"local"
|
||||
]
|
||||
"local",
|
||||
],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -6,7 +6,9 @@ use Crater\Http\Requests\ProfileRequest;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use function Pest\Laravel\{postJson, getJson, putJson};
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -41,7 +43,7 @@ test('update profile', function () {
|
||||
$user = [
|
||||
'name' => 'John Doe',
|
||||
'password' => 'admin@123',
|
||||
'email' => 'admin@crater.in'
|
||||
'email' => 'admin@crater.in',
|
||||
];
|
||||
|
||||
$response = putJson('api/v1/me', $user);
|
||||
@ -50,7 +52,7 @@ test('update profile', function () {
|
||||
|
||||
$this->assertDatabaseHas('users', [
|
||||
'name' => $user['name'],
|
||||
'email' => $user['email']
|
||||
'email' => $user['email'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -71,7 +73,7 @@ test('update company', function () {
|
||||
'address_street_1' => 'test1',
|
||||
'address_street_2' => 'test2',
|
||||
'phone' => '1234567890',
|
||||
'zip' => '112233'
|
||||
'zip' => '112233',
|
||||
];
|
||||
|
||||
$response = putJson('api/v1/company', $company);
|
||||
@ -79,7 +81,7 @@ test('update company', function () {
|
||||
$response->assertOk();
|
||||
|
||||
$this->assertDatabaseHas('companies', [
|
||||
'name' => $company['name']
|
||||
'name' => $company['name'],
|
||||
]);
|
||||
|
||||
$this->assertDatabaseHas('addresses', [
|
||||
@ -89,13 +91,13 @@ test('update company', function () {
|
||||
'address_street_1' => $company['address_street_1'],
|
||||
'address_street_2' => $company['address_street_2'],
|
||||
'phone' => $company['phone'],
|
||||
'zip' => $company['zip']
|
||||
'zip' => $company['zip'],
|
||||
]);
|
||||
});
|
||||
|
||||
test('update settings', function () {
|
||||
$settings = [
|
||||
'currency'=> 1,
|
||||
'currency' => 1,
|
||||
'time_zone' => 'Asia/Kolkata',
|
||||
'language' => 'en',
|
||||
'fiscal_year' => '1-12',
|
||||
@ -105,20 +107,20 @@ test('update settings', function () {
|
||||
'notify_invoice_viewed' => 'YES',
|
||||
'notify_estimate_viewed' => 'YES',
|
||||
'tax_per_item' => 'YES',
|
||||
'discount_per_item' => 'YES'
|
||||
'discount_per_item' => 'YES',
|
||||
];
|
||||
|
||||
$response = postJson('/api/v1/company/settings', ['settings' => $settings]);
|
||||
|
||||
$response->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
foreach ($settings as $key => $value) {
|
||||
$this->assertDatabaseHas('company_settings', [
|
||||
'option' => $key,
|
||||
'value' => $value
|
||||
'value' => $value,
|
||||
]);
|
||||
}
|
||||
});
|
||||
@ -135,7 +137,7 @@ test('get notification email settings', function () {
|
||||
'notify_invoice_viewed',
|
||||
'notify_estimate_viewed',
|
||||
'tax_per_item',
|
||||
'discount_per_item'
|
||||
'discount_per_item',
|
||||
];
|
||||
|
||||
$response = getJson('/api/v1/company/settings?'.http_build_query($data));
|
||||
|
||||
@ -1,12 +1,15 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\CustomField\CustomFieldsController;
|
||||
use Crater\Http\Requests\CustomFieldRequest;
|
||||
use Crater\Models\CustomField;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\CustomFieldRequest;
|
||||
use Crater\Http\Controllers\V1\CustomField\CustomFieldsController;
|
||||
use function Pest\Laravel\{postJson, putJson, getJson, deleteJson};
|
||||
use function Pest\Laravel\deleteJson;
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -34,7 +37,7 @@ test('create custom field', function () {
|
||||
postJson('api/v1/custom-fields', $data)
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$this->assertDatabaseHas('custom_fields', [
|
||||
@ -42,7 +45,7 @@ test('create custom field', function () {
|
||||
'label' => $data['label'],
|
||||
'type' => $data['type'],
|
||||
'model_type' => $data['model_type'],
|
||||
'is_required' => $data['is_required']
|
||||
'is_required' => $data['is_required'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -58,13 +61,13 @@ test('update custom field', function () {
|
||||
$customField = CustomField::factory()->create();
|
||||
|
||||
$newCustomField = CustomField::factory()->raw([
|
||||
'is_required' => false
|
||||
'is_required' => false,
|
||||
]);
|
||||
|
||||
putJson('api/v1/custom-fields/' . $customField->id, $newCustomField)
|
||||
putJson('api/v1/custom-fields/'.$customField->id, $newCustomField)
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$this->assertDatabaseHas('custom_fields', [
|
||||
@ -87,12 +90,12 @@ test('update validates using a form request', function () {
|
||||
test('delete custom field', function () {
|
||||
$customField = CustomField::factory()->create();
|
||||
|
||||
$response = deleteJson('api/v1/custom-fields/' . $customField->id);
|
||||
$response = deleteJson('api/v1/custom-fields/'.$customField->id);
|
||||
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$this->assertDeleted($customField);
|
||||
|
||||
@ -1,12 +1,14 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\Customer\CustomersController;
|
||||
use Crater\Http\Requests\CustomerRequest;
|
||||
use Crater\Models\Invoice;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\CustomerRequest;
|
||||
use Crater\Http\Controllers\V1\Customer\CustomersController;
|
||||
use function Pest\Laravel\{postJson, putJson, getJson};
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -30,11 +32,11 @@ test('get customers', function () {
|
||||
|
||||
test('customer stats', function () {
|
||||
$customer = User::factory()->create([
|
||||
'role' => 'customer'
|
||||
'role' => 'customer',
|
||||
]);
|
||||
|
||||
$invoice = Invoice::factory()->create([
|
||||
'user_id' => $customer->id
|
||||
'user_id' => $customer->id,
|
||||
]);
|
||||
|
||||
$response = getJson("api/v1/customers/{$customer->id}/stats");
|
||||
@ -45,7 +47,7 @@ test('customer stats', function () {
|
||||
test('create customer', function () {
|
||||
$customer = User::factory()->raw([
|
||||
'password' => 'secret',
|
||||
'role' => 'customer'
|
||||
'role' => 'customer',
|
||||
]);
|
||||
|
||||
$response = postJson('api/v1/customers', $customer);
|
||||
@ -54,13 +56,13 @@ test('create customer', function () {
|
||||
'name' => $customer['name'],
|
||||
'email' => $customer['email'],
|
||||
'role' => $customer['role'],
|
||||
'company_id' => $customer['company_id']
|
||||
'company_id' => $customer['company_id'],
|
||||
]);
|
||||
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
});
|
||||
|
||||
@ -74,7 +76,7 @@ test('store validates using a form request', function () {
|
||||
|
||||
test('get customer', function () {
|
||||
$customer = User::factory()->create([
|
||||
'role' => 'customer'
|
||||
'role' => 'customer',
|
||||
]);
|
||||
|
||||
$response = getJson("api/v1/customers/{$customer->id}");
|
||||
@ -84,7 +86,7 @@ test('get customer', function () {
|
||||
'name' => $customer['name'],
|
||||
'email' => $customer['email'],
|
||||
'role' => $customer['role'],
|
||||
'company_id' => $customer['company_id']
|
||||
'company_id' => $customer['company_id'],
|
||||
]);
|
||||
|
||||
$response->assertOk();
|
||||
@ -92,28 +94,28 @@ test('get customer', function () {
|
||||
|
||||
test('update customer', function () {
|
||||
$customer = User::factory()->create([
|
||||
'role' => 'customer'
|
||||
]);
|
||||
|
||||
$customer1 = User::factory()->raw([
|
||||
'role' => 'customer',
|
||||
'name' => 'new name'
|
||||
]);
|
||||
|
||||
$response = putJson('api/v1/customers/' . $customer->id, $customer1);
|
||||
$customer1 = User::factory()->raw([
|
||||
'role' => 'customer',
|
||||
'name' => 'new name',
|
||||
]);
|
||||
|
||||
$response = putJson('api/v1/customers/'.$customer->id, $customer1);
|
||||
|
||||
$this->assertDatabaseHas('users', [
|
||||
'id' => $customer->id,
|
||||
'name' => $customer1['name'],
|
||||
'email' => $customer1['email'],
|
||||
'role' => $customer1['role'],
|
||||
'company_id' => $customer1['company_id']
|
||||
'company_id' => $customer1['company_id'],
|
||||
]);
|
||||
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
});
|
||||
|
||||
@ -130,25 +132,25 @@ test('search customers', function () {
|
||||
'page' => 1,
|
||||
'limit' => 15,
|
||||
'search' => 'doe',
|
||||
'email' => '.com'
|
||||
'email' => '.com',
|
||||
];
|
||||
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
|
||||
$response = getJson('api/v1/customers?' . $queryString);
|
||||
$response = getJson('api/v1/customers?'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
|
||||
test('delete multiple customer', function () {
|
||||
$customers = User::factory()->count(4)->create([
|
||||
'role' => 'customer'
|
||||
'role' => 'customer',
|
||||
]);
|
||||
|
||||
$ids = $customers->pluck('id');
|
||||
|
||||
$data = [
|
||||
'ids' => $ids
|
||||
'ids' => $ids,
|
||||
];
|
||||
|
||||
$response = postJson('api/v1/customers/delete', $data);
|
||||
@ -156,6 +158,6 @@ test('delete multiple customer', function () {
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
});
|
||||
|
||||
@ -1,4 +1,5 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -1,19 +1,21 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Estimate;
|
||||
use Crater\Models\EstimateItem;
|
||||
use Crater\Models\Tax;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\EstimatesRequest;
|
||||
use Crater\Http\Controllers\V1\Estimate\EstimatesController;
|
||||
use Crater\Http\Controllers\V1\Estimate\SendEstimateController;
|
||||
use Crater\Http\Requests\DeleteEstimatesRequest;
|
||||
use Crater\Http\Requests\EstimatesRequest;
|
||||
use Crater\Http\Requests\SendEstimatesRequest;
|
||||
use Crater\Mail\SendEstimateMail;
|
||||
use Crater\Models\Estimate;
|
||||
use Crater\Models\EstimateItem;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
use function Pest\Laravel\{postJson, putJson, getJson};
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -38,10 +40,10 @@ test('get estimates', function () {
|
||||
test('create estimate', function () {
|
||||
$estimate = Estimate::factory()->raw([
|
||||
'items' => [
|
||||
EstimateItem::factory()->raw()
|
||||
EstimateItem::factory()->raw(),
|
||||
],
|
||||
'taxes' => [
|
||||
Tax::factory()->raw()
|
||||
Tax::factory()->raw(),
|
||||
],
|
||||
]);
|
||||
|
||||
@ -81,16 +83,16 @@ test('update estimate', function () {
|
||||
|
||||
$estimate2 = Estimate::factory()->raw([
|
||||
'items' => [
|
||||
EstimateItem::factory()->raw()
|
||||
EstimateItem::factory()->raw(),
|
||||
],
|
||||
'taxes' => [
|
||||
Tax::factory()->raw([
|
||||
'tax_type_id' => $estimate->taxes[0]->tax_type_id
|
||||
])
|
||||
]
|
||||
'tax_type_id' => $estimate->taxes[0]->tax_type_id,
|
||||
]),
|
||||
],
|
||||
]);
|
||||
|
||||
$response = putJson('api/v1/estimates/' . $estimate->id, $estimate2);
|
||||
$response = putJson('api/v1/estimates/'.$estimate->id, $estimate2);
|
||||
|
||||
$newEstimate = $response->decodeResponseJson()['estimate'];
|
||||
|
||||
@ -108,11 +110,11 @@ test('update estimate', function () {
|
||||
]);
|
||||
|
||||
$this->assertDatabaseHas('taxes', [
|
||||
'estimate_id' => $newEstimate['id']
|
||||
'estimate_id' => $newEstimate['id'],
|
||||
]);
|
||||
|
||||
$this->assertDatabaseHas('estimate_items', [
|
||||
'estimate_id' => $newEstimate['id']
|
||||
'estimate_id' => $newEstimate['id'],
|
||||
]);
|
||||
|
||||
$response->assertStatus(200);
|
||||
@ -133,12 +135,12 @@ test('search estimates', function () {
|
||||
'search' => 'doe',
|
||||
'from_date' => '2020-07-18',
|
||||
'to_date' => '2020-07-20',
|
||||
'estimate_number' => '000003'
|
||||
'estimate_number' => '000003',
|
||||
];
|
||||
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
|
||||
$response = getJson('api/v1/estimates?' . $queryString);
|
||||
$response = getJson('api/v1/estimates?'.$queryString);
|
||||
|
||||
$response->assertStatus(200);
|
||||
});
|
||||
@ -163,13 +165,13 @@ test('send estimate to customer', function () {
|
||||
'subject' => 'test',
|
||||
'body' => 'test',
|
||||
'from' => 'john@example.com',
|
||||
'to' => 'doe@example.com'
|
||||
'to' => 'doe@example.com',
|
||||
];
|
||||
|
||||
postJson("api/v1/estimates/{$estimate->id}/send", $data)
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
Mail::assertSent(SendEstimateMail::class);
|
||||
@ -182,7 +184,7 @@ test('estimate mark as accepted', function () {
|
||||
]);
|
||||
|
||||
$data = [
|
||||
'status' => Estimate::STATUS_ACCEPTED
|
||||
'status' => Estimate::STATUS_ACCEPTED,
|
||||
];
|
||||
|
||||
$response = postJson("api/v1/estimates/{$estimate->id}/status", $data);
|
||||
@ -190,7 +192,7 @@ test('estimate mark as accepted', function () {
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$estimate2 = Estimate::find($estimate->id);
|
||||
@ -204,7 +206,7 @@ test('estimate mark as rejected', function () {
|
||||
]);
|
||||
|
||||
$data = [
|
||||
'status' => Estimate::STATUS_REJECTED
|
||||
'status' => Estimate::STATUS_REJECTED,
|
||||
];
|
||||
|
||||
$response = postJson("api/v1/estimates/{$estimate->id}/status", $data);
|
||||
@ -212,7 +214,7 @@ test('estimate mark as rejected', function () {
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$estimate2 = Estimate::find($estimate->id);
|
||||
@ -248,7 +250,7 @@ test('delete multiple estimates', function () {
|
||||
$ids = $estimates->pluck('id');
|
||||
|
||||
$data = [
|
||||
'ids' => $ids
|
||||
'ids' => $ids,
|
||||
];
|
||||
|
||||
$response = postJson('api/v1/estimates/delete', $data);
|
||||
@ -256,7 +258,7 @@ test('delete multiple estimates', function () {
|
||||
$response
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
foreach ($estimates as $estimate) {
|
||||
|
||||
@ -1,11 +1,15 @@
|
||||
<?php
|
||||
use Crater\Models\User;
|
||||
|
||||
use Crater\Http\Controllers\V1\Expense\ExpenseCategoriesController;
|
||||
use Crater\Http\Requests\ExpenseCategoryRequest;
|
||||
use Crater\Models\ExpenseCategory;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\ExpenseCategoryRequest;
|
||||
use Crater\Http\Controllers\V1\Expense\ExpenseCategoriesController;
|
||||
use function Pest\Laravel\{postJson, putJson, getJson, deleteJson};
|
||||
use function Pest\Laravel\deleteJson;
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -82,7 +86,7 @@ test('delete category', function () {
|
||||
deleteJson('api/v1/categories/'.$category->id)
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$this->assertDeleted($category);
|
||||
|
||||
@ -1,12 +1,14 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\Expense\ExpensesController;
|
||||
use Crater\Http\Requests\ExpenseRequest;
|
||||
use Crater\Models\Expense;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\ExpenseRequest;
|
||||
use Crater\Http\Controllers\V1\Expense\ExpensesController;
|
||||
use function Pest\Laravel\{postJson, putJson, getJson, deleteJson};
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -48,7 +50,7 @@ test('store validates using a form request', function () {
|
||||
|
||||
test('get expense data', function () {
|
||||
$expense = Expense::factory()->create([
|
||||
'expense_date' => '2019-02-05'
|
||||
'expense_date' => '2019-02-05',
|
||||
]);
|
||||
|
||||
getJson("api/v1/expenses/{$expense->id}")->assertOk();
|
||||
@ -63,12 +65,12 @@ test('get expense data', function () {
|
||||
|
||||
test('update expense', function () {
|
||||
$expense = Expense::factory()->create([
|
||||
'expense_date' => '2019-02-05'
|
||||
'expense_date' => '2019-02-05',
|
||||
]);
|
||||
|
||||
$expense2 = Expense::factory()->raw();
|
||||
|
||||
putJson('api/v1/expenses/' . $expense->id, $expense2)->assertOk();
|
||||
putJson('api/v1/expenses/'.$expense->id, $expense2)->assertOk();
|
||||
|
||||
$this->assertDatabaseHas('expenses', [
|
||||
'id' => $expense->id,
|
||||
@ -93,23 +95,23 @@ test('search expenses', function () {
|
||||
'expense_category_id' => 1,
|
||||
'search' => 'cate',
|
||||
'from_date' => '2020-07-18',
|
||||
'to_date' => '2020-07-20'
|
||||
'to_date' => '2020-07-20',
|
||||
];
|
||||
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
|
||||
$response = getJson('api/v1/expenses?' . $queryString);
|
||||
$response = getJson('api/v1/expenses?'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
|
||||
test('delete multiple expenses', function () {
|
||||
$expenses = Expense::factory()->count(3)->create([
|
||||
'expense_date' => '2019-02-05'
|
||||
'expense_date' => '2019-02-05',
|
||||
]);
|
||||
|
||||
$data = [
|
||||
'ids' => $expenses->pluck('id')
|
||||
'ids' => $expenses->pluck('id'),
|
||||
];
|
||||
|
||||
$response = postJson('api/v1/expenses/delete', $data);
|
||||
@ -117,7 +119,7 @@ test('delete multiple expenses', function () {
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
foreach ($expenses as $expense) {
|
||||
|
||||
@ -1,10 +1,12 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\FileDisk;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use function Pest\Laravel\{postJson, putJson, getJson};
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
|
||||
@ -1,16 +1,18 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\Invoice\InvoicesController;
|
||||
use Crater\Http\Requests\InvoicesRequest;
|
||||
use Crater\Mail\SendInvoiceMail;
|
||||
use Crater\Models\Invoice;
|
||||
use Crater\Models\InvoiceItem;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\InvoicesRequest;
|
||||
use Crater\Http\Controllers\V1\Invoice\InvoicesController;
|
||||
use Crater\Mail\SendInvoiceMail;
|
||||
|
||||
use function Pest\Laravel\{postJson, putJson, getJson};
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -36,7 +38,7 @@ test('create invoice', function () {
|
||||
$invoice = Invoice::factory()
|
||||
->raw([
|
||||
'taxes' => [Tax::factory()->raw()],
|
||||
'items' => [InvoiceItem::factory()->raw()]
|
||||
'items' => [InvoiceItem::factory()->raw()],
|
||||
]);
|
||||
|
||||
$response = postJson('api/v1/invoices', $invoice);
|
||||
@ -62,7 +64,7 @@ test('create invoice as sent', function () {
|
||||
$invoice = Invoice::factory()
|
||||
->raw([
|
||||
'taxes' => [Tax::factory()->raw()],
|
||||
'items' => [InvoiceItem::factory()->raw()]
|
||||
'items' => [InvoiceItem::factory()->raw()],
|
||||
]);
|
||||
|
||||
$response = postJson('api/v1/invoices', $invoice);
|
||||
@ -101,10 +103,10 @@ test('update invoice', function () {
|
||||
$invoice2 = Invoice::factory()
|
||||
->raw([
|
||||
'taxes' => [Tax::factory()->raw()],
|
||||
'items' => [InvoiceItem::factory()->raw()]
|
||||
'items' => [InvoiceItem::factory()->raw()],
|
||||
]);
|
||||
|
||||
putJson('api/v1/invoices/' . $invoice->id, $invoice2)->assertOk();
|
||||
putJson('api/v1/invoices/'.$invoice->id, $invoice2)->assertOk();
|
||||
|
||||
$this->assertDatabaseHas('invoices', [
|
||||
'invoice_number' => $invoice2['invoice_number'],
|
||||
@ -141,15 +143,15 @@ test('send invoice to customer', function () {
|
||||
'from' => 'john@example.com',
|
||||
'to' => 'doe@example.com',
|
||||
'subject' => 'email subject',
|
||||
'body' => 'email body'
|
||||
'body' => 'email body',
|
||||
];
|
||||
|
||||
$response = postJson('api/v1/invoices/' . $invoices->id . '/send', $data);
|
||||
$response = postJson('api/v1/invoices/'.$invoices->id.'/send', $data);
|
||||
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$invoice2 = Invoice::find($invoices->id);
|
||||
@ -165,15 +167,15 @@ test('invoice mark as paid', function () {
|
||||
]);
|
||||
|
||||
$data = [
|
||||
'status' => Invoice::STATUS_COMPLETED
|
||||
'status' => Invoice::STATUS_COMPLETED,
|
||||
];
|
||||
|
||||
$response = postJson('api/v1/invoices/' . $invoice->id . '/status', $data);
|
||||
$response = postJson('api/v1/invoices/'.$invoice->id.'/status', $data);
|
||||
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$this->assertEquals(Invoice::find($invoice->id)->paid_status, Invoice::STATUS_PAID);
|
||||
@ -186,15 +188,15 @@ test('invoice mark as sent', function () {
|
||||
]);
|
||||
|
||||
$data = [
|
||||
'status' => Invoice::STATUS_SENT
|
||||
'status' => Invoice::STATUS_SENT,
|
||||
];
|
||||
|
||||
$response = postJson('api/v1/invoices/' . $invoice->id . '/status', $data);
|
||||
$response = postJson('api/v1/invoices/'.$invoice->id.'/status', $data);
|
||||
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$this->assertEquals(Invoice::find($invoice->id)->status, Invoice::STATUS_SENT);
|
||||
@ -208,12 +210,12 @@ test('search invoices', function () {
|
||||
'status' => Invoice::STATUS_DRAFT,
|
||||
'from_date' => '2019-01-20',
|
||||
'to_date' => '2019-01-27',
|
||||
'invoice_number' => '000012'
|
||||
'invoice_number' => '000012',
|
||||
];
|
||||
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
|
||||
$response = getJson('api/v1/invoices?' . $queryString);
|
||||
$response = getJson('api/v1/invoices?'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
@ -227,13 +229,13 @@ test('delete multiple invoices', function () {
|
||||
$ids = $invoices->pluck('id');
|
||||
|
||||
$data = [
|
||||
'ids' => $ids
|
||||
'ids' => $ids,
|
||||
];
|
||||
|
||||
postJson('api/v1/invoices/delete', $data)
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
foreach ($invoices as $invoice) {
|
||||
@ -252,6 +254,6 @@ test('clone invoice', function () {
|
||||
$response
|
||||
->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
});
|
||||
|
||||
@ -1,13 +1,15 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\Item\ItemsController;
|
||||
use Crater\Http\Requests\ItemsRequest;
|
||||
use Crater\Models\Item;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\ItemsRequest;
|
||||
use Crater\Http\Controllers\V1\Item\ItemsController;
|
||||
use function Pest\Laravel\{postJson, putJson, getJson, deleteJson};
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -33,8 +35,8 @@ test('create item', function () {
|
||||
$item = Item::factory()->raw([
|
||||
'taxes' => [
|
||||
Tax::factory()->raw(),
|
||||
Tax::factory()->raw()
|
||||
]
|
||||
Tax::factory()->raw(),
|
||||
],
|
||||
]);
|
||||
|
||||
$response = postJson('api/v1/items', $item);
|
||||
@ -43,7 +45,7 @@ test('create item', function () {
|
||||
'name' => $item['name'],
|
||||
'description' => $item['description'],
|
||||
'price' => $item['price'],
|
||||
'company_id' => $item['company_id']
|
||||
'company_id' => $item['company_id'],
|
||||
]);
|
||||
|
||||
$this->assertDatabaseHas('taxes', [
|
||||
@ -72,7 +74,7 @@ test('get item', function () {
|
||||
'name' => $item['name'],
|
||||
'description' => $item['description'],
|
||||
'price' => $item['price'],
|
||||
'company_id' => $item['company_id']
|
||||
'company_id' => $item['company_id'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -81,11 +83,11 @@ test('update item', function () {
|
||||
|
||||
$update_item = Item::factory()->raw([
|
||||
'taxes' => [
|
||||
Tax::factory()->raw()
|
||||
]
|
||||
Tax::factory()->raw(),
|
||||
],
|
||||
]);
|
||||
|
||||
$response = putJson('api/v1/items/' . $item->id, $update_item);
|
||||
$response = putJson('api/v1/items/'.$item->id, $update_item);
|
||||
|
||||
$response->assertOk();
|
||||
|
||||
@ -93,7 +95,7 @@ test('update item', function () {
|
||||
'name' => $update_item['name'],
|
||||
'description' => $update_item['description'],
|
||||
'price' => $update_item['price'],
|
||||
'company_id' => $update_item['company_id']
|
||||
'company_id' => $update_item['company_id'],
|
||||
]);
|
||||
|
||||
$this->assertDatabaseHas('taxes', [
|
||||
@ -113,7 +115,7 @@ test('delete multiple items', function () {
|
||||
$items = Item::factory()->count(5)->create();
|
||||
|
||||
$data = [
|
||||
'ids' => $items->pluck('id')
|
||||
'ids' => $items->pluck('id'),
|
||||
];
|
||||
|
||||
postJson("/api/v1/items/delete", $data)->assertOk();
|
||||
@ -129,12 +131,12 @@ test('search items', function () {
|
||||
'limit' => 15,
|
||||
'search' => 'doe',
|
||||
'price' => 6,
|
||||
'unit' => 'kg'
|
||||
'unit' => 'kg',
|
||||
];
|
||||
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
|
||||
$response = getJson('api/v1/items?' . $queryString);
|
||||
$response = getJson('api/v1/items?'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
|
||||
@ -22,25 +22,25 @@ beforeEach(function () {
|
||||
test('next number', function () {
|
||||
$key = 'invoice';
|
||||
|
||||
$response = getJson('api/v1/next-number?key=' . $key);
|
||||
$response = getJson('api/v1/next-number?key='.$key);
|
||||
|
||||
$response->assertStatus(200)->assertJson([
|
||||
'nextNumber' => '000001'
|
||||
'nextNumber' => '000001',
|
||||
]);
|
||||
|
||||
$key = 'estimate';
|
||||
|
||||
$response = getJson('api/v1/next-number?key=' . $key);
|
||||
$response = getJson('api/v1/next-number?key='.$key);
|
||||
|
||||
$response->assertStatus(200)->assertJson([
|
||||
'nextNumber' => '000001'
|
||||
'nextNumber' => '000001',
|
||||
]);
|
||||
|
||||
$key = 'payment';
|
||||
|
||||
$response = getJson('api/v1/next-number?key=' . $key);
|
||||
$response = getJson('api/v1/next-number?key='.$key);
|
||||
|
||||
$response->assertStatus(200)->assertJson([
|
||||
'nextNumber' => '000001'
|
||||
'nextNumber' => '000001',
|
||||
]);
|
||||
});
|
||||
|
||||
@ -4,7 +4,10 @@ use Crater\Models\Note;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use function Pest\Laravel\{getJson, postJson, putJson, deleteJson};
|
||||
use function Pest\Laravel\deleteJson;
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -38,7 +41,7 @@ test('retrieve note', function () {
|
||||
getJson("/api/v1/notes/{$note->id}")
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
'note' => $note->toArray()
|
||||
'note' => $note->toArray(),
|
||||
]);
|
||||
});
|
||||
|
||||
@ -59,7 +62,7 @@ test('delete note', function () {
|
||||
deleteJson("/api/v1/notes/{$note->id}")
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$this->assertDeleted($note);
|
||||
|
||||
@ -1,12 +1,15 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\Payment\PaymentMethodsController;
|
||||
use Crater\Http\Requests\PaymentMethodRequest;
|
||||
use Crater\Models\PaymentMethod;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\PaymentMethodRequest;
|
||||
use Crater\Http\Controllers\V1\Payment\PaymentMethodsController;
|
||||
use function Pest\Laravel\{postJson, putJson, getJson, deleteJson};
|
||||
use function Pest\Laravel\deleteJson;
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -42,7 +45,7 @@ test('create payment method', function () {
|
||||
|
||||
$this->assertDatabaseHas('payment_methods', [
|
||||
'name' => $data['name'],
|
||||
'company_id' => $data['company_id']
|
||||
'company_id' => $data['company_id'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -72,7 +75,7 @@ test('update payment method', function () {
|
||||
$method = PaymentMethod::factory()->create();
|
||||
|
||||
$data = [
|
||||
'name' => 'updated name'
|
||||
'name' => 'updated name',
|
||||
];
|
||||
|
||||
$response = putJson("api/v1/payment-methods/{$method->id}", $data);
|
||||
@ -81,7 +84,7 @@ test('update payment method', function () {
|
||||
|
||||
$this->assertDatabaseHas('payment_methods', [
|
||||
'id' => $method->id,
|
||||
'name' => $data['name']
|
||||
'name' => $data['name'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -96,7 +99,7 @@ test('update validates using a form request', function () {
|
||||
test('delete payment method', function () {
|
||||
$method = PaymentMethod::factory()->create();
|
||||
|
||||
$response = deleteJson('api/v1/payment-methods/' . $method->id);
|
||||
$response = deleteJson('api/v1/payment-methods/'.$method->id);
|
||||
|
||||
$response->assertOk();
|
||||
|
||||
|
||||
@ -1,15 +1,17 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\Payment\PaymentsController;
|
||||
use Crater\Http\Requests\PaymentRequest;
|
||||
use Crater\Mail\SendPaymentMail;
|
||||
use Crater\Models\Invoice;
|
||||
use Crater\Models\Payment;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\PaymentRequest;
|
||||
use Crater\Http\Controllers\V1\Payment\PaymentsController;
|
||||
use Crater\Mail\SendPaymentMail;
|
||||
|
||||
use function Pest\Laravel\{postJson, putJson, getJson, deleteJson};
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -41,12 +43,12 @@ test('get payment', function () {
|
||||
|
||||
test('create payment', function () {
|
||||
$invoice = Invoice::factory()->create([
|
||||
'due_amount' => 100
|
||||
'due_amount' => 100,
|
||||
]);
|
||||
|
||||
$payment = Payment::factory()->raw([
|
||||
'invoice_id' => $invoice->id,
|
||||
'payment_number' => "PAY-000001"
|
||||
'payment_number' => "PAY-000001",
|
||||
]);
|
||||
|
||||
$response = postJson('api/v1/payments', $payment);
|
||||
@ -71,7 +73,7 @@ test('store validates using a form request', function () {
|
||||
|
||||
test('update payment', function () {
|
||||
$payment = Payment::factory()->create([
|
||||
'payment_date' => '1988-08-18'
|
||||
'payment_date' => '1988-08-18',
|
||||
]);
|
||||
|
||||
$payment2 = Payment::factory()->raw([
|
||||
@ -104,18 +106,17 @@ test('search payments', function () {
|
||||
'limit' => 15,
|
||||
'search' => 'doe',
|
||||
'payment_number' => 'PAY-000001',
|
||||
'payment_mode' => 'OTHER'
|
||||
'payment_mode' => 'OTHER',
|
||||
];
|
||||
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
|
||||
$response = getJson('api/v1/payments?' . $queryString);
|
||||
$response = getJson('api/v1/payments?'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
|
||||
test('send payment to customer', function () {
|
||||
|
||||
Mail::fake();
|
||||
|
||||
$payment = Payment::factory()->create();
|
||||
@ -124,13 +125,13 @@ test('send payment to customer', function () {
|
||||
'subject' => 'test',
|
||||
'body' => 'test',
|
||||
'from' => 'john@example.com',
|
||||
'to' => 'doe@example.com'
|
||||
'to' => 'doe@example.com',
|
||||
];
|
||||
|
||||
$response = postJson("api/v1/payments/{$payment->id}/send", $data);
|
||||
|
||||
$response->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
Mail::assertSent(SendPaymentMail::class);
|
||||
@ -142,12 +143,12 @@ test('delete payment', function () {
|
||||
$ids = $payments->pluck('id');
|
||||
|
||||
$data = [
|
||||
'ids' => $ids
|
||||
'ids' => $ids,
|
||||
];
|
||||
|
||||
$response = postJson('api/v1/payments/delete', $data);
|
||||
|
||||
$response->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
});
|
||||
|
||||
@ -1,6 +1,7 @@
|
||||
<?php
|
||||
use Crater\Models\User;
|
||||
|
||||
use Crater\Models\Company;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use function Pest\Laravel\getJson;
|
||||
@ -27,9 +28,9 @@ test('get customer sales report', function () {
|
||||
'to_date' => '2020-07-20',
|
||||
];
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
$queryString = Company::find(1)->unique_hash . '?' . $queryString;
|
||||
$queryString = Company::find(1)->unique_hash.'?'.$queryString;
|
||||
|
||||
$response = getJson('reports/sales/customers/'. $queryString);
|
||||
$response = getJson('reports/sales/customers/'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
@ -42,9 +43,9 @@ test('get item sales report', function () {
|
||||
'to_date' => '2020-07-20',
|
||||
];
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
$queryString = Company::find(1)->unique_hash . '?' . $queryString;
|
||||
$queryString = Company::find(1)->unique_hash.'?'.$queryString;
|
||||
|
||||
$response = getJson('reports/sales/items/' . $queryString);
|
||||
$response = getJson('reports/sales/items/'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
@ -57,9 +58,9 @@ test('get expenses report', function () {
|
||||
'to_date' => '2020-07-20',
|
||||
];
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
$queryString = Company::find(1)->unique_hash . '?' . $queryString;
|
||||
$queryString = Company::find(1)->unique_hash.'?'.$queryString;
|
||||
|
||||
$response = getJson('reports/expenses/' . $queryString);
|
||||
$response = getJson('reports/expenses/'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
@ -72,9 +73,9 @@ test('get tax summary', function () {
|
||||
'to_date' => '2020-07-20',
|
||||
];
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
$queryString = Company::find(1)->unique_hash . '?' . $queryString;
|
||||
$queryString = Company::find(1)->unique_hash.'?'.$queryString;
|
||||
|
||||
$response = getJson('reports/tax-summary/' . $queryString);
|
||||
$response = getJson('reports/tax-summary/'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
@ -87,10 +88,9 @@ test('get profit loss', function () {
|
||||
'to_date' => '2020-07-20',
|
||||
];
|
||||
$queryString = http_build_query($filters, '', '&');
|
||||
$queryString = Company::find(1)->unique_hash . '?' . $queryString;
|
||||
$queryString = Company::find(1)->unique_hash.'?'.$queryString;
|
||||
|
||||
$response = getJson('reports/profit-loss/' . $queryString);
|
||||
$response = getJson('reports/profit-loss/'.$queryString);
|
||||
|
||||
$response->assertOk();
|
||||
});
|
||||
|
||||
|
||||
@ -1,13 +1,16 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\Settings\TaxTypesController;
|
||||
use Crater\Http\Requests\TaxTypeRequest;
|
||||
use Crater\Models\TaxType;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\TaxTypeRequest;
|
||||
use Crater\Http\Controllers\V1\Settings\TaxTypesController;
|
||||
|
||||
use function Pest\Laravel\{postJson, putJson, getJson, deleteJson};
|
||||
use function Pest\Laravel\deleteJson;
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -48,11 +51,11 @@ test('store validates using a form request', function () {
|
||||
test('get tax type', function () {
|
||||
$taxType = TaxType::factory()->create();
|
||||
|
||||
$response = getJson('api/v1/tax-types/' . $taxType->id);
|
||||
$response = getJson('api/v1/tax-types/'.$taxType->id);
|
||||
|
||||
$response->assertOk()
|
||||
->assertJson([
|
||||
'taxType' => $taxType->toArray()
|
||||
'taxType' => $taxType->toArray(),
|
||||
]);
|
||||
});
|
||||
|
||||
@ -61,11 +64,11 @@ test('update tax type', function () {
|
||||
|
||||
$taxType1 = TaxType::factory()->raw();
|
||||
|
||||
$response = putJson('api/v1/tax-types/' . $taxType->id, $taxType1);
|
||||
$response = putJson('api/v1/tax-types/'.$taxType->id, $taxType1);
|
||||
|
||||
$response->assertOk()
|
||||
->assertJson([
|
||||
'taxType' => $taxType1
|
||||
'taxType' => $taxType1,
|
||||
]);
|
||||
});
|
||||
|
||||
@ -80,11 +83,11 @@ test('update validates using a form request', function () {
|
||||
test('delete tax type', function () {
|
||||
$taxType = TaxType::factory()->create();
|
||||
|
||||
$response = deleteJson('api/v1/tax-types/' . $taxType->id);
|
||||
$response = deleteJson('api/v1/tax-types/'.$taxType->id);
|
||||
|
||||
$response->assertOk()
|
||||
->assertJson([
|
||||
'success' => true
|
||||
'success' => true,
|
||||
]);
|
||||
|
||||
$this->assertDeleted($taxType);
|
||||
|
||||
@ -1,12 +1,15 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Http\Controllers\V1\Item\UnitsController;
|
||||
use Crater\Http\Requests\UnitRequest;
|
||||
use Crater\Models\Unit;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use Crater\Http\Requests\UnitRequest;
|
||||
use Crater\Http\Controllers\V1\Item\UnitsController;
|
||||
use function Pest\Laravel\{postJson, putJson, getJson, deleteJson};
|
||||
use function Pest\Laravel\deleteJson;
|
||||
use function Pest\Laravel\getJson;
|
||||
use function Pest\Laravel\postJson;
|
||||
use function Pest\Laravel\putJson;
|
||||
|
||||
beforeEach(function () {
|
||||
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
||||
@ -31,7 +34,7 @@ test('get units', function () {
|
||||
test('create unit', function () {
|
||||
$data = [
|
||||
'name' => 'unit name',
|
||||
'company_id' => User::find(1)->company_id
|
||||
'company_id' => User::find(1)->company_id,
|
||||
];
|
||||
|
||||
$response = postJson('api/v1/units', $data);
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Tests\TestCase;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Tests\TestCase;
|
||||
|
||||
uses(TestCase::class, RefreshDatabase::class)->in('Feature');
|
||||
uses(TestCase::class, RefreshDatabase::class)->in('Unit');
|
||||
|
||||
@ -1,14 +1,16 @@
|
||||
<?php
|
||||
|
||||
namespace Tests;
|
||||
|
||||
use JMac\Testing\Traits\AdditionalAssertions;
|
||||
use Illuminate\Foundation\Testing\TestCase as BaseTestCase;
|
||||
use Illuminate\Database\Eloquent\Factories\Factory;
|
||||
use Illuminate\Foundation\Testing\TestCase as BaseTestCase;
|
||||
use Illuminate\Support\Str;
|
||||
use JMac\Testing\Traits\AdditionalAssertions;
|
||||
|
||||
abstract class TestCase extends BaseTestCase
|
||||
{
|
||||
use CreatesApplication, AdditionalAssertions;
|
||||
use CreatesApplication;
|
||||
use AdditionalAssertions;
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Address;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -30,4 +30,3 @@ test('an address belongs to country', function () {
|
||||
|
||||
$this->assertTrue($address->country->exists());
|
||||
});
|
||||
|
||||
|
||||
@ -1,8 +1,8 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\CompanySetting;
|
||||
use Crater\Models\Company;
|
||||
use Crater\Models\CompanySetting;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use function Pest\Faker\faker;
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Company;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,8 +1,8 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Country;
|
||||
use Crater\Models\Address;
|
||||
use Crater\Models\Country;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -24,9 +24,8 @@ test('country has many addresses', function () {
|
||||
$country = Country::find(1);
|
||||
|
||||
$address = Address::factory()->count(5)->create([
|
||||
'country_id' => $country->id
|
||||
'country_id' => $country->id,
|
||||
]);
|
||||
|
||||
$this->assertTrue($country->address()->exists());
|
||||
});
|
||||
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\CustomField;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\CustomFieldValue;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,9 +1,9 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Estimate;
|
||||
use Crater\Models\Item;
|
||||
use Crater\Models\EstimateItem;
|
||||
use Crater\Models\Item;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -30,7 +30,7 @@ test('estimate item belongs to estimate', function () {
|
||||
test('estimate item belongs to item', function () {
|
||||
$estimateItem = EstimateItem::factory()->create([
|
||||
'item_id' => Item::factory(),
|
||||
'estimate_id' => Estimate::factory()
|
||||
'estimate_id' => Estimate::factory(),
|
||||
]);
|
||||
|
||||
$this->assertTrue($estimateItem->item()->exists());
|
||||
@ -39,7 +39,7 @@ test('estimate item belongs to item', function () {
|
||||
|
||||
test('estimate item has many taxes', function () {
|
||||
$estimateItem = EstimateItem::factory()->hasTaxes(5)->create([
|
||||
'estimate_id' => Estimate::factory()
|
||||
'estimate_id' => Estimate::factory(),
|
||||
]);
|
||||
|
||||
$this->assertCount(5, $estimateItem->taxes);
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\EstimateTemplate;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,9 +1,9 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\Estimate;
|
||||
use Crater\Models\EstimateItem;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
@ -54,15 +54,15 @@ test('estimate belongs to estimate template', function () {
|
||||
|
||||
|
||||
test('get next estimate number', function () {
|
||||
$estimate = Estimate::factory()->create();
|
||||
$estimate = Estimate::factory()->create();
|
||||
|
||||
$prefix = $estimate->getEstimatePrefixAttribute();
|
||||
$prefix = $estimate->getEstimatePrefixAttribute();
|
||||
|
||||
$nextNumber = $estimate->getNextEstimateNumber($prefix);
|
||||
$nextNumber = $estimate->getNextEstimateNumber($prefix);
|
||||
|
||||
$estimate1 = Estimate::factory()->create();
|
||||
$estimate1 = Estimate::factory()->create();
|
||||
|
||||
$this->assertEquals($prefix.'-'.$nextNumber, $estimate1['estimate_number']);
|
||||
$this->assertEquals($prefix.'-'.$nextNumber, $estimate1['estimate_number']);
|
||||
});
|
||||
|
||||
test('get estimate prefix attribute', function () {
|
||||
@ -96,7 +96,7 @@ test('create estimate', function () {
|
||||
$estimate['taxes'] = [];
|
||||
array_push($estimate['taxes'], Tax::factory()->raw());
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace($estimate);
|
||||
|
||||
@ -121,7 +121,7 @@ test('create estimate', function () {
|
||||
'discount_type' => $estimate['discount_type'],
|
||||
'discount_val' => $estimate['discount_val'],
|
||||
'tax' => $estimate['tax'],
|
||||
'notes' => $estimate['notes']
|
||||
'notes' => $estimate['notes'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -131,7 +131,7 @@ test('update estimate', function () {
|
||||
$newEstimate = Estimate::factory()->raw();
|
||||
|
||||
$item = EstimateItem::factory()->raw([
|
||||
'estimate_id' => $estimate->id
|
||||
'estimate_id' => $estimate->id,
|
||||
]);
|
||||
|
||||
$newEstimate['items'] = [];
|
||||
@ -140,7 +140,7 @@ test('update estimate', function () {
|
||||
array_push($newEstimate['items'], $item);
|
||||
array_push($newEstimate['taxes'], Tax::factory()->raw());
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace($newEstimate);
|
||||
|
||||
@ -156,7 +156,7 @@ test('update estimate', function () {
|
||||
'description' => $item['description'],
|
||||
'price' => $item['price'],
|
||||
'total' => $item['total'],
|
||||
'quantity' => $item['quantity']
|
||||
'quantity' => $item['quantity'],
|
||||
]);
|
||||
|
||||
$this->assertDatabaseHas('estimates', [
|
||||
@ -169,7 +169,7 @@ test('update estimate', function () {
|
||||
'discount_type' => $newEstimate['discount_type'],
|
||||
'discount_val' => $newEstimate['discount_val'],
|
||||
'tax' => $newEstimate['tax'],
|
||||
'notes' => $newEstimate['notes']
|
||||
'notes' => $newEstimate['notes'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -179,12 +179,12 @@ test('create items', function () {
|
||||
$items = [];
|
||||
|
||||
$item = EstimateItem::factory()->raw([
|
||||
'invoice_id' => $estimate->id
|
||||
'invoice_id' => $estimate->id,
|
||||
]);
|
||||
|
||||
array_push($items, $item);
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace(['items' => $items ]);
|
||||
|
||||
@ -196,7 +196,7 @@ test('create items', function () {
|
||||
'price' => $item['price'],
|
||||
'tax' => $item['tax'],
|
||||
'quantity' => $item['quantity'],
|
||||
'total' => $item['total']
|
||||
'total' => $item['total'],
|
||||
]);
|
||||
|
||||
$this->assertCount(1, $estimate->items);
|
||||
@ -207,17 +207,17 @@ test('create taxes', function () {
|
||||
$taxes = [];
|
||||
|
||||
$tax1 = Tax::factory()->raw([
|
||||
'estimate_id' => $estimate->id
|
||||
'estimate_id' => $estimate->id,
|
||||
]);
|
||||
|
||||
$tax2 = Tax::factory()->raw([
|
||||
'estimate_id' => $estimate->id
|
||||
'estimate_id' => $estimate->id,
|
||||
]);
|
||||
|
||||
array_push($taxes, $tax1);
|
||||
array_push($taxes, $tax2);
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace(['taxes' => $taxes ]);
|
||||
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\ExpenseCategory;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Expense;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,9 +1,9 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Invoice;
|
||||
use Crater\Models\Item;
|
||||
use Crater\Models\InvoiceItem;
|
||||
use Crater\Models\Item;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -30,7 +30,7 @@ test('invoice item belongs to invoice', function () {
|
||||
test('invoice item belongs to item', function () {
|
||||
$invoiceItem = InvoiceItem::factory()->create([
|
||||
'item_id' => Item::factory(),
|
||||
'invoice_id' => Invoice::factory()
|
||||
'invoice_id' => Invoice::factory(),
|
||||
]);
|
||||
|
||||
$this->assertTrue($invoiceItem->item()->exists());
|
||||
@ -39,7 +39,7 @@ test('invoice item belongs to item', function () {
|
||||
|
||||
test('invoice item has many taxes', function () {
|
||||
$invoiceItem = InvoiceItem::factory()->hasTaxes(5)->create([
|
||||
'invoice_id' => Invoice::factory()
|
||||
'invoice_id' => Invoice::factory(),
|
||||
]);
|
||||
|
||||
$this->assertCount(5, $invoiceItem->taxes);
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\InvoiceTemplate;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,9 +1,9 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\Invoice;
|
||||
use Crater\Models\InvoiceItem;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
@ -113,11 +113,11 @@ test('create invoice', function () {
|
||||
$invoice['taxes'] = [];
|
||||
array_push($invoice['taxes'], Tax::factory()->raw());
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace($invoice);
|
||||
|
||||
$invoice_number = explode("-",$invoice['invoice_number']);
|
||||
$invoice_number = explode("-", $invoice['invoice_number']);
|
||||
$number_attributes['invoice_number'] = $invoice_number[0].'-'.sprintf('%06d', intval($invoice_number[1]));
|
||||
|
||||
$response = Invoice::createInvoice($request);
|
||||
@ -150,11 +150,11 @@ test('update invoice', function () {
|
||||
$newInvoice = Invoice::factory()->raw();
|
||||
|
||||
$item = InvoiceItem::factory()->raw([
|
||||
'invoice_id' => $invoice->id
|
||||
'invoice_id' => $invoice->id,
|
||||
]);
|
||||
|
||||
$tax = Tax::factory()->raw([
|
||||
'invoice_id' => $invoice->id
|
||||
'invoice_id' => $invoice->id,
|
||||
]);
|
||||
|
||||
$newInvoice['items'] = [];
|
||||
@ -163,7 +163,7 @@ test('update invoice', function () {
|
||||
array_push($newInvoice['items'], $item);
|
||||
array_push($newInvoice['taxes'], $tax);
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace($newInvoice);
|
||||
|
||||
@ -201,12 +201,12 @@ test('create items', function () {
|
||||
$items = [];
|
||||
|
||||
$item = InvoiceItem::factory()->raw([
|
||||
'invoice_id' => $invoice->id
|
||||
'invoice_id' => $invoice->id,
|
||||
]);
|
||||
|
||||
array_push($items, $item);
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace(['items' => $items ]);
|
||||
|
||||
@ -218,7 +218,7 @@ test('create items', function () {
|
||||
'price' => $item['price'],
|
||||
'tax' => $item['tax'],
|
||||
'quantity' => $item['quantity'],
|
||||
'total' => $item['total']
|
||||
'total' => $item['total'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -228,12 +228,12 @@ test('create taxes', function () {
|
||||
$taxes = [];
|
||||
|
||||
$tax = Tax::factory()->raw([
|
||||
'invoice_id' => $invoice->id
|
||||
'invoice_id' => $invoice->id,
|
||||
]);
|
||||
|
||||
array_push($taxes, $tax);
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace(['taxes' => $taxes ]);
|
||||
|
||||
|
||||
@ -1,11 +1,11 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Item;
|
||||
use Crater\Models\InvoiceItem;
|
||||
use Crater\Models\Invoice;
|
||||
use Crater\Models\EstimateItem;
|
||||
use Crater\Models\Estimate;
|
||||
use Crater\Models\EstimateItem;
|
||||
use Crater\Models\Invoice;
|
||||
use Crater\Models\InvoiceItem;
|
||||
use Crater\Models\Item;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -40,7 +40,7 @@ test('an item has many taxes', function () {
|
||||
|
||||
test('an item has many invoice items', function () {
|
||||
$item = Item::factory()->has(InvoiceItem::factory()->count(5)->state([
|
||||
'invoice_id' => Invoice::factory()
|
||||
'invoice_id' => Invoice::factory(),
|
||||
]))->create();
|
||||
|
||||
$this->assertCount(5, $item->invoiceItems);
|
||||
@ -52,7 +52,7 @@ test('an item has many estimate items', function () {
|
||||
$item = Item::factory()->has(EstimateItem::factory()
|
||||
->count(5)
|
||||
->state([
|
||||
'estimate_id' => Estimate::factory()
|
||||
'estimate_id' => Estimate::factory(),
|
||||
]))
|
||||
->create();
|
||||
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\PaymentMethod;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Payment;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -47,7 +47,7 @@ test('get payment num attribute', function () {
|
||||
|
||||
$prefix_attribute = $payment->getPaymentPrefixAttribute();
|
||||
|
||||
$this->assertEquals($prefix_attribute.'-'.$num_attribute , $payment['payment_number']);
|
||||
$this->assertEquals($prefix_attribute.'-'.$num_attribute, $payment['payment_number']);
|
||||
});
|
||||
|
||||
test('get payment prefix attribute', function () {
|
||||
@ -57,7 +57,7 @@ test('get payment prefix attribute', function () {
|
||||
|
||||
$prefix_attribute = $payment->getPaymentPrefixAttribute();
|
||||
|
||||
$this->assertEquals($prefix_attribute.'-'.$num_attribute , $payment['payment_number']);
|
||||
$this->assertEquals($prefix_attribute.'-'.$num_attribute, $payment['payment_number']);
|
||||
});
|
||||
|
||||
test('get next payment number', function () {
|
||||
@ -69,6 +69,5 @@ test('get next payment number', function () {
|
||||
|
||||
$payment2 = Payment::factory()->create();
|
||||
|
||||
$this->assertEquals($prefix_attribute.'-'.$next_payment_number , $payment2['payment_number']);
|
||||
$this->assertEquals($prefix_attribute.'-'.$next_payment_number, $payment2['payment_number']);
|
||||
});
|
||||
|
||||
|
||||
@ -3,9 +3,10 @@
|
||||
use Crater\Http\Requests\CustomFieldRequest;
|
||||
|
||||
test('custom field request validation rules', function () {
|
||||
$request = new CustomFieldRequest;
|
||||
$request = new CustomFieldRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'name' => 'required',
|
||||
'label' => 'required',
|
||||
'model_type' => 'required',
|
||||
@ -20,7 +21,7 @@ test('custom field request validation rules', function () {
|
||||
});
|
||||
|
||||
test('custom field request authorize', function () {
|
||||
$request = new CustomFieldRequest;
|
||||
$request = new CustomFieldRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,57 +3,59 @@
|
||||
use Crater\Http\Requests\CustomerRequest;
|
||||
|
||||
test('customer request post validation rules', function () {
|
||||
$request = new CustomerRequest;
|
||||
$request = new CustomerRequest();
|
||||
|
||||
$request->setMethod('POST');
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'name' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'addresses.*.address_street_1' => [
|
||||
'max:255'
|
||||
'max:255',
|
||||
],
|
||||
'addresses.*.address_street_2' => [
|
||||
'max:255'
|
||||
'max:255',
|
||||
],
|
||||
'email' => [
|
||||
'email',
|
||||
'nullable',
|
||||
'unique:users,email',
|
||||
]
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
});
|
||||
|
||||
test('customer request put validation rules', function () {
|
||||
$request = new CustomerRequest;
|
||||
$request = new CustomerRequest();
|
||||
|
||||
$request->setMethod('PUT');
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'name' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'addresses.*.address_street_1' => [
|
||||
'max:255'
|
||||
'max:255',
|
||||
],
|
||||
'addresses.*.address_street_2' => [
|
||||
'max:255'
|
||||
'max:255',
|
||||
],
|
||||
'email' => [
|
||||
'email',
|
||||
'nullable',
|
||||
'unique:users,email',
|
||||
]
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
});
|
||||
|
||||
test('customer request authorize', function () {
|
||||
$request = new CustomerRequest;
|
||||
$request = new CustomerRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -1,63 +1,64 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\Estimate;
|
||||
use Crater\Http\Requests\EstimatesRequest;
|
||||
use Crater\Models\Estimate;
|
||||
use Crater\Rules\UniqueNumber;
|
||||
|
||||
test('estimate request validation rules', function () {
|
||||
$request = new EstimatesRequest;
|
||||
$request = new EstimatesRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'estimate_date' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'expiry_date' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'user_id' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'discount' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'discount_val' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'sub_total' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'total' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'tax' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'estimate_template_id' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'items' => [
|
||||
'required',
|
||||
'array'
|
||||
'array',
|
||||
],
|
||||
'items.*.description' => [
|
||||
'max:255'
|
||||
'max:255',
|
||||
],
|
||||
'items.*' => [
|
||||
'required',
|
||||
'max:255'
|
||||
'max:255',
|
||||
],
|
||||
'items.*.name' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'items.*.quantity' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'items.*.price' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'estimate_number' => [
|
||||
'required',
|
||||
new UniqueNumber(Estimate::class)
|
||||
new UniqueNumber(Estimate::class),
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
@ -65,7 +66,7 @@ test('estimate request validation rules', function () {
|
||||
});
|
||||
|
||||
test('estimate request authorize', function () {
|
||||
$request = new EstimatesRequest;
|
||||
$request = new EstimatesRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,22 +3,23 @@
|
||||
use Crater\Http\Requests\ExpenseCategoryRequest;
|
||||
|
||||
test('expense category request validation rules', function () {
|
||||
$request = new ExpenseCategoryRequest;
|
||||
$request = new ExpenseCategoryRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'name' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'description' => [
|
||||
'nullable'
|
||||
]
|
||||
'nullable',
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
});
|
||||
|
||||
test('expense category request authorize', function () {
|
||||
$request = new ExpenseCategoryRequest;
|
||||
$request = new ExpenseCategoryRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,31 +3,32 @@
|
||||
use Crater\Http\Requests\ExpenseRequest;
|
||||
|
||||
test('expense request validation rules', function () {
|
||||
$request = new ExpenseRequest;
|
||||
$request = new ExpenseRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'expense_date' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'expense_category_id' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'amount' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'user_id' => [
|
||||
'nullable'
|
||||
'nullable',
|
||||
],
|
||||
'notes' => [
|
||||
'nullable'
|
||||
]
|
||||
'nullable',
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
});
|
||||
|
||||
test('expense request authorize', function () {
|
||||
$request = new ExpenseRequest;
|
||||
$request = new ExpenseRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,16 +3,17 @@
|
||||
use Crater\Http\Requests\GetSettingsRequest;
|
||||
|
||||
test('get settings request rules', function () {
|
||||
$request = new GetSettingsRequest;
|
||||
$request = new GetSettingsRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'settings' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'settings.*' => [
|
||||
'required',
|
||||
'string'
|
||||
]
|
||||
'string',
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
@ -20,7 +21,7 @@ test('get settings request rules', function () {
|
||||
|
||||
|
||||
test('get settings request authorize', function () {
|
||||
$request = new GetSettingsRequest;
|
||||
$request = new GetSettingsRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -5,59 +5,60 @@ use Crater\Models\Invoice;
|
||||
use Crater\Rules\UniqueNumber;
|
||||
|
||||
test('invoice request validation rules', function () {
|
||||
$request = new InvoicesRequest;
|
||||
$request = new InvoicesRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'invoice_date' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'due_date' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'user_id' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'discount' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'discount_val' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'sub_total' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'total' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'tax' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'invoice_template_id' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'items' => [
|
||||
'required',
|
||||
'array'
|
||||
'array',
|
||||
],
|
||||
'items.*' => [
|
||||
'required',
|
||||
'max:255'
|
||||
'max:255',
|
||||
],
|
||||
'items.*.description' => [
|
||||
'max:255'
|
||||
'max:255',
|
||||
],
|
||||
'items.*.name' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'items.*.quantity' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'items.*.price' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'invoice_number' => [
|
||||
'required',
|
||||
new UniqueNumber(Invoice::class)
|
||||
new UniqueNumber(Invoice::class),
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
@ -65,7 +66,7 @@ test('invoice request validation rules', function () {
|
||||
});
|
||||
|
||||
test('invoices request authorize', function () {
|
||||
$request = new InvoicesRequest;
|
||||
$request = new InvoicesRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,28 +3,29 @@
|
||||
use Crater\Http\Requests\ItemsRequest;
|
||||
|
||||
test('items request validation rules', function () {
|
||||
$request = new ItemsRequest;
|
||||
$request = new ItemsRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'name' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'price' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'unit_id' => [
|
||||
'nullable'
|
||||
'nullable',
|
||||
],
|
||||
'description' => [
|
||||
'nullable'
|
||||
]
|
||||
'nullable',
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
});
|
||||
|
||||
test('item request authorize', function () {
|
||||
$request = new ItemsRequest;
|
||||
$request = new ItemsRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,20 +3,21 @@
|
||||
use Crater\Http\Requests\PaymentMethodRequest;
|
||||
|
||||
test('payment method request validation rules', function () {
|
||||
$request = new PaymentMethodRequest;
|
||||
$request = new PaymentMethodRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'name' => [
|
||||
'required',
|
||||
'unique:payment_methods,name'
|
||||
]
|
||||
'unique:payment_methods,name',
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
});
|
||||
|
||||
test('payment method request authorize', function () {
|
||||
$request = new PaymentMethodRequest;
|
||||
$request = new PaymentMethodRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -5,21 +5,22 @@ use Crater\Models\Payment;
|
||||
use Crater\Rules\UniqueNumber;
|
||||
|
||||
test('payment request validation rules', function () {
|
||||
$request = new PaymentRequest;
|
||||
$request = new PaymentRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'payment_date' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'user_id' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'amount' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'payment_number' => [
|
||||
'required',
|
||||
new UniqueNumber(Payment::class)
|
||||
new UniqueNumber(Payment::class),
|
||||
],
|
||||
'invoice_id' => [
|
||||
'nullable',
|
||||
@ -36,7 +37,7 @@ test('payment request validation rules', function () {
|
||||
});
|
||||
|
||||
test('payment request authorize', function () {
|
||||
$request = new PaymentRequest;
|
||||
$request = new PaymentRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,24 +3,25 @@
|
||||
use Crater\Http\Requests\TaxTypeRequest;
|
||||
|
||||
test('tax type request validation rules', function () {
|
||||
$request = new TaxTypeRequest;
|
||||
$request = new TaxTypeRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'name' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'percent' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'description' => [
|
||||
'nullable'
|
||||
'nullable',
|
||||
],
|
||||
'compound_tax' => [
|
||||
'nullable'
|
||||
'nullable',
|
||||
],
|
||||
'collective_tax' => [
|
||||
'nullable'
|
||||
]
|
||||
'nullable',
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
@ -28,7 +29,7 @@ test('tax type request validation rules', function () {
|
||||
|
||||
|
||||
test('tax type request authorize', function () {
|
||||
$request = new TaxTypeRequest;
|
||||
$request = new TaxTypeRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,20 +3,21 @@
|
||||
use Crater\Http\Requests\UnitRequest;
|
||||
|
||||
test('unit request validation rules', function () {
|
||||
$request = new UnitRequest;
|
||||
$request = new UnitRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'name' => [
|
||||
'required',
|
||||
'unique:units,name'
|
||||
]
|
||||
'unique:units,name',
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
});
|
||||
|
||||
test('unit request authorize', function () {
|
||||
$request = new UnitRequest;
|
||||
$request = new UnitRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -3,15 +3,16 @@
|
||||
use Crater\Http\Requests\UpdateSettingsRequest;
|
||||
|
||||
test('update settings request rules', function () {
|
||||
$request = new UpdateSettingsRequest;
|
||||
$request = new UpdateSettingsRequest();
|
||||
|
||||
$this->assertEquals([
|
||||
$this->assertEquals(
|
||||
[
|
||||
'settings' => [
|
||||
'required'
|
||||
'required',
|
||||
],
|
||||
'settings.*' => [
|
||||
'required'
|
||||
]
|
||||
'required',
|
||||
],
|
||||
],
|
||||
$request->rules()
|
||||
);
|
||||
@ -19,7 +20,7 @@ test('update settings request rules', function () {
|
||||
|
||||
|
||||
test('update settings request authorize', function () {
|
||||
$request = new UpdateSettingsRequest;
|
||||
$request = new UpdateSettingsRequest();
|
||||
|
||||
$this->assertTrue($request->authorize());
|
||||
});
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Setting;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
use function Pest\Faker\faker;
|
||||
|
||||
@ -1,11 +1,11 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\Estimate;
|
||||
use Crater\Models\EstimateItem;
|
||||
use Crater\Models\Invoice;
|
||||
use Crater\Models\InvoiceItem;
|
||||
use Crater\Models\Tax;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -44,7 +44,7 @@ test('tax belongs to estimate', function () {
|
||||
|
||||
test('tax belongs to invoice item', function () {
|
||||
$tax = Tax::factory()->for(InvoiceItem::factory()->state([
|
||||
'invoice_id' => Invoice::factory()
|
||||
'invoice_id' => Invoice::factory(),
|
||||
]))->create();
|
||||
|
||||
$this->assertTrue($tax->invoiceItem()->exists());
|
||||
@ -52,7 +52,7 @@ test('tax belongs to invoice item', function () {
|
||||
|
||||
test('tax belongs to estimate item', function () {
|
||||
$tax = Tax::factory()->for(EstimateItem::factory()->state([
|
||||
'estimate_id' => Estimate::factory()
|
||||
'estimate_id' => Estimate::factory(),
|
||||
]))->create();
|
||||
|
||||
$this->assertTrue($tax->estimateItem()->exists());
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\TaxType;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Unit;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
|
||||
@ -21,7 +21,6 @@ beforeEach(function () {
|
||||
});
|
||||
|
||||
test('unit has many items', function () {
|
||||
|
||||
$unit = Unit::factory()->hasItems(5)->create();
|
||||
|
||||
$this->assertCount(5, $unit->items);
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Crater\Models\User;
|
||||
use Crater\Models\Address;
|
||||
use Crater\Models\User;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Laravel\Sanctum\Sanctum;
|
||||
@ -84,32 +84,32 @@ test('user has many invoices', function () {
|
||||
|
||||
test('create customer', function () {
|
||||
$customer = User::factory()->raw([
|
||||
'role' => 'customer'
|
||||
'role' => 'customer',
|
||||
]);
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace($customer);
|
||||
|
||||
$response = User::createCustomer($request);
|
||||
|
||||
$this->assertDatabaseHas('users', [
|
||||
$this->assertDatabaseHas('users', [
|
||||
'name' => $customer['name'],
|
||||
'email' => $customer['email'],
|
||||
'role' => $customer['role']
|
||||
'role' => $customer['role'],
|
||||
]);
|
||||
});
|
||||
|
||||
test('update customer', function () {
|
||||
$customer = User::factory()->create([
|
||||
'role' => 'customer'
|
||||
'role' => 'customer',
|
||||
]);
|
||||
|
||||
$customer2 = User::factory()->raw([
|
||||
'role' => 'customer'
|
||||
'role' => 'customer',
|
||||
]);
|
||||
|
||||
$request = new Request;
|
||||
$request = new Request();
|
||||
|
||||
$request->replace($customer2);
|
||||
|
||||
@ -121,6 +121,6 @@ test('update customer', function () {
|
||||
'id' => $customer->id,
|
||||
'name' => $customer2['name'],
|
||||
'email' => $customer2['email'],
|
||||
'role' => $customer2['role']
|
||||
'role' => $customer2['role'],
|
||||
]);
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user