invoiceninja/tests/Unit/RecurringExpenseCloneTest.php
Shift 19080933b6
Apply Laravel coding style
Shift automatically applies the Laravel coding style - which uses the PSR-2 coding style as a base with some minor additions.

You may customize the code style applied by adding a [PHP CS Fixer][1] or [PHP CodeSniffer][2] ruleset to your project root. Feel free to use [Shift's Laravel ruleset][3] to help you get started.

For more information on customizing the code style applied by Shift, [watch this short video][4].

[1]: https://github.com/FriendsOfPHP/PHP-CS-Fixer
[2]: https://github.com/squizlabs/PHP_CodeSniffer
[3]: https://gist.github.com/laravel-shift/cab527923ed2a109dda047b97d53c200
[4]: https://laravelshift.com/videos/shift-code-style
2022-06-21 09:57:17 +00:00

68 lines
1.9 KiB
PHP

<?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\Unit;
use App\Factory\RecurringExpenseFactory;
use App\Factory\RecurringExpenseToExpenseFactory;
use App\Models\Account;
use App\Models\Client;
use App\Models\Company;
use App\Models\RecurringExpense;
use App\Models\User;
use App\Utils\Ninja;
use Tests\TestCase;
/**
* @test
*/
class RecurringExpenseCloneTest extends TestCase
{
public $faker;
public function setUp() :void
{
parent::setUp();
$this->faker = \Faker\Factory::create();
}
public function testBadBase64String()
{
$account = Account::factory()->create();
$user = User::factory()->create(['account_id' => $account->id, 'email' => $this->faker->unique()->safeEmail]);
$company = Company::factory()->create(['account_id' => $account->id]);
$client = Client::factory()->create([
'user_id' => $user->id,
'company_id' => $company->id,
]);
$recurring_expense = RecurringExpenseFactory::create($company->id, $user->id);
$recurring_expense->date = now();
$recurring_expense->amount = 10;
$recurring_expense->foreign_amount = 20;
$recurring_expense->exchange_rate = 0.5;
$recurring_expense->private_notes = 'private';
$recurring_expense->public_notes = 'public';
$recurring_expense->custom_value4 = 'custom4';
$recurring_expense->should_be_invoiced = true;
$recurring_expense->save();
$expense = RecurringExpenseToExpenseFactory::create($recurring_expense);
$expense->save();
$this->assertNotNull($expense);
$this->assertEquals(20, $expense->foreign_amount);
$this->assertEquals(10, $expense->amount);
}
}