added tax factory
This commit is contained in:
34
database/factories/Tax.php
Normal file
34
database/factories/Tax.php
Normal file
@ -0,0 +1,34 @@
|
||||
<?php
|
||||
|
||||
use App\Models\Auth\User;
|
||||
use App\Models\Setting\Tax;
|
||||
use Faker\Generator as Faker;
|
||||
|
||||
$user = User::first();
|
||||
$company = $user->companies()->first();
|
||||
|
||||
$factory->define(Tax::class, function (Faker $faker) use ($company) {
|
||||
setting()->setExtraColumns(['company_id' => $company->id]);
|
||||
|
||||
$types = ['normal', 'inclusive', 'compound', 'fixed'];
|
||||
|
||||
return [
|
||||
'company_id' => $company->id,
|
||||
'name' => $faker->text(15),
|
||||
'rate' => $faker->randomFloat(2, 10, 20),
|
||||
'type' => $faker->randomElement($types),
|
||||
'enabled' => $faker->boolean ? 1 : 0,
|
||||
];
|
||||
});
|
||||
|
||||
$factory->state(Tax::class, 'enabled', ['enabled' => 1]);
|
||||
|
||||
$factory->state(Tax::class, 'disabled', ['enabled' => 0]);
|
||||
|
||||
$factory->state(Tax::class, 'normal', ['type' => 'normal']);
|
||||
|
||||
$factory->state(Tax::class, 'inclusive', ['type' => 'inclusive']);
|
||||
|
||||
$factory->state(Tax::class, 'compound', ['type' => 'compound']);
|
||||
|
||||
$factory->state(Tax::class, 'fixed', ['type' => 'fixed']);
|
@ -3,6 +3,7 @@
|
||||
namespace Tests\Feature\Settings;
|
||||
|
||||
use App\Jobs\Setting\CreateTax;
|
||||
use App\Models\Setting\Tax;
|
||||
use Tests\Feature\FeatureTestCase;
|
||||
|
||||
class TaxesTest extends FeatureTestCase
|
||||
@ -26,7 +27,7 @@ class TaxesTest extends FeatureTestCase
|
||||
public function testItShouldCreateTax()
|
||||
{
|
||||
$this->loginAs()
|
||||
->post(route('taxes.store'), $this->getTaxRequest())
|
||||
->post(route('taxes.store'), $this->getRequest())
|
||||
->assertStatus(200);
|
||||
|
||||
$this->assertFlashLevel('success');
|
||||
@ -34,7 +35,7 @@ class TaxesTest extends FeatureTestCase
|
||||
|
||||
public function testItShouldUpdateTax()
|
||||
{
|
||||
$request = $this->getTaxRequest();
|
||||
$request = $this->getRequest();
|
||||
|
||||
$tax = $this->dispatch(new CreateTax($request));
|
||||
|
||||
@ -49,7 +50,7 @@ class TaxesTest extends FeatureTestCase
|
||||
|
||||
public function testItShouldDeleteTax()
|
||||
{
|
||||
$tax = $this->dispatch(new CreateTax($this->getTaxRequest()));
|
||||
$tax = $this->dispatch(new CreateTax($this->getRequest()));
|
||||
|
||||
$this->loginAs()
|
||||
->delete(route('taxes.destroy', $tax->id))
|
||||
@ -58,14 +59,8 @@ class TaxesTest extends FeatureTestCase
|
||||
$this->assertFlashLevel('success');
|
||||
}
|
||||
|
||||
private function getTaxRequest()
|
||||
public function getRequest()
|
||||
{
|
||||
return [
|
||||
'company_id' => $this->company->id,
|
||||
'name' => $this->faker->text(15),
|
||||
'rate' => $this->faker->randomFloat(2, 10, 20),
|
||||
'type' => $this->faker->randomElement(['normal', 'inclusive', 'compound']),
|
||||
'enabled' => $this->faker->boolean ? 1 : 0
|
||||
];
|
||||
return factory(Tax::class)->states('enabled')->raw();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user