. */ declare(strict_types=1); namespace Tests\Feature\Controllers\Account; use Amount; use FireflyIII\Models\AccountType; use FireflyIII\Models\TransactionJournal; use FireflyIII\Repositories\Account\AccountRepositoryInterface; use FireflyIII\Repositories\Journal\JournalRepositoryInterface; use FireflyIII\Repositories\User\UserRepositoryInterface; use Illuminate\Support\Collection; use Log; use Mockery; use Tests\TestCase; use Preferences; /** * * Class DeleteControllerTest * * @SuppressWarnings(PHPMD.ExcessiveMethodLength) * @SuppressWarnings(PHPMD.CouplingBetweenObjects) */ class DeleteControllerTest extends TestCase { /** * */ public function setUp(): void { parent::setUp(); Log::info(sprintf('Now in %s.', get_class($this))); } /** * @covers \FireflyIII\Http\Controllers\Account\DeleteController * @covers \FireflyIII\Http\Controllers\Controller */ public function testDelete(): void { // mock stuff $journalRepos = $this->mock(JournalRepositoryInterface::class); $repository = $this->mock(AccountRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $asset = $this->getRandomAsset(); $repository->shouldReceive('getAccountsByType')->withArgs([[AccountType::ASSET]])->andReturn(new Collection); $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); // mock hasRole for user repository: $userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->andReturn(true)->atLeast()->once(); // mock Amount $euro = $this->getEuro(); Amount::shouldReceive('getDefaultCurrency')->atLeast()->once()->andReturn($euro); // mock calls to Preferences: $this->mockDefaultPreferences(); // mock calls to Configuration: $this->mockDefaultConfiguration(); $this->be($this->user()); $response = $this->get(route('accounts.delete', [$asset->id])); $response->assertStatus(200); // has bread crumb $response->assertSee('