2015-04-05 11:20:06 -05:00
|
|
|
<?php
|
|
|
|
use Carbon\Carbon;
|
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
use League\FactoryMuffin\Facade as FactoryMuffin;
|
|
|
|
|
|
|
|
/**
|
2015-05-17 05:49:09 -05:00
|
|
|
* @SuppressWarnings(PHPMD.TooManyMethods)
|
2015-04-05 11:20:06 -05:00
|
|
|
* Class BillControllerTest
|
|
|
|
*/
|
|
|
|
class BillControllerTest 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();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::create
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testCreate()
|
|
|
|
{
|
|
|
|
// go!
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$this->be($bill->user);
|
|
|
|
|
|
|
|
// CURRENCY:
|
|
|
|
$currency = FactoryMuffin::create('FireflyIII\Models\TransactionCurrency');
|
|
|
|
Amount::shouldReceive('getDefaultCurrency')->once()->andReturn($currency);
|
|
|
|
Amount::shouldReceive('getAllCurrencies')->once()->andReturn([$currency]);
|
2015-05-02 12:44:12 -05:00
|
|
|
Amount::shouldReceive('getCurrencyCode')->andReturn('X');
|
2015-04-05 11:20:06 -05:00
|
|
|
|
|
|
|
$this->call('GET', '/bills/create');
|
2015-05-05 03:30:39 -05:00
|
|
|
$this->assertViewHas('subTitle', 'Create new bill');
|
2015-04-05 11:20:06 -05:00
|
|
|
$this->assertResponseOk();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::delete
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testDelete()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$this->be($bill->user);
|
|
|
|
$this->call('GET', '/bills/delete/' . $bill->id);
|
2015-05-25 15:56:00 -05:00
|
|
|
$this->assertViewHas('subTitle', 'Delete bill "' . e($bill->name) . '"');
|
2015-04-05 11:20:06 -05:00
|
|
|
$this->assertResponseOk();
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::destroy
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testDestroy()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$this->be($bill->user);
|
|
|
|
|
2015-04-07 11:48:34 -05:00
|
|
|
$repository = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface');
|
|
|
|
$repository->shouldReceive('destroy')->andReturn(true);
|
|
|
|
|
2015-04-05 11:20:06 -05:00
|
|
|
|
|
|
|
$this->call('POST', '/bills/destroy/' . $bill->id, ['_token' => 'replaceMe']);
|
|
|
|
$this->assertSessionHas('success', 'The bill was deleted.');
|
|
|
|
$this->assertResponseStatus(302);
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::edit
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testEdit()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$this->be($bill->user);
|
|
|
|
|
|
|
|
// CURRENCY:
|
|
|
|
$currency = FactoryMuffin::create('FireflyIII\Models\TransactionCurrency');
|
|
|
|
Amount::shouldReceive('getDefaultCurrency')->once()->andReturn($currency);
|
|
|
|
Amount::shouldReceive('getAllCurrencies')->once()->andReturn([$currency]);
|
2015-05-02 12:44:12 -05:00
|
|
|
Amount::shouldReceive('getCurrencyCode')->andReturn('X');
|
2015-04-05 11:20:06 -05:00
|
|
|
|
|
|
|
$this->call('GET', '/bills/edit/' . $bill->id);
|
|
|
|
$this->assertViewHas('subTitle', 'Edit "' . e($bill->name) . '"');
|
|
|
|
$this->assertResponseOk();
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::index
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testIndex()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$this->be($bill->user);
|
|
|
|
|
|
|
|
$collection = new Collection;
|
|
|
|
$collection->push($bill);
|
|
|
|
|
|
|
|
Amount::shouldReceive('format')->andReturn('XX');
|
2015-05-02 12:44:12 -05:00
|
|
|
Amount::shouldReceive('getCurrencyCode')->andReturn('X');
|
2015-04-05 11:20:06 -05:00
|
|
|
|
|
|
|
$repository = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface');
|
|
|
|
$repository->shouldReceive('getBills')->once()->andReturn($collection);
|
|
|
|
$repository->shouldReceive('nextExpectedMatch')->with($bill)->andReturn(new Carbon);
|
|
|
|
$repository->shouldReceive('lastFoundMatch')->with($bill)->andReturn(new Carbon);
|
|
|
|
|
|
|
|
$this->call('GET', '/bills');
|
|
|
|
$this->assertResponseOk();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::rescan
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testRescan()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$journal = FactoryMuffin::create('FireflyIII\Models\TransactionJournal');
|
|
|
|
$collection = new Collection;
|
|
|
|
$this->be($bill->user);
|
|
|
|
$collection->push($journal);
|
|
|
|
|
|
|
|
$repository = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface');
|
|
|
|
$repository->shouldReceive('getPossiblyRelatedJournals')->once()->andReturn($collection);
|
|
|
|
$repository->shouldReceive('scan');
|
|
|
|
|
|
|
|
$this->call('GET', '/bills/rescan/' . $bill->id);
|
|
|
|
$this->assertResponseStatus(302);
|
|
|
|
$this->assertSessionHas('success', 'Rescanned everything.');
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::rescan
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testRescanInactive()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$bill->active = 0;
|
|
|
|
$bill->save();
|
|
|
|
$this->be($bill->user);
|
|
|
|
|
|
|
|
$this->call('GET', '/bills/rescan/' . $bill->id);
|
|
|
|
$this->assertResponseStatus(302);
|
|
|
|
$this->assertSessionHas('warning', 'Inactive bills cannot be scanned.');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::show
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testShow()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$journal = FactoryMuffin::create('FireflyIII\Models\TransactionJournal');
|
|
|
|
$collection = new Collection;
|
|
|
|
|
|
|
|
$bill->save();
|
|
|
|
$this->be($bill->user);
|
|
|
|
$collection->push($journal);
|
|
|
|
|
|
|
|
|
|
|
|
$repository = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface');
|
|
|
|
$repository->shouldReceive('getJournals')->once()->andReturn($collection);
|
|
|
|
$repository->shouldReceive('nextExpectedMatch')->once()->andReturn(new Carbon);
|
|
|
|
|
|
|
|
Amount::shouldReceive('format')->andReturn('XX');
|
2015-06-02 10:58:30 -05:00
|
|
|
Amount::shouldReceive('formatJournal')->andReturn('XX');
|
2015-04-05 11:20:06 -05:00
|
|
|
Amount::shouldReceive('getCurrencyCode')->andReturn('XX');
|
|
|
|
|
2015-05-02 12:44:12 -05:00
|
|
|
|
2015-04-05 11:20:06 -05:00
|
|
|
$this->call('GET', '/bills/show/' . $bill->id);
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::store
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testStore()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$repository = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface');
|
|
|
|
$request = $this->mock('FireflyIII\Http\Requests\BillFormRequest');
|
|
|
|
|
|
|
|
$this->be($bill->user);
|
|
|
|
$request->shouldReceive('getBillData')->once()->andReturn([]);
|
|
|
|
$repository->shouldReceive('store')->with([])->andReturn($bill);
|
|
|
|
|
|
|
|
$this->call('POST', '/bills/store', ['_token' => 'replaceMe']);
|
|
|
|
$this->assertResponseStatus(302);
|
|
|
|
$this->assertSessionHas('success', 'Bill "' . e($bill->name) . '" stored.');
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::store
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testStoreAndRedirect()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$repository = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface');
|
|
|
|
$request = $this->mock('FireflyIII\Http\Requests\BillFormRequest');
|
|
|
|
|
|
|
|
$this->be($bill->user);
|
|
|
|
$request->shouldReceive('getBillData')->once()->andReturn([]);
|
|
|
|
$repository->shouldReceive('store')->with([])->andReturn($bill);
|
|
|
|
|
|
|
|
$this->call('POST', '/bills/store', ['_token' => 'replaceMe', 'create_another' => 1]);
|
|
|
|
$this->assertResponseStatus(302);
|
|
|
|
$this->assertSessionHas('success', 'Bill "' . e($bill->name) . '" stored.');
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::update
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testUpdate()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$repository = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface');
|
|
|
|
$request = $this->mock('FireflyIII\Http\Requests\BillFormRequest');
|
|
|
|
|
|
|
|
$this->be($bill->user);
|
|
|
|
$request->shouldReceive('getBillData')->once()->andReturn([]);
|
|
|
|
$repository->shouldReceive('update')->andReturn($bill);
|
|
|
|
|
|
|
|
$this->call('POST', '/bills/update/' . $bill->id, ['_token' => 'replaceMe']);
|
|
|
|
$this->assertResponseStatus(302);
|
|
|
|
$this->assertSessionHas('success', 'Bill "' . e($bill->name) . '" updated.');
|
|
|
|
}
|
|
|
|
|
2015-05-23 12:41:54 -05:00
|
|
|
/**
|
|
|
|
* @covers FireflyIII\Http\Controllers\BillController::update
|
|
|
|
*/
|
2015-04-05 11:20:06 -05:00
|
|
|
public function testUpdateAndRedirect()
|
|
|
|
{
|
|
|
|
$bill = FactoryMuffin::create('FireflyIII\Models\Bill');
|
|
|
|
$repository = $this->mock('FireflyIII\Repositories\Bill\BillRepositoryInterface');
|
|
|
|
$request = $this->mock('FireflyIII\Http\Requests\BillFormRequest');
|
|
|
|
|
|
|
|
$this->be($bill->user);
|
|
|
|
$request->shouldReceive('getBillData')->once()->andReturn([]);
|
|
|
|
$repository->shouldReceive('update')->andReturn($bill);
|
|
|
|
|
|
|
|
$this->call('POST', '/bills/update/' . $bill->id, ['_token' => 'replaceMe', 'return_to_edit' => 1]);
|
|
|
|
$this->assertResponseStatus(302);
|
|
|
|
|
|
|
|
}
|
2015-05-05 05:51:57 -05:00
|
|
|
}
|