Files
crater/tests/Unit/InvoiceTest.php
Mohit Panjwani 89ee58590c build version 400
2020-12-02 17:54:08 +05:30

248 lines
6.6 KiB
PHP

<?php
use Crater\Models\User;
use Crater\Models\Tax;
use Crater\Models\Invoice;
use Crater\Models\InvoiceItem;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Artisan;
use Laravel\Sanctum\Sanctum;
beforeEach(function () {
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
Artisan::call('db:seed', ['--class' => 'DemoSeeder', '--force' => true]);
Artisan::call('db:seed', ['--class' => 'UnitSeeder', '--force' => true]);
Artisan::call('db:seed', ['--class' => 'PaymentMethodSeeder', '--force' => true]);
$user = User::where('role', 'super admin')->first();
$this->withHeaders([
'company' => $user->company_id,
]);
Sanctum::actingAs(
$user,
['*']
);
});
test('invoice has many invoice items', function () {
$invoice = Invoice::factory()->hasItems(5)->create();
$this->assertCount(5, $invoice->items);
$this->assertTrue($invoice->items()->exists());
});
test('invoice has many taxes', function () {
$invoice = Invoice::factory()->hasTaxes(5)->create();
$this->assertCount(5, $invoice->taxes);
$this->assertTrue($invoice->taxes()->exists());
});
test('invoice has many payments', function () {
$invoice = Invoice::factory()->hasPayments(5)->create();
$this->assertCount(5, $invoice->payments);
$this->assertTrue($invoice->payments()->exists());
});
test('invoice belongs to user', function () {
$invoice = Invoice::factory()->forUser()->create();
$this->assertTrue($invoice->user()->exists());
});
test('invoice belongs to invoice template', function () {
$invoice = Invoice::factory()->forInvoiceTemplate()->create();
$this->assertTrue($invoice->invoiceTemplate()->exists());
});
test('get next invoice number', function () {
$invoice = Invoice::factory()->create();
$prefix = $invoice->getInvoicePrefixAttribute();
$nextNumber = $invoice->getNextInvoiceNumber($prefix);
$invoice1 = Invoice::factory()->create();
$this->assertEquals($prefix.'-'.$nextNumber, $invoice1['invoice_number']);
});
test('get invoice prefix attribute', function () {
$invoice = Invoice::factory()->create();
$num = $invoice->getInvoiceNumAttribute();
$prefix = $invoice->getInvoicePrefixAttribute();
$this->assertEquals($prefix.'-'.$num, $invoice['invoice_number']);
});
test('get invoice num attribute', function () {
$invoice = Invoice::factory()->create();
$num = $invoice->getInvoiceNumAttribute();
$prefix = $invoice->getInvoicePrefixAttribute();
$this->assertEquals($prefix.'-'.$num, $invoice['invoice_number']);
});
test('get previous status', function () {
$invoice = Invoice::factory()->create();
$status = $invoice->getPreviousStatus();
$this->assertEquals('OVERDUE', $status);
});
test('create invoice', function () {
$invoice = Invoice::factory()->raw();
$item = InvoiceItem::factory()->raw();
$invoice['items'] = [];
array_push($invoice['items'], $item);
$invoice['taxes'] = [];
array_push($invoice['taxes'], Tax::factory()->raw());
$request = new Request;
$request->replace($invoice);
$invoice_number = explode("-",$invoice['invoice_number']);
$number_attributes['invoice_number'] = $invoice_number[0].'-'.sprintf('%06d', intval($invoice_number[1]));
$response = Invoice::createInvoice($request);
$this->assertDatabaseHas('invoice_items', [
'invoice_id' => $response->id,
'name' => $item['name'],
'description' => $item['description'],
'total' => $item['total'],
'quantity' => $item['quantity'],
'discount' => $item['discount'],
'price' => $item['price'],
]);
$this->assertDatabaseHas('invoices', [
'invoice_number' => $invoice['invoice_number'],
'sub_total' => $invoice['sub_total'],
'total' => $invoice['total'],
'tax' => $invoice['tax'],
'discount' => $invoice['discount'],
'notes' => $invoice['notes'],
'user_id' => $invoice['user_id'],
'invoice_template_id' => $invoice['invoice_template_id'],
]);
});
test('update invoice', function () {
$invoice = Invoice::factory()->create();
$newInvoice = Invoice::factory()->raw();
$item = InvoiceItem::factory()->raw([
'invoice_id' => $invoice->id
]);
$tax = Tax::factory()->raw([
'invoice_id' => $invoice->id
]);
$newInvoice['items'] = [];
$newInvoice['taxes'] = [];
array_push($newInvoice['items'], $item);
array_push($newInvoice['taxes'], $tax);
$request = new Request;
$request->replace($newInvoice);
$invoice_number = explode("-", $newInvoice['invoice_number']);
$number_attributes['invoice_number'] = $invoice_number[0].'-'.sprintf('%06d', intval($invoice_number[1]));
$response = $invoice->updateInvoice($request);
$this->assertDatabaseHas('invoice_items', [
'invoice_id' => $response->id,
'name' => $item['name'],
'description' => $item['description'],
'total' => $item['total'],
'quantity' => $item['quantity'],
'discount' => $item['discount'],
'price' => $item['price'],
]);
$this->assertDatabaseHas('invoices', [
'invoice_number' => $newInvoice['invoice_number'],
'sub_total' => $newInvoice['sub_total'],
'total' => $newInvoice['total'],
'tax' => $newInvoice['tax'],
'discount' => $newInvoice['discount'],
'notes' => $newInvoice['notes'],
'user_id' => $newInvoice['user_id'],
'invoice_template_id' => $newInvoice['invoice_template_id'],
]);
});
test('create items', function () {
$invoice = Invoice::factory()->create();
$items = [];
$item = InvoiceItem::factory()->raw([
'invoice_id' => $invoice->id
]);
array_push($items, $item);
$request = new Request;
$request->replace(['items' => $items ]);
Invoice::createItems($invoice, $request);
$this->assertDatabaseHas('invoice_items', [
'invoice_id' => $invoice->id,
'description' => $item['description'],
'price' => $item['price'],
'tax' => $item['tax'],
'quantity' => $item['quantity'],
'total' => $item['total']
]);
});
test('create taxes', function () {
$invoice = Invoice::factory()->create();
$taxes = [];
$tax = Tax::factory()->raw([
'invoice_id' => $invoice->id
]);
array_push($taxes, $tax);
$request = new Request;
$request->replace(['taxes' => $taxes ]);
Invoice::createTaxes($invoice, $request);
$this->assertDatabaseHas('taxes', [
'invoice_id' => $invoice->id,
'name' => $tax['name'],
'amount' => $tax['amount'],
]);
});