. */ declare(strict_types=1); namespace Tests\Feature\Controllers\Json; use FireflyIII\Helpers\Collector\JournalCollectorInterface; 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 Illuminate\Support\Collection; use Log; use Tests\TestCase; /** * Class AutoCompleteControllerTest */ class AutoCompleteControllerTest extends TestCase { /** * */ public function setUp() { parent::setUp(); Log::debug(sprintf('Now in %s.', get_class($this))); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::allAccounts */ public function testAllAccounts() { // mock stuff $accountA = factory(Account::class)->make(); $collection = new Collection([$accountA]); $accountRepos = $this->mock(AccountRepositoryInterface::class); $accountRepos->shouldReceive('getAccountsByType') ->withArgs([[AccountType::REVENUE, AccountType::EXPENSE, AccountType::BENEFICIARY, AccountType::DEFAULT, AccountType::ASSET]]) ->andReturn($collection); $this->be($this->user()); $response = $this->get(route('json.all-accounts')); $response->assertStatus(200); $response->assertExactJson([$accountA->name]); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::allTransactionJournals */ public function testAllTransactionJournals() { $collector = $this->mock(JournalCollectorInterface::class); $collector->shouldReceive('setLimit')->withArgs([250])->andReturnSelf(); $collector->shouldReceive('setPage')->withArgs([1])->andReturnSelf(); $collector->shouldReceive('getJournals')->andReturn(new Collection); $this->be($this->user()); $response = $this->get(route('json.all-transaction-journals')); $response->assertStatus(200); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::budgets */ public function testBudgets() { // mock stuff $budget = factory(Budget::class)->make(); $categoryRepos = $this->mock(BudgetRepositoryInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $categoryRepos->shouldReceive('getBudgets')->andReturn(new Collection([$budget])); $this->be($this->user()); $response = $this->get(route('json.budgets')); $response->assertStatus(200); $response->assertExactJson([$budget->name]); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::categories */ public function testCategories() { // mock stuff $category = factory(Category::class)->make(); $categoryRepos = $this->mock(CategoryRepositoryInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $categoryRepos->shouldReceive('getCategories')->andReturn(new Collection([$category])); $this->be($this->user()); $response = $this->get(route('json.categories')); $response->assertStatus(200); $response->assertExactJson([$category->name]); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::expenseAccounts */ public function testExpenseAccounts() { // mock stuff $accountA = factory(Account::class)->make(); $accountB = factory(Account::class)->make(); $accountA->active = true; $accountB->active = false; $collection = new Collection([$accountA, $accountB]); $accountRepos = $this->mock(AccountRepositoryInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $accountRepos->shouldReceive('getAccountsByType')->withArgs([[AccountType::EXPENSE, AccountType::BENEFICIARY]])->once()->andReturn($collection); $this->be($this->user()); $response = $this->get(route('json.expense-accounts')); $response->assertStatus(200); $response->assertExactJson([$accountA->name]); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::journalsWithId */ public function testJournalsWithId() { $journal = $this->user()->transactionJournals()->where('id', '!=', 1)->first(); $journal->journal_id = $journal->id; $collection = new Collection([$journal]); $collector = $this->mock(JournalCollectorInterface::class); $collector->shouldReceive('setLimit')->withArgs([400])->andReturnSelf(); $collector->shouldReceive('setPage')->withArgs([1])->andReturnSelf(); $collector->shouldReceive('getJournals')->andReturn($collection); $this->be($this->user()); $response = $this->get(route('json.journals-with-id', [1])); $response->assertStatus(200); $response->assertExactJson([['id' => $journal->id, 'name' => $journal->id . ': ' . $journal->description]]); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::revenueAccounts */ public function testRevenueAccounts() { // mock stuff $accountA = factory(Account::class)->make(); $accountB = factory(Account::class)->make(); $accountA->active = true; $accountB->active = false; $collection = new Collection([$accountA, $accountB]); $accountRepos = $this->mock(AccountRepositoryInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $accountRepos->shouldReceive('getAccountsByType')->withArgs([[AccountType::REVENUE]])->once()->andReturn($collection); $this->be($this->user()); $response = $this->get(route('json.revenue-accounts')); $response->assertStatus(200); $response->assertExactJson([$accountA->name]); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::tags */ public function testTags() { // mock stuff $tag = factory(Tag::class)->make(); $tagRepos = $this->mock(TagRepositoryInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $tagRepos->shouldReceive('get')->andReturn(new Collection([$tag]))->once(); $this->be($this->user()); $response = $this->get(route('json.tags')); $response->assertStatus(200); $response->assertExactJson([$tag->tag]); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::transactionJournals */ public function testTransactionJournals() { // mock stuff $collector = $this->mock(JournalCollectorInterface::class); $journalRepos = $this->mock(JournalRepositoryInterface::class); $journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $collector->shouldReceive('setTypes')->andReturnSelf(); $collector->shouldReceive('setLimit')->andReturnSelf(); $collector->shouldReceive('setPage')->andReturnSelf(); $collector->shouldReceive('getJournals')->andReturn(new Collection); $this->be($this->user()); $response = $this->get(route('json.transaction-journals', ['deposit'])); $response->assertStatus(200); $response->assertExactJson([]); } /** * @covers \FireflyIII\Http\Controllers\Json\AutoCompleteController::transactionTypes */ public function testTransactionTypes(): void { // mock stuff $journalRepos = $this->mock(JournalRepositoryInterface::class); $journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $journalRepos->shouldReceive('getTransactionTypes')->once()->andReturn(new Collection); $this->be($this->user()); $response = $this->get(route('json.transaction-types', ['deposit'])); $response->assertStatus(200); $response->assertExactJson([]); } }