mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 05:26:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			628 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			628 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * TransactionLinkControllerTest.php
 | |
|  * Copyright (c) 2018 thegrumpydictator@gmail.com
 | |
|  *
 | |
|  * 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
 | |
|  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| declare(strict_types=1);
 | |
| 
 | |
| namespace Tests\Api\V1\Controllers;
 | |
| 
 | |
| 
 | |
| use Carbon\Carbon;
 | |
| use FireflyIII\Helpers\Collector\TransactionCollectorInterface;
 | |
| use FireflyIII\Models\Transaction;
 | |
| use FireflyIII\Models\TransactionJournalLink;
 | |
| use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
 | |
| use FireflyIII\Repositories\LinkType\LinkTypeRepositoryInterface;
 | |
| use FireflyIII\Transformers\TransactionLinkTransformer;
 | |
| use Illuminate\Support\Collection;
 | |
| use Laravel\Passport\Passport;
 | |
| use Log;
 | |
| use Tests\TestCase;
 | |
| 
 | |
| /**
 | |
|  *
 | |
|  * Class TransactionLinkControllerTest
 | |
|  */
 | |
| class TransactionLinkControllerTest extends TestCase
 | |
| {
 | |
|     /**
 | |
|      *
 | |
|      */
 | |
|     public function setUp(): void
 | |
|     {
 | |
|         parent::setUp();
 | |
|         Passport::actingAs($this->user());
 | |
|         Log::info(sprintf('Now in %s.', get_class($this)));
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      */
 | |
|     public function testDelete(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser')->once();
 | |
|         $journalRepos->shouldReceive('setUser')->once();
 | |
|         $repository->shouldReceive('destroyLink')->once()->andReturn(true);
 | |
| 
 | |
|         // get a link
 | |
|         /** @var TransactionJournalLink $journalLink */
 | |
|         $journalLink = TransactionJournalLink::first();
 | |
| 
 | |
|         // call API
 | |
|         $response = $this->delete('/api/v1/transaction_links/' . $journalLink->id);
 | |
|         $response->assertStatus(204);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      */
 | |
|     public function testIndex(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
|         $transformer  = $this->mock(TransactionLinkTransformer::class);
 | |
| 
 | |
|         // mock transformer
 | |
|         $transformer->shouldReceive('setParameters')->withAnyArgs()->atLeast()->once();
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser')->once();
 | |
|         $repository->shouldReceive('findByName')->once()->andReturn(null);
 | |
|         $repository->shouldReceive('getJournalLinks')->once()->andReturn(new Collection);
 | |
| 
 | |
|         $journalRepos->shouldReceive('setUser')->once();
 | |
| 
 | |
|         // call API
 | |
|         $response = $this->get('/api/v1/transaction_links');
 | |
|         $response->assertStatus(200);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      */
 | |
|     public function testShow(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
| 
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
|         $transformer  = $this->mock(TransactionLinkTransformer::class);
 | |
| 
 | |
|         // mock transformer
 | |
|         $transformer->shouldReceive('setParameters')->withAnyArgs()->atLeast()->once();
 | |
|         $transformer->shouldReceive('setCurrentScope')->withAnyArgs()->atLeast()->once()->andReturnSelf();
 | |
|         $transformer->shouldReceive('getDefaultIncludes')->withAnyArgs()->atLeast()->once()->andReturn([]);
 | |
|         $transformer->shouldReceive('getAvailableIncludes')->withAnyArgs()->atLeast()->once()->andReturn([]);
 | |
|         $transformer->shouldReceive('transform')->atLeast()->once()->andReturn(['id' => 5]);
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser')->once();
 | |
|         $journalRepos->shouldReceive('setUser')->once();
 | |
| 
 | |
| 
 | |
|         // call API
 | |
|         $response = $this->get('/api/v1/transaction_links/' . $journalLink->id);
 | |
|         $response->assertStatus(200);
 | |
|         $response->assertSee($journalLink->id);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testStore(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
|         $transformer  = $this->mock(TransactionLinkTransformer::class);
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         // mock transformer
 | |
|         $transformer->shouldReceive('setParameters')->withAnyArgs()->atLeast()->once();
 | |
|         $transformer->shouldReceive('setCurrentScope')->withAnyArgs()->atLeast()->once()->andReturnSelf();
 | |
|         $transformer->shouldReceive('getDefaultIncludes')->withAnyArgs()->atLeast()->once()->andReturn([]);
 | |
|         $transformer->shouldReceive('getAvailableIncludes')->withAnyArgs()->atLeast()->once()->andReturn([]);
 | |
|         $transformer->shouldReceive('transform')->atLeast()->once()->andReturn(['id' => 5]);
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->andReturn($journal);
 | |
|         $repository->shouldReceive('storeLink')->once()->andReturn($journalLink);
 | |
|         $repository->shouldReceive('findLink')->once()->andReturn(false);
 | |
| 
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->post('/api/v1/transaction_links', $data);
 | |
|         $response->assertStatus(200);
 | |
|         $response->assertHeader('Content-Type', 'application/vnd.api+json');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * In this particular test the journal link request will fail.
 | |
|      *
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testStoreExistingLink(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
|         $collector->shouldReceive('withOpposingAccount')->andReturnSelf();
 | |
|         $collector->shouldReceive('withCategoryInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('withBudgetInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('setJournals')->andReturnSelf();
 | |
|         $collector->shouldReceive('getTransactions')->andReturn(new Collection([$transaction]));
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->andReturn($journal);
 | |
|         $repository->shouldReceive('findLink')->once()->andReturn(true);
 | |
| 
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->post('/api/v1/transaction_links', $data, ['Accept' => 'application/json']);
 | |
|         $response->assertStatus(422);
 | |
|         $response->assertSee('Already have a link between inward and outward.');
 | |
| 
 | |
| 
 | |
|         $response->assertHeader('Content-Type', 'application/json');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * In this particular test the TransactionLinkRequest will report the failure.
 | |
|      *
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testStoreInvalidInward(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
|         $collector->shouldReceive('withOpposingAccount')->andReturnSelf();
 | |
|         $collector->shouldReceive('withCategoryInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('withBudgetInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('setJournals')->andReturnSelf();
 | |
|         $collector->shouldReceive('getTransactions')->andReturn(new Collection([$transaction]));
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->once()->withArgs([1])->andReturn(null);
 | |
|         $journalRepos->shouldReceive('findNull')->once()->withArgs([2])->andReturn(null);
 | |
| 
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->post('/api/v1/transaction_links', $data, ['Accept' => 'application/json']);
 | |
|         $response->assertSee('Invalid inward ID.'); // the creation moment.
 | |
|         $response->assertStatus(422);
 | |
|         $response->assertHeader('Content-Type', 'application/json');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * In this particular test the TransactionLinkRequest will report the failure.
 | |
|      *
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testStoreInvalidOutward(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
|         $collector->shouldReceive('withOpposingAccount')->andReturnSelf();
 | |
|         $collector->shouldReceive('withCategoryInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('withBudgetInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('setJournals')->andReturnSelf();
 | |
|         $collector->shouldReceive('getTransactions')->andReturn(new Collection([$transaction]));
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->once()->withArgs([1])->andReturn($journal);
 | |
|         $journalRepos->shouldReceive('findNull')->once()->withArgs([2])->andReturn(null);
 | |
| 
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->post('/api/v1/transaction_links', $data, ['Accept' => 'application/json']);
 | |
|         $response->assertSee('Invalid outward ID.');
 | |
|         $response->assertStatus(422);
 | |
|         $response->assertHeader('Content-Type', 'application/json');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testStoreNoJournal(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
|         $collector->shouldReceive('withOpposingAccount')->andReturnSelf();
 | |
|         $collector->shouldReceive('withCategoryInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('withBudgetInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('setJournals')->andReturnSelf();
 | |
|         $collector->shouldReceive('getTransactions')->andReturn(new Collection([$transaction]));
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->twice()->withArgs([1])->andReturn($journal, null);
 | |
|         $journalRepos->shouldReceive('findNull')->twice()->withArgs([2])->andReturn($journal, null);
 | |
|         $repository->shouldReceive('findLink')->once()->andReturn(false);
 | |
| 
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->post('/api/v1/transaction_links', $data, ['Accept' => 'application/json']);
 | |
|         $response->assertStatus(500);
 | |
|         $response->assertSee('Source or destination is NULL.'); // the creation moment.
 | |
|         $response->assertHeader('Content-Type', 'application/json');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testStoreWithNull(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
|         // mock stuff:
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
|         $collector->shouldReceive('withOpposingAccount')->andReturnSelf();
 | |
|         $collector->shouldReceive('withCategoryInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('withBudgetInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('setJournals')->andReturnSelf();
 | |
|         $collector->shouldReceive('getTransactions')->andReturn(new Collection([$transaction]));
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->andReturn(null);
 | |
| 
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->post('/api/v1/transaction_links', $data, ['Accept' => 'application/json']);
 | |
|         $response->assertStatus(422);
 | |
|         $response->assertSee('Invalid inward ID.'); // error message
 | |
|         $response->assertHeader('Content-Type', 'application/json');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testUpdate(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         // mock repositories
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
|         $transformer  = $this->mock(TransactionLinkTransformer::class);
 | |
| 
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
|         // mock transformer
 | |
|         $transformer->shouldReceive('setParameters')->withAnyArgs()->atLeast()->once();
 | |
|         $transformer->shouldReceive('setCurrentScope')->withAnyArgs()->atLeast()->once()->andReturnSelf();
 | |
|         $transformer->shouldReceive('getDefaultIncludes')->withAnyArgs()->atLeast()->once()->andReturn([]);
 | |
|         $transformer->shouldReceive('getAvailableIncludes')->withAnyArgs()->atLeast()->once()->andReturn([]);
 | |
|         $transformer->shouldReceive('transform')->atLeast()->once()->andReturn(['id' => 5]);
 | |
| 
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
|         $collector->shouldReceive('withOpposingAccount')->andReturnSelf();
 | |
|         $collector->shouldReceive('withCategoryInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('withBudgetInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('setJournals')->andReturnSelf();
 | |
|         $collector->shouldReceive('getTransactions')->andReturn(new Collection([$transaction]));
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->andReturn($journal);
 | |
|         $repository->shouldReceive('updateLink')->once()->andReturn($journalLink);
 | |
|         $repository->shouldReceive('findLink')->once()->andReturn(false);
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->put('/api/v1/transaction_links/' . $journalLink->id, $data, ['Accept' => 'application/json']);
 | |
|         $response->assertStatus(200);
 | |
|         $response->assertHeader('Content-Type', 'application/vnd.api+json');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testUpdateNoJournal(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         // mock repositories
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
| 
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
|         $collector->shouldReceive('withOpposingAccount')->andReturnSelf();
 | |
|         $collector->shouldReceive('withCategoryInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('withBudgetInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('setJournals')->andReturnSelf();
 | |
|         $collector->shouldReceive('getTransactions')->andReturn(new Collection([$transaction]));
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->twice()->withArgs([1])->andReturn($journal, null);
 | |
|         $journalRepos->shouldReceive('findNull')->twice()->withArgs([2])->andReturn($journal, null);
 | |
|         $repository->shouldReceive('findLink')->once()->andReturn(false);
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->put('/api/v1/transaction_links/' . $journalLink->id, $data, ['Accept' => 'application/json']);
 | |
|         $response->assertStatus(500);
 | |
|         $response->assertSee('Source or destination is NULL.'); // the creation moment.
 | |
|         $response->assertHeader('Content-Type', 'application/json');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \FireflyIII\Api\V1\Controllers\TransactionLinkController
 | |
|      * @covers \FireflyIII\Api\V1\Requests\TransactionLinkRequest
 | |
|      */
 | |
|     public function testUpdateWithNull(): void
 | |
|     {
 | |
|         $this->markTestIncomplete('Needs to be rewritten for v4.8.0');
 | |
| 
 | |
|         return;
 | |
|         // mock repositories
 | |
|         $repository   = $this->mock(LinkTypeRepositoryInterface::class);
 | |
|         $journalRepos = $this->mock(JournalRepositoryInterface::class);
 | |
|         $collector    = $this->mock(TransactionCollectorInterface::class);
 | |
| 
 | |
|         $journalLink                        = TransactionJournalLink::first();
 | |
|         $journal                            = $this->user()->transactionJournals()->find(1);
 | |
|         $transaction                        = Transaction::first();
 | |
|         $transaction->date                  = new Carbon;
 | |
|         $transaction->transaction_type_type = 'Withdrawal';
 | |
| 
 | |
| 
 | |
|         // mock calls:
 | |
|         $repository->shouldReceive('setUser');
 | |
|         $journalRepos->shouldReceive('setUser');
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
| 
 | |
|         $collector->shouldReceive('setUser')->withAnyArgs();
 | |
|         $collector->shouldReceive('withOpposingAccount')->andReturnSelf();
 | |
|         $collector->shouldReceive('withCategoryInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('withBudgetInformation')->andReturnSelf();
 | |
|         $collector->shouldReceive('setJournals')->andReturnSelf();
 | |
|         $collector->shouldReceive('getTransactions')->andReturn(new Collection([$transaction]));
 | |
| 
 | |
|         $journalRepos->shouldReceive('findNull')->andReturn(null);
 | |
| 
 | |
|         // data to submit
 | |
|         $data = [
 | |
|             'link_type_id' => '1',
 | |
|             'inward_id'    => '1',
 | |
|             'outward_id'   => '2',
 | |
|             'notes'        => 'Some notes',
 | |
|         ];
 | |
| 
 | |
|         // test API
 | |
|         $response = $this->put('/api/v1/transaction_links/' . $journalLink->id, $data, ['Accept' => 'application/json']);
 | |
|         $response->assertStatus(422);
 | |
|         $response->assertSee('Invalid inward ID.'); // the creation moment.
 | |
|         $response->assertHeader('Content-Type', 'application/json');
 | |
|     }
 | |
| }
 |