| 
									
										
										
										
											2017-02-12 12:00:11 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * RuleControllerTest.php | 
					
						
							|  |  |  |  * Copyright (c) 2017 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * This file is part of Firefly III. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							| 
									
										
										
										
											2017-12-17 14:42:21 +01:00
										 |  |  |  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2017-02-12 12:00:11 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:00:11 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Tests\Feature\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-28 15:50:00 +01:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  | use FireflyIII\Jobs\ExecuteRuleOnExistingTransactions; | 
					
						
							|  |  |  | use FireflyIII\Jobs\Job; | 
					
						
							| 
									
										
										
										
											2017-02-12 13:15:23 +01:00
										 |  |  | use FireflyIII\Models\Rule; | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | use FireflyIII\Models\RuleGroup; | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  | use FireflyIII\Models\Transaction; | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  | use FireflyIII\Repositories\Account\AccountRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | use FireflyIII\Repositories\Journal\JournalRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2017-02-12 13:15:23 +01:00
										 |  |  | use FireflyIII\Repositories\Rule\RuleRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | use FireflyIII\Repositories\RuleGroup\RuleGroupRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2017-09-13 07:49:58 +02:00
										 |  |  | use FireflyIII\TransactionRules\TransactionMatcher; | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  | use Queue; | 
					
						
							| 
									
										
										
										
											2017-02-12 12:00:11 +01:00
										 |  |  | use Tests\TestCase; | 
					
						
							| 
									
										
										
										
											2018-03-24 06:08:50 +01:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Class RuleControllerTest | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-08-12 10:27:45 +02:00
										 |  |  |  * @SuppressWarnings(PHPMD.TooManyPublicMethods) | 
					
						
							|  |  |  |  * @SuppressWarnings(PHPMD.ExcessiveMethodLength) | 
					
						
							|  |  |  |  * @SuppressWarnings(PHPMD.CouplingBetweenObjects) | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-02-12 12:00:11 +01:00
										 |  |  | class RuleControllerTest extends TestCase | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-03-24 06:08:50 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setUp() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::setUp(); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         Log::debug(sprintf('Now in %s.', \get_class($this))); | 
					
						
							| 
									
										
										
										
											2018-03-24 06:08:50 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::create | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testCreate() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // mock stuff
 | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.create', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |         $response->assertSee('<ol class="breadcrumb">'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::create | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getPreviousTriggers | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getPreviousActions | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |     public function testCreatePreviousInput() | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $old = [ | 
					
						
							|  |  |  |             'rule-trigger'       => ['description_is'], | 
					
						
							|  |  |  |             'rule-trigger-stop'  => ['1'], | 
					
						
							|  |  |  |             'rule-trigger-value' => ['X'], | 
					
						
							|  |  |  |             'rule-action'        => ['set_category'], | 
					
						
							|  |  |  |             'rule-action-stop'   => ['1'], | 
					
						
							|  |  |  |             'rule-action-value'  => ['x'], | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         $this->session(['_old_input' => $old]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.create', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |         $response->assertSee('<ol class="breadcrumb">'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::delete | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testDelete() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.delete', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |         $response->assertSee('<ol class="breadcrumb">'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::destroy | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testDestroy() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $repository->shouldReceive('destroy'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-18 20:53:44 +01:00
										 |  |  |         $this->session(['rules.delete.uri' => 'http://localhost']); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->post(route('rules.destroy', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(302); | 
					
						
							|  |  |  |         $response->assertSessionHas('success'); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:32:13 +01:00
										 |  |  |         $response->assertRedirect(route('index')); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::down | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testDown() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         $repository->shouldReceive('moveDown'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.down', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(302); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:32:13 +01:00
										 |  |  |         $response->assertRedirect(route('rules.index')); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::edit | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getCurrentActions | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getCurrentTriggers | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testEdit() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2018-02-28 15:50:00 +01:00
										 |  |  |         $groupRepos   = $this->mock(RuleGroupRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository->shouldReceive('getPrimaryTrigger')->andReturn(new Rule); | 
					
						
							| 
									
										
										
										
											2018-02-28 15:50:00 +01:00
										 |  |  |         $groupRepos->shouldReceive('get')->andReturn(new Collection); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.edit', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |         $response->assertSee('<ol class="breadcrumb">'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::edit | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getPreviousActions | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getPreviousTriggers | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testEditPreviousInput() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $old = [ | 
					
						
							|  |  |  |             'rule-trigger'       => ['description_is'], | 
					
						
							|  |  |  |             'rule-trigger-stop'  => ['1'], | 
					
						
							|  |  |  |             'rule-trigger-value' => ['X'], | 
					
						
							|  |  |  |             'rule-action'        => ['set_category'], | 
					
						
							|  |  |  |             'rule-action-stop'   => ['1'], | 
					
						
							|  |  |  |             'rule-action-value'  => ['x'], | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         $this->session(['_old_input' => $old]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2018-02-28 15:50:00 +01:00
										 |  |  |         $groupRepos   = $this->mock(RuleGroupRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         $repository->shouldReceive('getPrimaryTrigger')->andReturn(new Rule); | 
					
						
							| 
									
										
										
										
											2018-02-28 15:50:00 +01:00
										 |  |  |         $groupRepos->shouldReceive('get')->andReturn(new Collection); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.edit', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |         $response->assertSee('<ol class="breadcrumb">'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::execute | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testExecute() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-02-28 15:50:00 +01:00
										 |  |  |         $account      = $this->user()->accounts()->find(1); | 
					
						
							|  |  |  |         $accountRepos = $this->mock(AccountRepositoryInterface::class); | 
					
						
							|  |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $this->session(['first' => new Carbon('2010-01-01')]); | 
					
						
							|  |  |  |         $accountRepos->shouldReceive('getAccountsById')->andReturn(new Collection([$account])); | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |         Queue::fake(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'accounts'   => [1], | 
					
						
							|  |  |  |             'start_date' => '2017-01-01', | 
					
						
							|  |  |  |             'end_date'   => '2017-01-02', | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->post(route('rules.execute', [1]), $data); | 
					
						
							|  |  |  |         $response->assertStatus(302); | 
					
						
							|  |  |  |         $response->assertSessionHas('success'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Queue::assertPushed( | 
					
						
							|  |  |  |             ExecuteRuleOnExistingTransactions::class, function (Job $job) { | 
					
						
							|  |  |  |             return $job->getRule()->id === 1; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::index | 
					
						
							| 
									
										
										
										
											2017-02-17 20:14:38 +01:00
										 |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::__construct | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::createDefaultRule | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::createDefaultRuleGroup | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testIndex() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							|  |  |  |         $repository     = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $ruleGroupRepos = $this->mock(RuleGroupRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos   = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         $ruleGroupRepos->shouldReceive('count')->andReturn(0); | 
					
						
							|  |  |  |         $ruleGroupRepos->shouldReceive('store'); | 
					
						
							|  |  |  |         $repository->shouldReceive('getFirstRuleGroup')->andReturn(new RuleGroup); | 
					
						
							|  |  |  |         $ruleGroupRepos->shouldReceive('getRuleGroupsWithRules')->andReturn(new Collection); | 
					
						
							|  |  |  |         $repository->shouldReceive('count')->andReturn(0); | 
					
						
							|  |  |  |         $repository->shouldReceive('store'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.index')); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |         $response->assertSee('<ol class="breadcrumb">'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::reorderRuleActions | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testReorderRuleActions() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-22 21:12:27 +01:00
										 |  |  |         $data = ['actions' => [1, 2, 3]]; | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository->shouldReceive('reorderRuleActions')->once(); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->post(route('rules.reorder-actions', [1]), $data); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::reorderRuleTriggers | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testReorderRuleTriggers() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-11-22 21:12:27 +01:00
										 |  |  |         $data = ['triggers' => [1, 2, 3]]; | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $repository->shouldReceive('reorderRuleTriggers')->once(); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->post(route('rules.reorder-triggers', [1]), $data); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::selectTransactions() | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testSelectTransactions() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $accountRepos = $this->mock(AccountRepositoryInterface::class); | 
					
						
							|  |  |  |         $accountRepos->shouldReceive('getAccountsByType')->andReturn(new Collection); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.select-transactions', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |         $response->assertSee('<ol class="breadcrumb">'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-03-24 06:08:50 +01:00
										 |  |  |      * @covers       \FireflyIII\Http\Controllers\RuleController::store | 
					
						
							| 
									
										
										
										
											2018-03-03 17:16:47 +01:00
										 |  |  |      * @covers       \FireflyIII\Http\Requests\RuleFormRequest | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testStore() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-09-03 15:57:13 +02:00
										 |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2017-03-16 20:46:18 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-16 20:46:18 +01:00
										 |  |  |         $repository->shouldReceive('store')->andReturn(new Rule); | 
					
						
							| 
									
										
										
										
											2017-09-03 15:57:13 +02:00
										 |  |  |         $repository->shouldReceive('find')->withArgs([0])->andReturn(new Rule)->once(); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-18 20:53:44 +01:00
										 |  |  |         $this->session(['rules.create.uri' => 'http://localhost']); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $data = [ | 
					
						
							|  |  |  |             'rule_group_id'      => 1, | 
					
						
							|  |  |  |             'active'             => 1, | 
					
						
							|  |  |  |             'title'              => 'A', | 
					
						
							|  |  |  |             'trigger'            => 'store-journal', | 
					
						
							|  |  |  |             'description'        => 'D', | 
					
						
							|  |  |  |             'rule-trigger'       => [ | 
					
						
							|  |  |  |                 1 => 'from_account_starts', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'rule-trigger-value' => [ | 
					
						
							|  |  |  |                 1 => 'B', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'rule-action'        => [ | 
					
						
							|  |  |  |                 1 => 'set_category', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'rule-action-value'  => [ | 
					
						
							|  |  |  |                 1 => 'C', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->post(route('rules.store', [1]), $data); | 
					
						
							|  |  |  |         $response->assertStatus(302); | 
					
						
							|  |  |  |         $response->assertSessionHas('success'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::testTriggers | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getValidTriggerList | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testTestTriggers() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $data = [ | 
					
						
							|  |  |  |             'rule-trigger'       => ['description_is'], | 
					
						
							|  |  |  |             'rule-trigger-value' => ['Bla bla'], | 
					
						
							|  |  |  |             'rule-trigger-stop'  => ['1'], | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $matcher      = $this->mock(TransactionMatcher::class); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $matcher->shouldReceive('setLimit')->withArgs([10])->andReturnSelf()->once(); | 
					
						
							|  |  |  |         $matcher->shouldReceive('setRange')->withArgs([200])->andReturnSelf()->once(); | 
					
						
							|  |  |  |         $matcher->shouldReceive('setTriggers')->andReturnSelf()->once(); | 
					
						
							| 
									
										
										
										
											2017-07-16 17:05:52 +02:00
										 |  |  |         $matcher->shouldReceive('findTransactionsByTriggers')->andReturn(new Collection); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							| 
									
										
										
										
											2017-07-08 06:28:44 +02:00
										 |  |  |         $uri      = route('rules.test-triggers') . '?' . http_build_query($data); | 
					
						
							|  |  |  |         $response = $this->get($uri); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::testTriggersByRule() | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testTestTriggersByRule() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $matcher = $this->mock(TransactionMatcher::class); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $matcher->shouldReceive('setLimit')->withArgs([10])->andReturnSelf()->once(); | 
					
						
							|  |  |  |         $matcher->shouldReceive('setRange')->withArgs([200])->andReturnSelf()->once(); | 
					
						
							|  |  |  |         $matcher->shouldReceive('setRule')->andReturnSelf()->once(); | 
					
						
							|  |  |  |         $matcher->shouldReceive('findTransactionsByRule')->andReturn(new Collection); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.test-triggers-rule', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-08 06:28:44 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * This actually hits an error and not the actually code but OK. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::testTriggers | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getValidTriggerList | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testTestTriggersError() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-07-08 06:28:44 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $uri      = route('rules.test-triggers'); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $response = $this->get($uri); | 
					
						
							|  |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::testTriggers | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::getValidTriggerList | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testTestTriggersMax() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'rule-trigger'       => ['description_is'], | 
					
						
							|  |  |  |             'rule-trigger-value' => ['Bla bla'], | 
					
						
							|  |  |  |             'rule-trigger-stop'  => ['1'], | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2017-07-08 06:28:44 +02:00
										 |  |  |         $set  = factory(Transaction::class, 10)->make(); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // mock stuff
 | 
					
						
							|  |  |  |         $matcher      = $this->mock(TransactionMatcher::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $matcher->shouldReceive('setLimit')->withArgs([10])->andReturnSelf()->once(); | 
					
						
							|  |  |  |         $matcher->shouldReceive('setRange')->withArgs([200])->andReturnSelf()->once(); | 
					
						
							|  |  |  |         $matcher->shouldReceive('setTriggers')->andReturnSelf()->once(); | 
					
						
							| 
									
										
										
										
											2017-07-16 17:05:52 +02:00
										 |  |  |         $matcher->shouldReceive('findTransactionsByTriggers')->andReturn($set); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->be($this->user()); | 
					
						
							| 
									
										
										
										
											2017-07-08 06:28:44 +02:00
										 |  |  |         $uri      = route('rules.test-triggers') . '?' . http_build_query($data); | 
					
						
							| 
									
										
										
										
											2017-03-24 11:07:38 +01:00
										 |  |  |         $response = $this->get($uri); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $response->assertStatus(200); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @covers \FireflyIII\Http\Controllers\RuleController::up | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testUp() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							|  |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         $repository->shouldReceive('moveUp'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->get(route('rules.up', [1])); | 
					
						
							|  |  |  |         $response->assertStatus(302); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:32:13 +01:00
										 |  |  |         $response->assertRedirect(route('rules.index')); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-03-24 06:08:50 +01:00
										 |  |  |      * @covers       \FireflyIII\Http\Controllers\RuleController::update | 
					
						
							| 
									
										
										
										
											2018-03-03 17:16:47 +01:00
										 |  |  |      * @covers       \FireflyIII\Http\Requests\RuleFormRequest | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testUpdate() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  |         // mock stuff
 | 
					
						
							| 
									
										
										
										
											2017-09-03 15:57:13 +02:00
										 |  |  |         $repository   = $this->mock(RuleRepositoryInterface::class); | 
					
						
							|  |  |  |         $journalRepos = $this->mock(JournalRepositoryInterface::class); | 
					
						
							|  |  |  |         $rule         = Rule::find(1); | 
					
						
							| 
									
										
										
										
											2018-04-28 10:27:33 +02:00
										 |  |  |         $journalRepos->shouldReceive('firstNull')->once()->andReturn(new TransactionJournal); | 
					
						
							| 
									
										
										
										
											2017-09-03 15:57:13 +02:00
										 |  |  |         $repository->shouldReceive('find')->withArgs([1])->andReturn($rule)->once(); | 
					
						
							| 
									
										
										
										
											2017-03-16 20:46:18 +01:00
										 |  |  |         $repository->shouldReceive('update'); | 
					
						
							| 
									
										
										
										
											2017-03-05 18:15:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $data = [ | 
					
						
							|  |  |  |             'rule_group_id'      => 1, | 
					
						
							| 
									
										
										
										
											2017-09-03 13:16:11 +02:00
										 |  |  |             'id'                 => 1, | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |             'title'              => 'Your first default rule', | 
					
						
							|  |  |  |             'trigger'            => 'store-journal', | 
					
						
							|  |  |  |             'active'             => 1, | 
					
						
							|  |  |  |             'description'        => 'This rule is an example. You can safely delete it.', | 
					
						
							|  |  |  |             'rule-trigger'       => [ | 
					
						
							|  |  |  |                 1 => 'description_is', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'rule-trigger-value' => [ | 
					
						
							|  |  |  |                 1 => 'something', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'rule-action'        => [ | 
					
						
							|  |  |  |                 1 => 'prepend_description', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'rule-action-value'  => [ | 
					
						
							|  |  |  |                 1 => 'Bla bla', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2017-03-18 20:53:44 +01:00
										 |  |  |         $this->session(['rules.edit.uri' => 'http://localhost']); | 
					
						
							| 
									
										
										
										
											2017-02-12 12:21:44 +01:00
										 |  |  |         $this->be($this->user()); | 
					
						
							|  |  |  |         $response = $this->post(route('rules.update', [1]), $data); | 
					
						
							|  |  |  |         $response->assertStatus(302); | 
					
						
							|  |  |  |         $response->assertSessionHas('success'); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-02-16 22:33:32 +01:00
										 |  |  | } |