mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 13:36:15 +00:00 
			
		
		
		
	Covered the JSON controller.
This commit is contained in:
		
							
								
								
									
										206
									
								
								tests/controllers/JsonControllerTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										206
									
								
								tests/controllers/JsonControllerTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,206 @@ | ||||
| <?php | ||||
|  | ||||
| use Carbon\Carbon; | ||||
| use Illuminate\Support\Collection; | ||||
| use League\FactoryMuffin\Facade as FactoryMuffin; | ||||
|  | ||||
| /** | ||||
|  * Class JsonControllerTest | ||||
|  */ | ||||
| class JsonControllerTest extends TestCase | ||||
| { | ||||
|     /** | ||||
|      * Sets up the fixture, for example, opens a network connection. | ||||
|      * This method is called before a test is executed. | ||||
|      */ | ||||
|     public function setUp() | ||||
|     { | ||||
|         parent::setUp(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * This method is called before the first test of this test class is run. | ||||
|      * | ||||
|      * @since Method available since Release 3.4.0 | ||||
|      */ | ||||
|     public static function setUpBeforeClass() | ||||
|     { | ||||
|         parent::setUpBeforeClass(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Tears down the fixture, for example, closes a network connection. | ||||
|      * This method is called after a test is executed. | ||||
|      */ | ||||
|     public function tearDown() | ||||
|     { | ||||
|         parent::tearDown(); | ||||
|  | ||||
|     } | ||||
|  | ||||
|     public function testBoxBillsPaid() | ||||
|     { | ||||
|         $bill       = FactoryMuffin::create('FireflyIII\Models\Bill'); | ||||
|         $cc         = FactoryMuffin::create('FireflyIII\Models\Account'); | ||||
|         $ccs        = new Collection([$cc]); | ||||
|         $collection = new Collection([$bill]); | ||||
|         $ranges     = [['start' => new Carbon, 'end' => new Carbon]]; | ||||
|         $this->be($bill->user); | ||||
|  | ||||
|         $bills    = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface'); | ||||
|         $accounts = $this->mock('FireflyIII\Repositories\Account\AccountRepositoryInterface'); | ||||
|  | ||||
|         // mock! | ||||
|         $bills->shouldReceive('getActiveBills')->andReturn($collection); | ||||
|         $bills->shouldReceive('getRanges')->andReturn($ranges); | ||||
|         $bills->shouldReceive('getJournalsInRange')->andReturn(new Collection); | ||||
|         $accounts->shouldReceive('getCreditCards')->andReturn($ccs); | ||||
|         $accounts->shouldReceive('getTransfersInRange')->andReturn(new Collection); | ||||
|         Amount::shouldReceive('format')->andReturn('xx'); | ||||
|         Steam::shouldReceive('balance')->andReturn(0); | ||||
|  | ||||
|  | ||||
|         $this->call('GET', '/json/box/bills-paid'); | ||||
|         $this->assertResponseOk(); | ||||
|  | ||||
|     } | ||||
|  | ||||
|     public function testBoxBillsUnpaid() | ||||
|     { | ||||
|         $bill       = FactoryMuffin::create('FireflyIII\Models\Bill'); | ||||
|         $cc         = FactoryMuffin::create('FireflyIII\Models\Account'); | ||||
|         $ccs        = new Collection([$cc]); | ||||
|         $collection = new Collection([$bill]); | ||||
|         $ranges     = [['start' => new Carbon, 'end' => new Carbon]]; | ||||
|         $this->be($bill->user); | ||||
|  | ||||
|         $bills    = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface'); | ||||
|         $accounts = $this->mock('FireflyIII\Repositories\Account\AccountRepositoryInterface'); | ||||
|  | ||||
|         // mock! | ||||
|         $bills->shouldReceive('getActiveBills')->andReturn($collection); | ||||
|         $bills->shouldReceive('getRanges')->andReturn($ranges); | ||||
|         $bills->shouldReceive('getJournalsInRange')->andReturn(new Collection); | ||||
|         $bills->shouldReceive('createFakeBill')->andReturn($bill); | ||||
|         $accounts->shouldReceive('getCreditCards')->andReturn($ccs); | ||||
|         Amount::shouldReceive('format')->andReturn('xx'); | ||||
|         Steam::shouldReceive('balance')->andReturn(-1); | ||||
|  | ||||
|         $this->call('GET', '/json/box/bills-unpaid'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
|     public function testBoxIn() | ||||
|     { | ||||
|         $user = FactoryMuffin::create('FireflyIII\User'); | ||||
|         $this->be($user); | ||||
|  | ||||
|         $repository = $this->mock('FireflyIII\Helpers\Report\ReportQueryInterface'); | ||||
|         $repository->shouldReceive('incomeByPeriod')->andReturn(new Collection); | ||||
|         Amount::shouldReceive('format')->andReturn('xx'); | ||||
|  | ||||
|         $this->call('GET', '/json/box/in'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
|     public function testBoxOut() | ||||
|     { | ||||
|         $user = FactoryMuffin::create('FireflyIII\User'); | ||||
|         $this->be($user); | ||||
|  | ||||
|         $repository = $this->mock('FireflyIII\Helpers\Report\ReportQueryInterface'); | ||||
|         $repository->shouldReceive('journalsByExpenseAccount')->andReturn(new Collection); | ||||
|         Amount::shouldReceive('format')->andReturn('xx'); | ||||
|  | ||||
|         $this->call('GET', '/json/box/out'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
|     public function testCategories() | ||||
|     { | ||||
|         $category = FactoryMuffin::create('FireflyIII\Models\Category'); | ||||
|         $this->be($category->user); | ||||
|         $categories = new Collection([$category]); | ||||
|  | ||||
|         $repository = $this->mock('FireflyIII\Repositories\Category\CategoryRepositoryInterface'); | ||||
|         $repository->shouldReceive('getCategories')->andReturn($categories); | ||||
|  | ||||
|         $this->call('GET', '/json/categories'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
|     public function testExpenseAccounts() | ||||
|     { | ||||
|         $account = FactoryMuffin::create('FireflyIII\Models\Account'); | ||||
|         $this->be($account->user); | ||||
|         $accounts = new Collection([$account]); | ||||
|  | ||||
|         $repository = $this->mock('FireflyIII\Repositories\Account\AccountRepositoryInterface'); | ||||
|         $repository->shouldReceive('getAccounts')->with(['Expense account', 'Beneficiary account'])->andReturn($accounts); | ||||
|  | ||||
|         $this->call('GET', '/json/expense-accounts'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
|     public function testRevenueAccounts() | ||||
|     { | ||||
|         $account = FactoryMuffin::create('FireflyIII\Models\Account'); | ||||
|         $this->be($account->user); | ||||
|         $accounts = new Collection([$account]); | ||||
|  | ||||
|         $repository = $this->mock('FireflyIII\Repositories\Account\AccountRepositoryInterface'); | ||||
|         $repository->shouldReceive('getAccounts')->with(['Revenue account'])->andReturn($accounts); | ||||
|  | ||||
|         $this->call('GET', '/json/revenue-accounts'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
|     public function testSetSharedReports() | ||||
|     { | ||||
|         $pref       = FactoryMuffin::create('FireflyIII\Models\Preference'); | ||||
|         $pref->data = false; | ||||
|         $pref->save(); | ||||
|         $user = FactoryMuffin::create('FireflyIII\User'); | ||||
|         $this->be($user); | ||||
|  | ||||
|         Preferences::shouldReceive('get')->withArgs(['showSharedReports', false])->andReturn($pref); | ||||
|         Preferences::shouldReceive('set')->withArgs(['showSharedReports', true]); | ||||
|  | ||||
|         $this->call('GET', '/json/show-shared-reports/set'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     public function testShowSharedReports() | ||||
|     { | ||||
|         $pref       = FactoryMuffin::create('FireflyIII\Models\Preference'); | ||||
|         $pref->data = false; | ||||
|         $pref->save(); | ||||
|         $user = FactoryMuffin::create('FireflyIII\User'); | ||||
|         $this->be($user); | ||||
|  | ||||
|         Preferences::shouldReceive('get')->withArgs(['showSharedReports', false])->andReturn($pref); | ||||
|  | ||||
|  | ||||
|         $this->call('GET', '/json/show-shared-reports'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
|     public function testTransactionJournals() | ||||
|     { | ||||
|         $journal    = FactoryMuffin::create('FireflyIII\Models\TransactionJournal'); | ||||
|         $type = FactoryMuffin::create('FireflyIII\Models\TransactionType'); | ||||
|         $collection = new Collection([$journal]); | ||||
|         $user       = FactoryMuffin::create('FireflyIII\User'); | ||||
|         $this->be($user); | ||||
|  | ||||
|         $repository = $this->mock('FireflyIII\Repositories\Journal\JournalRepositoryInterface'); | ||||
|         $repository->shouldReceive('getTransactionType')->with('withdrawal')->andReturn($type); | ||||
|         $repository->shouldReceive('getJournalsOfType')->with($type)->andReturn($collection); | ||||
|  | ||||
|  | ||||
|         $this->call('GET', '/json/transaction-journals/withdrawal'); | ||||
|         $this->assertResponseOk(); | ||||
|     } | ||||
|  | ||||
| } | ||||
		Reference in New Issue
	
	Block a user