. */ declare(strict_types=1); namespace Tests\Feature\Controllers; use Carbon\Carbon; use FireflyIII\Generator\Report\Account\YearReportGenerator as AcYRG; use FireflyIII\Generator\Report\Audit\YearReportGenerator as AYRG; use FireflyIII\Generator\Report\Budget\YearReportGenerator as BYRG; use FireflyIII\Generator\Report\Category\YearReportGenerator as CYRG; use FireflyIII\Generator\Report\Standard\YearReportGenerator as SYRG; use FireflyIII\Generator\Report\Tag\YearReportGenerator as TYRG; use FireflyIII\Helpers\Fiscal\FiscalHelperInterface; use FireflyIII\Helpers\Report\ReportHelperInterface; use FireflyIII\Models\Account; use FireflyIII\Models\AccountType; use FireflyIII\Models\Budget; use FireflyIII\Models\Category; use FireflyIII\Models\Tag; use FireflyIII\Models\TransactionJournal; use FireflyIII\Repositories\Account\AccountRepositoryInterface; use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; use FireflyIII\Repositories\Category\CategoryRepositoryInterface; use FireflyIII\Repositories\Journal\JournalRepositoryInterface; use FireflyIII\Repositories\Tag\TagRepositoryInterface; use FireflyIII\Repositories\User\UserRepositoryInterface; use Illuminate\Support\Collection; use Log; use Mockery; use Tests\TestCase; /** * Class ReportControllerTest * * @SuppressWarnings(PHPMD.TooManyPublicMethods) * @SuppressWarnings(PHPMD.ExcessiveMethodLength) * @SuppressWarnings(PHPMD.CouplingBetweenObjects) */ class ReportControllerTest extends TestCase { /** * */ public function setUp(): void { parent::setUp(); Log::info(sprintf('Now in %s.', get_class($this))); } /** * @covers \FireflyIII\Http\Controllers\ReportController */ public function testAccountReport(): void { $budgetRepository = $this->mock(BudgetRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $fiscalHelper = $this->mock(FiscalHelperInterface::class); $generator = $this->mock(AcYRG::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $reportHelper = $this->mock(ReportHelperInterface::class); $budgetRepository->shouldReceive('cleanupBudgets'); $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); $start = Carbon::now()->startOfYear(); $end = Carbon::now()->endOfYear(); $fiscalHelper->shouldReceive('startOfFiscalYear')->atLeast()->once()->andReturn($start); $fiscalHelper->shouldReceive('endOfFiscalYear')->atLeast()->once()->andReturn($end); $generator->shouldReceive('setStartDate')->once(); $generator->shouldReceive('setEndDate')->once(); $generator->shouldReceive('setAccounts')->once(); $generator->shouldReceive('setExpense')->once(); $generator->shouldReceive('generate')->once()->andReturn('here-be-report'); $this->be($this->user()); $response = $this->get(route('reports.report.account', [1, 2, '20160101', '20161231'])); $response->assertStatus(200); } /** * @covers \FireflyIII\Http\Controllers\ReportController */ public function testAuditReport(): void { $budgetRepository = $this->mock(BudgetRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $fiscalHelper = $this->mock(FiscalHelperInterface::class); $generator = $this->mock(AYRG::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $reportHelper = $this->mock(ReportHelperInterface::class); $budgetRepository->shouldReceive('cleanupBudgets'); $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); $start = Carbon::now()->startOfYear(); $end = Carbon::now()->endOfYear(); $fiscalHelper->shouldReceive('startOfFiscalYear')->atLeast()->once()->andReturn($start); $fiscalHelper->shouldReceive('endOfFiscalYear')->atLeast()->once()->andReturn($end); $generator->shouldReceive('setStartDate')->once(); $generator->shouldReceive('setEndDate')->once(); $generator->shouldReceive('setAccounts')->once(); $generator->shouldReceive('generate')->once()->andReturn('here-be-report'); $this->be($this->user()); $response = $this->get(route('reports.report.audit', [1, '20160101', '20161231'])); $response->assertStatus(200); } /** * @covers \FireflyIII\Http\Controllers\ReportController */ public function testBudgetReport(): void { $budgetRepository = $this->mock(BudgetRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $fiscalHelper = $this->mock(FiscalHelperInterface::class); $generator = $this->mock(BYRG::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $reportHelper = $this->mock(ReportHelperInterface::class); $start = Carbon::now()->startOfYear(); $end = Carbon::now()->endOfYear(); $fiscalHelper->shouldReceive('startOfFiscalYear')->atLeast()->once()->andReturn($start); $fiscalHelper->shouldReceive('endOfFiscalYear')->atLeast()->once()->andReturn($end); $budgetRepository->shouldReceive('cleanupBudgets'); $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); $generator->shouldReceive('setStartDate')->once(); $generator->shouldReceive('setEndDate')->once(); $generator->shouldReceive('setAccounts')->once(); $generator->shouldReceive('setBudgets')->once(); $generator->shouldReceive('generate')->once()->andReturn('here-be-report'); $this->be($this->user()); $response = $this->get(route('reports.report.budget', [1, 1, '20160101', '20161231'])); $response->assertStatus(200); } /** * @covers \FireflyIII\Http\Controllers\ReportController */ public function testCategoryReport(): void { $budgetRepository = $this->mock(BudgetRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $fiscalHelper = $this->mock(FiscalHelperInterface::class); $generator = $this->mock(CYRG::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $reportHelper = $this->mock(ReportHelperInterface::class); $start = Carbon::now()->startOfYear(); $end = Carbon::now()->endOfYear(); $budgetRepository->shouldReceive('cleanupBudgets'); $fiscalHelper->shouldReceive('startOfFiscalYear')->atLeast()->once()->andReturn($start); $fiscalHelper->shouldReceive('endOfFiscalYear')->atLeast()->once()->andReturn($end); $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); $generator->shouldReceive('setStartDate')->once(); $generator->shouldReceive('setEndDate')->once(); $generator->shouldReceive('setAccounts')->once(); $generator->shouldReceive('setCategories')->once(); $generator->shouldReceive('generate')->once()->andReturn('here-be-report'); $this->be($this->user()); $response = $this->get(route('reports.report.category', [1, 1, '20160101', '20161231'])); $response->assertStatus(200); } /** * @covers \FireflyIII\Http\Controllers\ReportController */ public function testDefaultReport(): void { $budgetRepository = $this->mock(BudgetRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $fiscalHelper = $this->mock(FiscalHelperInterface::class); $generator = $this->mock(SYRG::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $reportHelper = $this->mock(ReportHelperInterface::class); $start = Carbon::now()->startOfYear(); $end = Carbon::now()->endOfYear(); $fiscalHelper->shouldReceive('startOfFiscalYear')->atLeast()->once()->andReturn($start); $fiscalHelper->shouldReceive('endOfFiscalYear')->atLeast()->once()->andReturn($end); $budgetRepository->shouldReceive('cleanupBudgets'); $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); $generator->shouldReceive('setStartDate')->once(); $generator->shouldReceive('setEndDate')->once(); $generator->shouldReceive('setAccounts')->once(); $generator->shouldReceive('generate')->once()->andReturn('here-be-report'); $this->be($this->user()); $response = $this->get(route('reports.report.default', [1, '20160101', '20161231'])); $response->assertStatus(200); } /** * @covers \FireflyIII\Http\Controllers\ReportController */ public function testDefaultReportBadDate(): void { $budgetRepository = $this->mock(BudgetRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $fiscalHelper = $this->mock(FiscalHelperInterface::class); $reportHelper = $this->mock(ReportHelperInterface::class); $start = Carbon::now()->startOfYear(); $end = Carbon::now()->endOfYear(); $fiscalHelper->shouldReceive('startOfFiscalYear')->atLeast()->once()->andReturn($start); $fiscalHelper->shouldReceive('endOfFiscalYear')->atLeast()->once()->andReturn($end); $budgetRepository->shouldReceive('cleanupBudgets'); $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); $this->be($this->user()); $response = $this->get(route('reports.report.default', [1, '20160101', '20150131'])); $response->assertStatus(200); $response->assertSee('End date of report must be after start date.'); } /** * @covers \FireflyIII\Http\Controllers\ReportController */ public function testIndex(): void { $budgetRepository = $this->mock(BudgetRepositoryInterface::class); $userRepos = $this->mock(UserRepositoryInterface::class); $fiscalHelper = $this->mock(FiscalHelperInterface::class); $helper = $this->mock(ReportHelperInterface::class); $accountRepos = $this->mock(AccountRepositoryInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $budgetRepository->shouldReceive('cleanupBudgets'); $userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->atLeast()->once()->andReturn(true); $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); $helper->shouldReceive('listOfMonths')->andReturn([]); $accountRepos->shouldReceive('getAccountsByType')->withArgs([[AccountType::DEFAULT, AccountType::ASSET]])->andReturn(new Collection)->once(); $this->be($this->user()); $response = $this->get(route('reports.index')); $response->assertStatus(200); $response->assertSee('