mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-11-08 18:58:07 +00:00
Speed up some tests.
This commit is contained in:
@@ -47,7 +47,8 @@
|
|||||||
"symfony/css-selector": "3.1.*",
|
"symfony/css-selector": "3.1.*",
|
||||||
"symfony/dom-crawler": "3.1.*",
|
"symfony/dom-crawler": "3.1.*",
|
||||||
"barryvdh/laravel-debugbar": "2.*",
|
"barryvdh/laravel-debugbar": "2.*",
|
||||||
"barryvdh/laravel-ide-helper": "2.*"
|
"barryvdh/laravel-ide-helper": "2.*",
|
||||||
|
"johnkary/phpunit-speedtrap": "^1.0"
|
||||||
},
|
},
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"classmap": [
|
"classmap": [
|
||||||
|
|||||||
@@ -8,6 +8,9 @@
|
|||||||
convertWarningsToExceptions="true"
|
convertWarningsToExceptions="true"
|
||||||
processIsolation="false"
|
processIsolation="false"
|
||||||
stopOnFailure="true">
|
stopOnFailure="true">
|
||||||
|
<listeners>
|
||||||
|
<listener class="JohnKary\PHPUnit\Listener\SpeedTrapListener" />
|
||||||
|
</listeners>
|
||||||
<testsuites>
|
<testsuites>
|
||||||
<testsuite name="Application Test Suite">
|
<testsuite name="Application Test Suite">
|
||||||
<directory suffix="Test.php">./tests</directory>
|
<directory suffix="Test.php">./tests</directory>
|
||||||
|
|||||||
@@ -287,7 +287,7 @@ Route::group(
|
|||||||
Route::group(
|
Route::group(
|
||||||
['middleware' => 'user-full-auth', 'namespace' => 'Chart', 'prefix' => 'chart/category', 'as' => 'chart.category.'], function () {
|
['middleware' => 'user-full-auth', 'namespace' => 'Chart', 'prefix' => 'chart/category', 'as' => 'chart.category.'], function () {
|
||||||
|
|
||||||
Route::get('frontpage', ['uses' => 'CategoryController@frontpage']);
|
Route::get('frontpage', ['uses' => 'CategoryController@frontpage', 'as' => 'frontpage']);
|
||||||
Route::get('period/{category}', ['uses' => 'CategoryController@currentPeriod', 'as' => 'current']);
|
Route::get('period/{category}', ['uses' => 'CategoryController@currentPeriod', 'as' => 'current']);
|
||||||
Route::get('period/{category}/{date}', ['uses' => 'CategoryController@specificPeriod', 'as' => 'specific']);
|
Route::get('period/{category}/{date}', ['uses' => 'CategoryController@specificPeriod', 'as' => 'specific']);
|
||||||
Route::get('all/{category}', ['uses' => 'CategoryController@all', 'as' => 'all']);
|
Route::get('all/{category}', ['uses' => 'CategoryController@all', 'as' => 'all']);
|
||||||
|
|||||||
@@ -8,8 +8,11 @@
|
|||||||
*
|
*
|
||||||
* See the LICENSE file for details.
|
* See the LICENSE file for details.
|
||||||
*/
|
*/
|
||||||
|
use FireflyIII\Helpers\Collector\JournalCollectorInterface;
|
||||||
use FireflyIII\Models\Account;
|
use FireflyIII\Models\Account;
|
||||||
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
||||||
|
use FireflyIII\Repositories\Account\AccountTaskerInterface;
|
||||||
|
use Illuminate\Pagination\LengthAwarePaginator;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -105,10 +108,18 @@ class AccountControllerTest extends TestCase
|
|||||||
public function testShow(string $range)
|
public function testShow(string $range)
|
||||||
{
|
{
|
||||||
|
|
||||||
$tasker = $this->mock(\FireflyIII\Repositories\Account\AccountTaskerInterface::class);
|
$tasker = $this->mock(AccountTaskerInterface::class);
|
||||||
$tasker->shouldReceive('amountOutInPeriod')->withAnyArgs()->andReturn('-1');
|
$tasker->shouldReceive('amountOutInPeriod')->withAnyArgs()->andReturn('-1');
|
||||||
$tasker->shouldReceive('amountInInPeriod')->withAnyArgs()->andReturn('1');
|
$tasker->shouldReceive('amountInInPeriod')->withAnyArgs()->andReturn('1');
|
||||||
|
|
||||||
|
$collector = $this->mock(JournalCollectorInterface::class);
|
||||||
|
$collector->shouldReceive('setAccounts')->andReturnSelf();
|
||||||
|
$collector->shouldReceive('setRange')->andReturnSelf();
|
||||||
|
$collector->shouldReceive('setLimit')->andReturnSelf();
|
||||||
|
$collector->shouldReceive('setPage')->andReturnSelf();
|
||||||
|
$collector->shouldReceive('getPaginatedJournals')->andReturn(new LengthAwarePaginator([], 0, 10));
|
||||||
|
|
||||||
|
|
||||||
$this->be($this->user());
|
$this->be($this->user());
|
||||||
$this->changeDateRange($this->user(), $range);
|
$this->changeDateRange($this->user(), $range);
|
||||||
$this->call('GET', route('accounts.show', [1]));
|
$this->call('GET', route('accounts.show', [1]));
|
||||||
|
|||||||
@@ -11,6 +11,8 @@
|
|||||||
|
|
||||||
namespace Chart;
|
namespace Chart;
|
||||||
|
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
|
||||||
use TestCase;
|
use TestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -37,6 +39,11 @@ class BudgetControllerTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function testBudget(string $range)
|
public function testBudget(string $range)
|
||||||
{
|
{
|
||||||
|
$budgetRepository = $this->mock(BudgetRepositoryInterface::class);
|
||||||
|
$budgetRepository->shouldReceive('firstUseDate')->andReturn(new Carbon('2015-01-01'));
|
||||||
|
$budgetRepository->shouldReceive('spentInPeriod')->andReturn('-100');
|
||||||
|
|
||||||
|
|
||||||
$this->be($this->user());
|
$this->be($this->user());
|
||||||
$this->changeDateRange($this->user(), $range);
|
$this->changeDateRange($this->user(), $range);
|
||||||
$this->call('get', route('chart.budget.budget', [1]));
|
$this->call('get', route('chart.budget.budget', [1]));
|
||||||
@@ -51,9 +58,12 @@ class BudgetControllerTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function testBudgetLimit(string $range)
|
public function testBudgetLimit(string $range)
|
||||||
{
|
{
|
||||||
|
$budgetRepository = $this->mock(BudgetRepositoryInterface::class);
|
||||||
|
$budgetRepository->shouldReceive('spentInPeriod')->andReturn('-100');
|
||||||
|
|
||||||
$this->be($this->user());
|
$this->be($this->user());
|
||||||
$this->changeDateRange($this->user(), $range);
|
$this->changeDateRange($this->user(), $range);
|
||||||
$this->call('get', route('chart.budget.budget', [1,1]));
|
$this->call('get', route('chart.budget.budget-limit', [1,1]));
|
||||||
$this->assertResponseStatus(200);
|
$this->assertResponseStatus(200);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,9 @@
|
|||||||
namespace Chart;
|
namespace Chart;
|
||||||
|
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
|
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
||||||
use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
|
use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
|
||||||
|
use Illuminate\Support\Collection;
|
||||||
use TestCase;
|
use TestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -54,12 +56,22 @@ class CategoryControllerTest extends TestCase
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\Http\Controllers\Chart\CategoryController::currentPeriod
|
* @covers \FireflyIII\Http\Controllers\Chart\CategoryController::currentPeriod
|
||||||
|
* @covers \FireflyIII\Http\Controllers\Chart\CategoryController::makePeriodChart
|
||||||
* @dataProvider dateRangeProvider
|
* @dataProvider dateRangeProvider
|
||||||
*
|
*
|
||||||
* @param string $range
|
* @param string $range
|
||||||
*/
|
*/
|
||||||
public function testCurrentPeriod(string $range)
|
public function testCurrentPeriod(string $range)
|
||||||
{
|
{
|
||||||
|
// this is actually for makePeriodChart
|
||||||
|
$accountRepository = $this->mock(AccountRepositoryInterface::class);
|
||||||
|
$categoryRepository = $this->mock(CategoryRepositoryInterface::class);
|
||||||
|
$account = $this->user()->accounts()->where('account_type_id', 5)->first();
|
||||||
|
$accountRepository->shouldReceive('getAccountsByType')->andReturn(new Collection([$account]));
|
||||||
|
$categoryRepository->shouldReceive('spentInPeriod')->andReturn('0');
|
||||||
|
$categoryRepository->shouldReceive('earnedInPeriod')->andReturn('0');
|
||||||
|
|
||||||
|
|
||||||
$this->be($this->user());
|
$this->be($this->user());
|
||||||
$this->changeDateRange($this->user(), $range);
|
$this->changeDateRange($this->user(), $range);
|
||||||
$this->call('get', route('chart.category.current', [1]));
|
$this->call('get', route('chart.category.current', [1]));
|
||||||
@@ -74,9 +86,21 @@ class CategoryControllerTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function testFrontpage(string $range)
|
public function testFrontpage(string $range)
|
||||||
{
|
{
|
||||||
|
$accountRepository = $this->mock(AccountRepositoryInterface::class);
|
||||||
|
$categoryRepository = $this->mock(CategoryRepositoryInterface::class);
|
||||||
|
$category = $this->user()->categories()->first();
|
||||||
|
$account = $this->user()->accounts()->where('account_type_id', 5)->first();
|
||||||
|
// get one category
|
||||||
|
$categoryRepository->shouldReceive('getCategories')->andReturn(new Collection([$category]));
|
||||||
|
// get one account
|
||||||
|
$accountRepository->shouldReceive('getAccountsByType')->andReturn(new Collection([$account]));
|
||||||
|
// always return zero
|
||||||
|
$categoryRepository->shouldReceive('spentInPeriod')->andReturn('0');
|
||||||
|
$categoryRepository->shouldReceive('spentInPeriodWithoutCategory')->andReturn('0');
|
||||||
|
|
||||||
$this->be($this->user());
|
$this->be($this->user());
|
||||||
$this->changeDateRange($this->user(), $range);
|
$this->changeDateRange($this->user(), $range);
|
||||||
$this->call('get', route('chart.category.current', [1]));
|
$this->call('get', route('chart.category.frontpage', [1]));
|
||||||
$this->assertResponseStatus(200);
|
$this->assertResponseStatus(200);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -102,12 +126,20 @@ class CategoryControllerTest extends TestCase
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\Http\Controllers\Chart\CategoryController::specificPeriod
|
* @covers \FireflyIII\Http\Controllers\Chart\CategoryController::specificPeriod
|
||||||
|
* @covers \FireflyIII\Http\Controllers\Chart\CategoryController::makePeriodChart
|
||||||
* @dataProvider dateRangeProvider
|
* @dataProvider dateRangeProvider
|
||||||
*
|
*
|
||||||
* @param string $range
|
* @param string $range
|
||||||
*/
|
*/
|
||||||
public function testSpecificPeriod(string $range)
|
public function testSpecificPeriod(string $range)
|
||||||
{
|
{
|
||||||
|
$accountRepository = $this->mock(AccountRepositoryInterface::class);
|
||||||
|
$categoryRepository = $this->mock(CategoryRepositoryInterface::class);
|
||||||
|
$account = $this->user()->accounts()->where('account_type_id', 5)->first();
|
||||||
|
$accountRepository->shouldReceive('getAccountsByType')->andReturn(new Collection([$account]));
|
||||||
|
$categoryRepository->shouldReceive('spentInPeriod')->andReturn('0');
|
||||||
|
$categoryRepository->shouldReceive('earnedInPeriod')->andReturn('0');
|
||||||
|
|
||||||
$this->be($this->user());
|
$this->be($this->user());
|
||||||
$this->changeDateRange($this->user(), $range);
|
$this->changeDateRange($this->user(), $range);
|
||||||
$this->call('get', route('chart.category.specific', ['1', '2012-01-01']));
|
$this->call('get', route('chart.category.specific', ['1', '2012-01-01']));
|
||||||
|
|||||||
Reference in New Issue
Block a user