2022-09-15 06:15:02 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoice Ninja (https://invoiceninja.com).
|
|
|
|
*
|
|
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
|
|
*
|
|
|
|
* @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
|
|
|
|
*
|
|
|
|
* @license https://www.elastic.co/licensing/elastic-license
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Tests\Feature\Bank;
|
|
|
|
|
2022-10-27 03:10:11 +02:00
|
|
|
use App\Factory\BankIntegrationFactory;
|
|
|
|
use App\Factory\BankTransactionFactory;
|
2022-12-05 00:07:34 +01:00
|
|
|
use App\Factory\InvoiceFactory;
|
|
|
|
use App\Factory\InvoiceItemFactory;
|
2022-09-15 06:15:02 +02:00
|
|
|
use App\Models\BankTransaction;
|
|
|
|
use App\Models\Invoice;
|
|
|
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
|
|
|
use Tests\MockAccountData;
|
|
|
|
use Tests\TestCase;
|
|
|
|
|
|
|
|
class BankTransactionTest extends TestCase
|
|
|
|
{
|
|
|
|
use DatabaseTransactions;
|
|
|
|
use MockAccountData;
|
|
|
|
|
|
|
|
protected function setUp() :void
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
$this->makeTestData();
|
|
|
|
|
|
|
|
$this->withoutMiddleware(
|
|
|
|
ThrottleRequests::class
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-01-22 04:49:15 +01:00
|
|
|
|
|
|
|
public function testBankTransactionBulkActions()
|
|
|
|
{
|
|
|
|
$data = [
|
|
|
|
'ids' => [$this->bank_integration->hashed_id],
|
|
|
|
'action' => 'archive'
|
|
|
|
];
|
|
|
|
|
|
|
|
$response = $this->withHeaders([
|
|
|
|
'X-API-SECRET' => config('ninja.api_secret'),
|
|
|
|
'X-API-TOKEN' => $this->token,
|
|
|
|
])->post('/api/v1/bank_transactions/bulk', $data)
|
|
|
|
->assertStatus(200);
|
|
|
|
|
|
|
|
$data = [
|
|
|
|
'ids' => [$this->bank_integration->hashed_id],
|
|
|
|
'action' => 'restore'
|
|
|
|
];
|
|
|
|
|
|
|
|
$response = $this->withHeaders([
|
|
|
|
'X-API-SECRET' => config('ninja.api_secret'),
|
|
|
|
'X-API-TOKEN' => $this->token,
|
|
|
|
])->post('/api/v1/bank_transactions/bulk', $data)
|
|
|
|
->assertStatus(200);
|
|
|
|
|
|
|
|
$data = [
|
|
|
|
'ids' => [$this->bank_integration->hashed_id],
|
|
|
|
'action' => 'delete'
|
|
|
|
];
|
|
|
|
|
|
|
|
$response = $this->withHeaders([
|
|
|
|
'X-API-SECRET' => config('ninja.api_secret'),
|
|
|
|
'X-API-TOKEN' => $this->token,
|
|
|
|
])->post('/api/v1/bank_transactions/bulk', $data)
|
|
|
|
->assertStatus(200);
|
|
|
|
}
|
|
|
|
|
2022-11-30 08:40:55 +01:00
|
|
|
public function testLinkExpenseToTransaction()
|
|
|
|
{
|
|
|
|
$data = [];
|
|
|
|
|
|
|
|
$bi = BankIntegrationFactory::create($this->company->id, $this->user->id, $this->account->id);
|
|
|
|
$bi->save();
|
|
|
|
|
|
|
|
$bt = BankTransactionFactory::create($this->company->id, $this->user->id);
|
|
|
|
$bt->bank_integration_id = $bi->id;
|
|
|
|
$bt->status_id = BankTransaction::STATUS_UNMATCHED;
|
|
|
|
$bt->description = 'Fuel';
|
|
|
|
$bt->amount = 10;
|
|
|
|
$bt->currency_code = $this->client->currency()->code;
|
|
|
|
$bt->date = now()->format('Y-m-d');
|
|
|
|
$bt->transaction_id = 1234567890;
|
|
|
|
$bt->category_id = 10000003;
|
|
|
|
$bt->base_type = 'DEBIT';
|
|
|
|
$bt->save();
|
|
|
|
|
2022-12-05 00:07:34 +01:00
|
|
|
$this->expense->vendor_id = $this->vendor->id;
|
|
|
|
$this->expense->save();
|
|
|
|
|
2022-11-30 08:40:55 +01:00
|
|
|
$data = [];
|
|
|
|
|
|
|
|
$data['transactions'][] = [
|
|
|
|
'id' => $bt->hashed_id,
|
|
|
|
'expense_id' => $this->expense->hashed_id
|
|
|
|
];
|
|
|
|
|
|
|
|
$response = $this->withHeaders([
|
|
|
|
'X-API-SECRET' => config('ninja.api_secret'),
|
|
|
|
'X-API-TOKEN' => $this->token,
|
|
|
|
])->postJson('/api/v1/bank_transactions/match', $data);
|
|
|
|
|
|
|
|
$response->assertStatus(200);
|
|
|
|
|
|
|
|
$this->assertEquals($this->expense->refresh()->transaction_id, $bt->id);
|
|
|
|
$this->assertEquals($bt->refresh()->expense_id, $this->expense->id);
|
2022-12-05 00:07:34 +01:00
|
|
|
$this->assertEquals($this->vendor->id, $bt->vendor_id);
|
|
|
|
$this->assertEquals(BankTransaction::STATUS_CONVERTED, $bt->status_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testLinkingManuallyPaidInvoices()
|
|
|
|
{
|
|
|
|
$invoice = InvoiceFactory::create($this->company->id, $this->user->id);
|
|
|
|
$invoice->client_id = $this->client->id;
|
|
|
|
$invoice->status_id = Invoice::STATUS_SENT;
|
|
|
|
$invoice->number = "InvoiceMatchingNumber123";
|
|
|
|
$line_items = [];
|
|
|
|
|
|
|
|
$item = InvoiceItemFactory::create();
|
|
|
|
$item->quantity = 1;
|
|
|
|
$item->cost = 325;
|
|
|
|
$item->type_id = 1;
|
|
|
|
|
|
|
|
$line_items[] = $item;
|
|
|
|
|
|
|
|
$invoice->line_items = $line_items;
|
|
|
|
|
|
|
|
$invoice = $invoice->calc()->getInvoice();
|
|
|
|
|
|
|
|
$invoice->service()->markPaid();
|
|
|
|
|
|
|
|
$p = $invoice->payments->first();
|
|
|
|
|
|
|
|
|
|
|
|
$bi = BankIntegrationFactory::create($this->company->id, $this->user->id, $this->account->id);
|
|
|
|
$bi->save();
|
|
|
|
|
|
|
|
$bt = BankTransactionFactory::create($this->company->id, $this->user->id);
|
|
|
|
$bt->bank_integration_id = $bi->id;
|
|
|
|
$bt->status_id = BankTransaction::STATUS_UNMATCHED;
|
|
|
|
$bt->description = 'InvoiceMatchingNumber123';
|
|
|
|
$bt->amount = 325;
|
|
|
|
$bt->currency_code = $this->client->currency()->code;
|
|
|
|
$bt->date = now()->format('Y-m-d');
|
|
|
|
$bt->transaction_id = 1234567890;
|
|
|
|
$bt->category_id = 10000003;
|
|
|
|
$bt->base_type = 'CREDIT';
|
|
|
|
$bt->save();
|
|
|
|
|
|
|
|
$data = [];
|
|
|
|
|
|
|
|
$data['transactions'][] = [
|
|
|
|
'id' => $bt->hashed_id,
|
|
|
|
'payment_id' => $p->hashed_id
|
|
|
|
];
|
|
|
|
|
|
|
|
$response = $this->withHeaders([
|
|
|
|
'X-API-SECRET' => config('ninja.api_secret'),
|
|
|
|
'X-API-TOKEN' => $this->token,
|
|
|
|
])->postJson('/api/v1/bank_transactions/match', $data);
|
|
|
|
|
|
|
|
$response->assertStatus(200);
|
|
|
|
|
|
|
|
$this->assertEquals($p->refresh()->transaction_id, $bt->id);
|
|
|
|
$this->assertEquals($bt->refresh()->payment_id, $p->id);
|
2022-11-30 08:40:55 +01:00
|
|
|
$this->assertEquals(BankTransaction::STATUS_CONVERTED, $bt->status_id);
|
2022-12-05 00:07:34 +01:00
|
|
|
$this->assertEquals($invoice->hashed_id, $bt->invoice_ids);
|
2022-11-30 08:40:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-11-30 08:39:22 +01:00
|
|
|
public function testLinkPaymentToTransaction()
|
|
|
|
{
|
|
|
|
$data = [];
|
|
|
|
|
|
|
|
$bi = BankIntegrationFactory::create($this->company->id, $this->user->id, $this->account->id);
|
|
|
|
$bi->save();
|
|
|
|
|
|
|
|
$bt = BankTransactionFactory::create($this->company->id, $this->user->id);
|
|
|
|
$bt->bank_integration_id = $bi->id;
|
|
|
|
$bt->status_id = BankTransaction::STATUS_UNMATCHED;
|
|
|
|
$bt->description = 'Fuel';
|
|
|
|
$bt->amount = 10;
|
|
|
|
$bt->currency_code = $this->client->currency()->code;
|
|
|
|
$bt->date = now()->format('Y-m-d');
|
|
|
|
$bt->transaction_id = 1234567890;
|
|
|
|
$bt->category_id = 10000003;
|
|
|
|
$bt->base_type = 'CREDIT';
|
|
|
|
$bt->save();
|
|
|
|
|
|
|
|
$data = [];
|
|
|
|
|
|
|
|
$data['transactions'][] = [
|
|
|
|
'id' => $bt->hashed_id,
|
|
|
|
'payment_id' => $this->payment->hashed_id
|
|
|
|
];
|
|
|
|
|
|
|
|
$response = $this->withHeaders([
|
|
|
|
'X-API-SECRET' => config('ninja.api_secret'),
|
|
|
|
'X-API-TOKEN' => $this->token,
|
|
|
|
])->postJson('/api/v1/bank_transactions/match', $data);
|
|
|
|
|
|
|
|
$response->assertStatus(200);
|
|
|
|
|
|
|
|
$this->assertEquals($this->payment->refresh()->transaction_id, $bt->id);
|
|
|
|
$this->assertEquals($bt->refresh()->payment_id, $this->payment->id);
|
|
|
|
$this->assertEquals(BankTransaction::STATUS_CONVERTED, $bt->status_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-09-15 06:15:02 +02:00
|
|
|
public function testMatchBankTransactionsValidationShouldFail()
|
|
|
|
{
|
2022-10-26 05:03:49 +02:00
|
|
|
$data = [];
|
|
|
|
|
|
|
|
$data['transactions'][] = [
|
2022-09-22 08:20:54 +02:00
|
|
|
'bad_key' => 10,
|
2022-09-15 06:15:02 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
$response = $this->withHeaders([
|
|
|
|
'X-API-SECRET' => config('ninja.api_secret'),
|
|
|
|
'X-API-TOKEN' => $this->token,
|
|
|
|
])->postJson('/api/v1/bank_transactions/match', $data);
|
|
|
|
|
|
|
|
$response->assertStatus(422);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testMatchBankTransactionValidationShouldPass()
|
|
|
|
{
|
2023-02-16 02:36:09 +01:00
|
|
|
if (config('ninja.testvars.travis') !== false) {
|
|
|
|
$this->markTestSkipped('Skip test for Github Actions');
|
|
|
|
}
|
2022-10-27 04:46:06 +02:00
|
|
|
|
2022-10-26 05:03:49 +02:00
|
|
|
$data = [];
|
|
|
|
|
2022-10-27 03:10:11 +02:00
|
|
|
$bi = BankIntegrationFactory::create($this->company->id, $this->user->id, $this->account->id);
|
|
|
|
$bi->save();
|
|
|
|
|
|
|
|
$bt = BankTransactionFactory::create($this->company->id, $this->user->id);
|
|
|
|
$bt->bank_integration_id = $bi->id;
|
|
|
|
$bt->description = 'Fuel';
|
|
|
|
$bt->amount = 10;
|
|
|
|
$bt->currency_code = $this->client->currency()->code;
|
|
|
|
$bt->date = now()->format('Y-m-d');
|
|
|
|
$bt->transaction_id = 1234567890;
|
|
|
|
$bt->category_id = 10000003;
|
|
|
|
$bt->base_type = 'DEBIT';
|
|
|
|
$bt->save();
|
|
|
|
|
|
|
|
$data = [];
|
|
|
|
|
2022-10-26 05:03:49 +02:00
|
|
|
$data['transactions'][] = [
|
2022-10-27 03:10:11 +02:00
|
|
|
'id' => $bt->hashed_id,
|
2022-09-15 06:15:02 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
$response = $this->withHeaders([
|
|
|
|
'X-API-SECRET' => config('ninja.api_secret'),
|
|
|
|
'X-API-TOKEN' => $this->token,
|
|
|
|
])->postJson('/api/v1/bank_transactions/match', $data);
|
|
|
|
|
|
|
|
$response->assertStatus(200);
|
|
|
|
}
|
2023-02-16 02:36:09 +01:00
|
|
|
}
|