. */ declare(strict_types=1); namespace Tests\Feature\Controllers\Transaction; use FireflyIII\Helpers\Attachments\AttachmentHelperInterface; use FireflyIII\Helpers\Collector\TransactionCollectorInterface; use FireflyIII\Models\TransactionJournal; use FireflyIII\Repositories\Account\AccountRepositoryInterface; use FireflyIII\Repositories\Bill\BillRepositoryInterface; use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; use FireflyIII\Repositories\Currency\CurrencyRepositoryInterface; use FireflyIII\Repositories\Journal\JournalRepositoryInterface; use FireflyIII\Repositories\RuleGroup\RuleGroupRepositoryInterface; use FireflyIII\Repositories\User\UserRepositoryInterface; use FireflyIII\Transformers\TransactionTransformer; use Illuminate\Support\Collection; use Illuminate\Support\MessageBag; use Log; use Mockery; use Tests\TestCase; /** * Class SplitControllerTest * * @SuppressWarnings(PHPMD.TooManyPublicMethods) * @SuppressWarnings(PHPMD.ExcessiveMethodLength) * @SuppressWarnings(PHPMD.CouplingBetweenObjects) */ class SplitControllerTest extends TestCase { /** * */ public function setUp(): void { parent::setUp(); Log::info(sprintf('Now in %s.', get_class($this))); } /** * @covers \FireflyIII\Http\Controllers\Transaction\SplitController */ public function testEdit(): void { $this->markTestIncomplete('Needs to be rewritten for v4.8.0'); return; $currencyRepository = $this->mock(CurrencyRepositoryInterface::class); $accountRepos = $this->mock(AccountRepositoryInterface::class); $budgetRepository = $this->mock(BudgetRepositoryInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $attHelper = $this->mock(AttachmentHelperInterface::class); $transformer = $this->mock(TransactionTransformer::class); $collector = $this->mock(TransactionCollectorInterface::class); $deposit = $this->getRandomDeposit(); $destination = $deposit->transactions()->where('amount', '>', 0)->first(); $account = $destination->account; // mock calls $journalRepos->shouldReceive('firstNull')->once()->andReturn($deposit); $currencyRepository->shouldReceive('get')->once()->andReturn(new Collection); $budgetRepository->shouldReceive('getActiveBudgets')->andReturn(new Collection)->atLeast()->once(); $transformer->shouldReceive('setParameters')->atLeast()->once(); $collector->shouldReceive('setUser')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('withOpposingAccount')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('withCategoryInformation')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('withBudgetInformation')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('setJournals')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('getTransactions')->atLeast()->once()->andReturn(new Collection); $userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->atLeast()->once()->andReturn(true); $journalRepos->shouldReceive('getJournalSourceAccounts')->andReturn(new Collection([$account]))->atLeast()->once(); $journalRepos->shouldReceive('getJournalDestinationAccounts')->andReturn(new Collection([$account]))->atLeast()->once(); $journalRepos->shouldReceive('getTransactionType')->once()->andReturn('Deposit'); $journalRepos->shouldReceive('getJournalDate')->andReturn('2018-01-01')->once(); $journalRepos->shouldReceive('getMetaField')->andReturn('')->atLeast()->once(); $journalRepos->shouldReceive('getNoteText')->andReturn('Some note')->atLeast()->once(); $this->be($this->user()); $response = $this->get(route('transactions.split.edit', [$deposit->id])); $response->assertStatus(200); // has bread crumb $response->assertSee('