. */ declare(strict_types=1); namespace Tests\Feature\Controllers\Transaction; use Amount; use FireflyIII\Events\UpdatedTransactionGroup; use FireflyIII\Helpers\Collector\GroupCollectorInterface; use FireflyIII\Models\TransactionType; use FireflyIII\Repositories\Account\AccountRepositoryInterface; use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; use FireflyIII\Repositories\User\UserRepositoryInterface; use FireflyIII\Services\Internal\Update\JournalUpdateService; use Illuminate\Support\Collection; use Log; use Mockery; use Preferences; use Tests\TestCase; /** * Class MassControllerTest * * @SuppressWarnings(PHPMD.TooManyPublicMethods) * @SuppressWarnings(PHPMD.ExcessiveMethodLength) * @SuppressWarnings(PHPMD.CouplingBetweenObjects) */ class MassControllerTest extends TestCase { /** * */ public function setUp(): void { parent::setUp(); Log::info(sprintf('Now in %s.', get_class($this))); } /** * @covers \FireflyIII\Http\Controllers\Transaction\MassController */ public function testDelete(): void { $this->mockDefaultSession(); $withdrawal = $this->getRandomWithdrawal(); $withdrawalArray = $this->getRandomWithdrawalAsArray(); $userRepos = $this->mock(UserRepositoryInterface::class); $userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->atLeast()->once()->andReturn(true); $collector = $this->mock(GroupCollectorInterface::class); $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('withAccountInformation')->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('setJournalIds')->withArgs([[$withdrawal->id]])->atLeast()->once()->andReturnSelf(); $collector->shouldReceive('getExtractedJournals')->atLeast()->once()->andReturn([$withdrawalArray]); Amount::shouldReceive('formatAnything')->atLeast()->once()->andReturn('x'); $this->be($this->user()); $response = $this->get(route('transactions.mass.delete', [$withdrawal->id])); $response->assertStatus(200); $response->assertSee('Delete a number of transactions'); // has bread crumb $response->assertSee('