Updates for tests
This commit is contained in:
parent
579bb07af3
commit
d5a7cab86c
|
|
@ -22,7 +22,7 @@ use Tests\TestCase;
|
||||||
*/
|
*/
|
||||||
class PeppolApiTest extends TestCase
|
class PeppolApiTest extends TestCase
|
||||||
{
|
{
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
|
|
||||||
protected function setUp(): void
|
protected function setUp(): void
|
||||||
|
|
|
||||||
|
|
@ -42,7 +42,7 @@ use InvoiceNinja\EInvoice\Models\FatturaPA\FatturaElettronicaHeaderType\FatturaE
|
||||||
|
|
||||||
class PeppolTest extends TestCase
|
class PeppolTest extends TestCase
|
||||||
{
|
{
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
|
|
||||||
protected int $iterations = 10;
|
protected int $iterations = 10;
|
||||||
|
|
|
||||||
|
|
@ -32,7 +32,7 @@ use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
class ProjectApiTest extends TestCase
|
class ProjectApiTest extends TestCase
|
||||||
{
|
{
|
||||||
use MakesHash;
|
use MakesHash;
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
|
|
||||||
protected $faker;
|
protected $faker;
|
||||||
|
|
|
||||||
|
|
@ -17,6 +17,7 @@ use Tests\MockAccountData;
|
||||||
use App\Factory\InvoiceItemFactory;
|
use App\Factory\InvoiceItemFactory;
|
||||||
use App\Factory\CloneQuoteToInvoiceFactory;
|
use App\Factory\CloneQuoteToInvoiceFactory;
|
||||||
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
|
@ -24,13 +25,15 @@ use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
class CloneQuoteToInvoiceFactoryTest extends TestCase
|
class CloneQuoteToInvoiceFactoryTest extends TestCase
|
||||||
{
|
{
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
|
|
||||||
protected function setUp(): void
|
protected function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
$this->makeTestData();
|
$this->makeTestData();
|
||||||
|
|
||||||
|
Model::reguard();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testCloneItemSanityInvoice()
|
public function testCloneItemSanityInvoice()
|
||||||
|
|
|
||||||
|
|
@ -29,7 +29,7 @@ use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
class EInvoiceTest extends TestCase
|
class EInvoiceTest extends TestCase
|
||||||
{
|
{
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
|
|
||||||
protected function setUp(): void
|
protected function setUp(): void
|
||||||
{
|
{
|
||||||
|
|
@ -74,7 +74,6 @@ class EInvoiceTest extends TestCase
|
||||||
|
|
||||||
$data = $this->getExpiredPurchases([$company->company_key], true);
|
$data = $this->getExpiredPurchases([$company->company_key], true);
|
||||||
|
|
||||||
|
|
||||||
$this->assertEquals(100, $data['purchased']);
|
$this->assertEquals(100, $data['purchased']);
|
||||||
$this->assertEquals(-50, $data['sent'] + $data['received']);
|
$this->assertEquals(-50, $data['sent'] + $data['received']);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -30,7 +30,7 @@ use Tests\TestCase;
|
||||||
class FactoryCreationTest extends TestCase
|
class FactoryCreationTest extends TestCase
|
||||||
{
|
{
|
||||||
use MakesHash;
|
use MakesHash;
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
|
|
||||||
protected function setUp(): void
|
protected function setUp(): void
|
||||||
|
|
|
||||||
|
|
@ -39,7 +39,7 @@ use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
class GeneratesCounterTest extends TestCase
|
class GeneratesCounterTest extends TestCase
|
||||||
{
|
{
|
||||||
use GeneratesCounter;
|
use GeneratesCounter;
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
use MakesHash;
|
use MakesHash;
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -11,18 +11,20 @@
|
||||||
|
|
||||||
namespace Tests\Unit;
|
namespace Tests\Unit;
|
||||||
|
|
||||||
use App\Factory\InvoiceInvitationFactory;
|
|
||||||
use App\Utils\Traits\MakesHash;
|
|
||||||
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
|
||||||
use Illuminate\Routing\Middleware\ThrottleRequests;
|
|
||||||
use Illuminate\Validation\ValidationException;
|
|
||||||
use Tests\MockAccountData;
|
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
use Tests\MockAccountData;
|
||||||
|
use App\Utils\Traits\MakesHash;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use App\Factory\InvoiceInvitationFactory;
|
||||||
|
use Illuminate\Validation\ValidationException;
|
||||||
|
use Illuminate\Routing\Middleware\ThrottleRequests;
|
||||||
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
|
|
||||||
|
|
||||||
class InvitationTest extends TestCase
|
class InvitationTest extends TestCase
|
||||||
{
|
{
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
use MakesHash;
|
use MakesHash;
|
||||||
|
|
||||||
protected function setUp(): void
|
protected function setUp(): void
|
||||||
|
|
@ -36,6 +38,8 @@ class InvitationTest extends TestCase
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->withoutExceptionHandling();
|
$this->withoutExceptionHandling();
|
||||||
|
|
||||||
|
Model::reguard();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testInvitationSanity()
|
public function testInvitationSanity()
|
||||||
|
|
@ -63,7 +67,7 @@ class InvitationTest extends TestCase
|
||||||
$response = $this->withHeaders([
|
$response = $this->withHeaders([
|
||||||
'X-API-SECRET' => config('ninja.api_secret'),
|
'X-API-SECRET' => config('ninja.api_secret'),
|
||||||
'X-API-TOKEN' => $this->token,
|
'X-API-TOKEN' => $this->token,
|
||||||
])->putJson('/api/v1/invoices/'.$this->invoice->hashed_id, $this->invoice->toArray());
|
])->putJson('/api/v1/invoices/'.$this->invoice->hashed_id, $data);
|
||||||
|
|
||||||
$response->assertStatus(200);
|
$response->assertStatus(200);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -11,35 +11,113 @@
|
||||||
|
|
||||||
namespace Tests\Unit;
|
namespace Tests\Unit;
|
||||||
|
|
||||||
use App\DataMapper\InvoiceItem;
|
use Tests\TestCase;
|
||||||
use App\Factory\InvoiceFactory;
|
use App\Models\User;
|
||||||
use App\Factory\InvoiceItemFactory;
|
use App\Models\Account;
|
||||||
use App\Helpers\Invoice\InvoiceSum;
|
use App\Models\Company;
|
||||||
use App\Helpers\Invoice\InvoiceSumInclusive;
|
|
||||||
use App\Models\Invoice;
|
use App\Models\Invoice;
|
||||||
use App\Models\Payment;
|
use App\Models\Payment;
|
||||||
use App\Repositories\InvoiceRepository;
|
|
||||||
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
|
||||||
use Tests\MockAccountData;
|
use Tests\MockAccountData;
|
||||||
use Tests\TestCase;
|
use App\Models\CompanyToken;
|
||||||
|
use App\DataMapper\InvoiceItem;
|
||||||
|
use App\Factory\InvoiceFactory;
|
||||||
|
use App\DataMapper\CompanySettings;
|
||||||
|
use App\Factory\CompanyUserFactory;
|
||||||
|
use App\Factory\InvoiceItemFactory;
|
||||||
|
use App\Helpers\Invoice\InvoiceSum;
|
||||||
|
use App\Repositories\InvoiceRepository;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use App\Helpers\Invoice\InvoiceSumInclusive;
|
||||||
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
|
|
||||||
class InvoiceMarkPaidTest extends TestCase
|
class InvoiceMarkPaidTest extends TestCase
|
||||||
{
|
{
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
// use DatabaseTransactions;
|
use DatabaseTransactions;
|
||||||
|
|
||||||
public $invoice;
|
public $invoice;
|
||||||
|
public $company;
|
||||||
|
|
||||||
|
public $user;
|
||||||
|
|
||||||
|
public $payload;
|
||||||
|
|
||||||
|
public $account;
|
||||||
|
|
||||||
|
public $client;
|
||||||
|
|
||||||
|
public $token;
|
||||||
|
|
||||||
|
public $cu;
|
||||||
|
public $faker;
|
||||||
|
|
||||||
public function setUp(): void
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
$this->makeTestData();
|
// $this->makeTestData();
|
||||||
|
|
||||||
|
$this->faker = \Faker\Factory::create();
|
||||||
|
|
||||||
|
Model::reguard();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function buildData()
|
||||||
|
{
|
||||||
|
if($this->account)
|
||||||
|
$this->account->forceDelete();
|
||||||
|
|
||||||
|
/** @var \App\Models\Account $account */
|
||||||
|
$this->account = Account::factory()->create([
|
||||||
|
'hosted_client_count' => 1000,
|
||||||
|
'hosted_company_count' => 1000,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->account->num_users = 3;
|
||||||
|
$this->account->save();
|
||||||
|
|
||||||
|
$this->user = User::factory()->create([
|
||||||
|
'account_id' => $this->account->id,
|
||||||
|
'confirmation_code' => 'xyz123',
|
||||||
|
'email' => $this->faker->unique()->safeEmail(),
|
||||||
|
]);
|
||||||
|
|
||||||
|
$settings = CompanySettings::defaults();
|
||||||
|
$settings->client_online_payment_notification = false;
|
||||||
|
$settings->client_manual_payment_notification = false;
|
||||||
|
|
||||||
|
$this->company = Company::factory()->create([
|
||||||
|
'account_id' => $this->account->id,
|
||||||
|
'settings' => $settings,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->company->settings = $settings;
|
||||||
|
$this->company->save();
|
||||||
|
|
||||||
|
$this->cu = CompanyUserFactory::create($this->user->id, $this->company->id, $this->account->id);
|
||||||
|
$this->cu->is_owner = true;
|
||||||
|
$this->cu->is_admin = true;
|
||||||
|
$this->cu->is_locked = false;
|
||||||
|
$this->cu->save();
|
||||||
|
|
||||||
|
$this->token = \Illuminate\Support\Str::random(64);
|
||||||
|
|
||||||
|
$company_token = new CompanyToken();
|
||||||
|
$company_token->user_id = $this->user->id;
|
||||||
|
$company_token->company_id = $this->company->id;
|
||||||
|
$company_token->account_id = $this->account->id;
|
||||||
|
$company_token->name = 'test token';
|
||||||
|
$company_token->token = $this->token;
|
||||||
|
$company_token->is_system = true;
|
||||||
|
|
||||||
|
$company_token->save();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testInvoiceMarkPaidFromDraft()
|
public function testInvoiceMarkPaidFromDraft()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
$this->buildData();
|
||||||
|
|
||||||
$c = \App\Models\Client::factory()->create([
|
$c = \App\Models\Client::factory()->create([
|
||||||
'user_id' => $this->user->id,
|
'user_id' => $this->user->id,
|
||||||
|
|
@ -75,6 +153,9 @@ class InvoiceMarkPaidTest extends TestCase
|
||||||
|
|
||||||
$i->calc()->getInvoice();
|
$i->calc()->getInvoice();
|
||||||
|
|
||||||
|
$repo = new InvoiceRepository();
|
||||||
|
$repo->save([], $i);
|
||||||
|
|
||||||
$response = $this->withHeaders([
|
$response = $this->withHeaders([
|
||||||
'X-API-SECRET' => config('ninja.api_secret'),
|
'X-API-SECRET' => config('ninja.api_secret'),
|
||||||
'X-API-TOKEN' => $this->token,
|
'X-API-TOKEN' => $this->token,
|
||||||
|
|
@ -92,8 +173,7 @@ class InvoiceMarkPaidTest extends TestCase
|
||||||
$this->assertEquals(10, $i->paid_to_date);
|
$this->assertEquals(10, $i->paid_to_date);
|
||||||
$this->assertEquals(4, $i->status_id);
|
$this->assertEquals(4, $i->status_id);
|
||||||
|
|
||||||
|
$this->account->delete();
|
||||||
$c->forceDelete();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -101,6 +181,7 @@ class InvoiceMarkPaidTest extends TestCase
|
||||||
public function testInvoiceMarkPaidFromDraftBulk()
|
public function testInvoiceMarkPaidFromDraftBulk()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
$this->buildData();
|
||||||
|
|
||||||
$c = \App\Models\Client::factory()->create([
|
$c = \App\Models\Client::factory()->create([
|
||||||
'user_id' => $this->user->id,
|
'user_id' => $this->user->id,
|
||||||
|
|
@ -137,6 +218,9 @@ class InvoiceMarkPaidTest extends TestCase
|
||||||
|
|
||||||
$i->calc()->getInvoice();
|
$i->calc()->getInvoice();
|
||||||
|
|
||||||
|
$repo = new InvoiceRepository();
|
||||||
|
$repo->save([], $i);
|
||||||
|
|
||||||
$data = [
|
$data = [
|
||||||
'action' => 'mark_paid',
|
'action' => 'mark_paid',
|
||||||
'ids' => [$i->hashed_id]
|
'ids' => [$i->hashed_id]
|
||||||
|
|
@ -161,6 +245,8 @@ class InvoiceMarkPaidTest extends TestCase
|
||||||
|
|
||||||
|
|
||||||
$c->forceDelete();
|
$c->forceDelete();
|
||||||
|
|
||||||
|
$this->account->delete();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -370,7 +370,12 @@ class LateFeeTest extends TestCase
|
||||||
|
|
||||||
$this->assertEquals(2, count($i->line_items));
|
$this->assertEquals(2, count($i->line_items));
|
||||||
|
|
||||||
|
try{
|
||||||
$i->service()->autoBill();
|
$i->service()->autoBill();
|
||||||
|
}
|
||||||
|
catch(\Exception $e){
|
||||||
|
nlog($e->getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
$i = $i->fresh();
|
$i = $i->fresh();
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue