. */ declare(strict_types=1); namespace Tests\Feature\Controllers\Transaction; use Amount; use FireflyIII\Helpers\Collector\GroupCollectorInterface; use FireflyIII\Models\TransactionJournal; use FireflyIII\Models\TransactionType; use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; use FireflyIII\Repositories\User\UserRepositoryInterface; use Illuminate\Support\Collection; use Log; use Mockery; use Preferences; use Tests\TestCase; /** * Class BulkControllerTest * * @SuppressWarnings(PHPMD.TooManyPublicMethods) * @SuppressWarnings(PHPMD.ExcessiveMethodLength) * @SuppressWarnings(PHPMD.CouplingBetweenObjects) */ class BulkControllerTest extends TestCase { /** * */ public function setUp(): void { parent::setUp(); Log::info(sprintf('Now in %s.', get_class($this))); } /** * @covers \FireflyIII\Http\Controllers\Transaction\BulkController * @covers \FireflyIII\Http\Controllers\Transaction\BulkController */ public function testEditWithdrawal(): void { // mock stuff: $journalRepos = $this->mockDefaultSession(); $budgetRepos = $this->mock(BudgetRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $collector = $this->mock(GroupCollectorInterface::class); $withdrawal = $this->getRandomWithdrawal(); $withdrawalArray = $this->getRandomWithdrawalAsArray(); Amount::shouldReceive('formatAnything')->atLeast()->once()->andReturn('-100'); $collector->shouldReceive('setTypes') ->withArgs([[TransactionType::WITHDRAWAL, TransactionType::DEPOSIT, TransactionType::TRANSFER]])->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('withCategoryInformation')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('withBudgetInformation')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('withTagInformation')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('setJournalIds')->atLeast()->once()->withArgs([[$withdrawal->id]])->andReturnSelf(); $collector->shouldReceive('getExtractedJournals')->atLeast()->once()->andReturn([$withdrawalArray]); $userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->atLeast()->once()->andReturn(true); $budgetRepos->shouldReceive('getActiveBudgets')->andReturn(new Collection); $journalRepos->shouldReceive('getJournalSourceAccounts')->andReturn(new Collection); $journalRepos->shouldReceive('getJournalDestinationAccounts')->andReturn(new Collection); $journalRepos->shouldReceive('getTransactionType')->andReturn('Transfer'); $journalRepos->shouldReceive('isJournalReconciled')->andReturn(false); $this->be($this->user()); $response = $this->get(route('transactions.bulk.edit', [$withdrawal->id])); $response->assertStatus(200); $response->assertSee('Bulk edit a number of transactions'); // has bread crumb $response->assertSee('