This fixes the tests (must still upload test database).

This commit is contained in:
James Cole
2017-06-24 12:38:24 +02:00
parent 8e3ba7caf2
commit 5fbc319b20
8 changed files with 127 additions and 352 deletions

View File

@@ -77,7 +77,9 @@ class Import extends Command
$handler = new CommandHandler($this); $handler = new CommandHandler($this);
$monolog->pushHandler($handler); $monolog->pushHandler($handler);
$routine = new ImportRoutine($job); /** @var ImportRoutine $routine */
$routine = app(ImportRoutine::class);
$routine->setJob($job);
$routine->run(); $routine->run();
/** @var MessageBag $error */ /** @var MessageBag $error */

View File

@@ -243,7 +243,9 @@ class ImportController extends Controller
*/ */
public function start(ImportJob $job) public function start(ImportJob $job)
{ {
$routine = new ImportRoutine($job); /** @var ImportRoutine $routine */
$routine = app(ImportRoutine::class);
$routine->setJob($job);
$result = $routine->run(); $result = $routine->run();
if ($result) { if ($result) {
return Response::json(['run' => 'ok']); return Response::json(['run' => 'ok']);
@@ -281,9 +283,12 @@ class ImportController extends Controller
$key = sprintf('firefly.import_configurators.%s', $type); $key = sprintf('firefly.import_configurators.%s', $type);
$className = config($key); $className = config($key);
if (is_null($className)) { if (is_null($className)) {
throw new FireflyException('Cannot find configurator class for this job.'); throw new FireflyException('Cannot find configurator class for this job.'); // @codeCoverageIgnore
} }
$configurator = new $className($job); /** @var ConfiguratorInterface $configurator */
$configurator = app($className);
$configurator->setJob($job);
return $configurator; return $configurator;
} }

View File

@@ -22,10 +22,8 @@ interface ConfiguratorInterface
{ {
/** /**
* ConfiguratorInterface constructor. * ConfiguratorInterface constructor.
*
* @param ImportJob $job
*/ */
public function __construct(ImportJob $job); public function __construct();
/** /**
* Store any data from the $data array into the job. * Store any data from the $data array into the job.
@@ -36,6 +34,13 @@ interface ConfiguratorInterface
*/ */
public function configureJob(array $data): bool; public function configureJob(array $data): bool;
/**
* @param ImportJob $job
*
* @return void
*/
public function setJob(ImportJob $job);
/** /**
* Return the data required for the next step in the job configuration. * Return the data required for the next step in the job configuration.
* *

View File

@@ -28,14 +28,11 @@ class CsvConfigurator implements ConfiguratorInterface
{ {
private $job; private $job;
public function __construct(ImportJob $job) /**
* ConfiguratorInterface constructor.
*/
public function __construct()
{ {
$this->job = $job;
if (is_null($this->job->configuration) || count($this->job->configuration) === 0) {
Log::debug(sprintf('Gave import job %s initial configuration.', $this->job->key));
$this->job->configuration = config('csv.default_config');
$this->job->save();
}
} }
/** /**
@@ -116,6 +113,19 @@ class CsvConfigurator implements ConfiguratorInterface
return false; return false;
} }
/**
* @param ImportJob $job
*/
public function setJob(ImportJob $job)
{
$this->job = $job;
if (is_null($this->job->configuration) || count($this->job->configuration) === 0) {
Log::debug(sprintf('Gave import job %s initial configuration.', $this->job->key));
$this->job->configuration = config('csv.default_config');
$this->job->save();
}
}
/** /**
* @return string * @return string
* @throws FireflyException * @throws FireflyException

View File

@@ -37,16 +37,23 @@ class ImportRoutine
/** /**
* ImportRoutine constructor. * ImportRoutine constructor.
* *
* @param ImportJob $job
*/ */
public function __construct(ImportJob $job) public function __construct()
{ {
$this->job = $job;
$this->journals = new Collection; $this->journals = new Collection;
$this->errors = new Collection; $this->errors = new Collection;
Log::debug(sprintf('Job ID is #%d', $job->id)); Log::debug(sprintf('Job ID is #%d', $job->id));
} }
/**
* @param ImportJob $job
*/
public function setJob(ImportJob $job)
{
$this->job = $job;
}
/** /**
* *
*/ */

View File

@@ -390,7 +390,7 @@ Route::group(
Route::get('download/{importJob}', ['uses' => 'ImportController@download', 'as' => 'download']); Route::get('download/{importJob}', ['uses' => 'ImportController@download', 'as' => 'download']);
Route::get('status/{importJob}', ['uses' => 'ImportController@status', 'as' => 'status']); Route::get('status/{importJob}', ['uses' => 'ImportController@status', 'as' => 'status']);
Route::get('json/{importJob}', ['uses' => 'ImportController@json', 'as' => 'json']); Route::get('json/{importJob}', ['uses' => 'ImportController@json', 'as' => 'json']);
Route::any('start/{importJob}', ['uses' => 'ImportController@start', 'as' => 'start']); Route::post('start/{importJob}', ['uses' => 'ImportController@start', 'as' => 'start']);

View File

@@ -7,19 +7,14 @@
* See the LICENSE file for details. * See the LICENSE file for details.
*/ */
declare(strict_types = 1); declare(strict_types=1);
namespace Tests\Feature\Controllers; namespace Tests\Feature\Controllers;
use FireflyIII\Import\ImportProcedureInterface; use FireflyIII\Import\Configurator\CsvConfigurator;
use FireflyIII\Import\Setup\CsvSetup; use FireflyIII\Import\Routine\ImportRoutine;
use FireflyIII\Models\ImportJob; use FireflyIII\Models\ImportJob;
use FireflyIII\Models\Tag;
use FireflyIII\Models\TransactionJournal;
use FireflyIII\Repositories\ImportJob\ImportJobRepositoryInterface; use FireflyIII\Repositories\ImportJob\ImportJobRepositoryInterface;
use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
use FireflyIII\Repositories\Tag\TagRepositoryInterface;
use FireflyIII\Repositories\User\UserRepositoryInterface;
use Illuminate\Http\UploadedFile; use Illuminate\Http\UploadedFile;
use Tests\TestCase; use Tests\TestCase;
@@ -31,53 +26,20 @@ use Tests\TestCase;
class ImportControllerTest extends TestCase class ImportControllerTest extends TestCase
{ {
/**
* @covers \FireflyIII\Http\Controllers\ImportController::complete
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/
public function testComplete()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user());
$response = $this->get(route('import.complete', ['complete']));
$response->assertStatus(200);
$response->assertSee('<ol class="breadcrumb">');
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::complete
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/
public function testCompleteWrongJob()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user());
$response = $this->get(route('import.complete', ['configure']));
$response->assertStatus(302);
}
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::__construct
* @covers \FireflyIII\Http\Controllers\ImportController::configure * @covers \FireflyIII\Http\Controllers\ImportController::configure
* @covers \FireflyIII\Http\Controllers\ImportController::makeImporter * @covers \FireflyIII\Http\Controllers\ImportController::makeConfigurator
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/ */
public function testConfigure() public function testConfigure()
{ {
$setup = $this->mock(CsvSetup::class); // mock stuff.
$journalRepos = $this->mock(JournalRepositoryInterface::class); $configurator = $this->mock(CsvConfigurator::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $configurator->shouldReceive('setJob')->once();
$configurator->shouldReceive('isJobConfigured')->once()->andReturn(false);
$configurator->shouldReceive('getNextView')->once()->andReturn('import.csv.initial');
$configurator->shouldReceive('getNextData')->andReturn(['specifics' => [], 'delimiters' => [], 'accounts' => []])->once();
$setup->shouldReceive('setJob')->once();
$setup->shouldReceive('configure')->once();
$setup->shouldReceive('getConfigurationData')->andReturn(['specifics' => [], 'delimiters' => [], 'accounts' => []])->once();
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.configure', ['configure'])); $response = $this->get(route('import.configure', ['configure']));
@@ -86,86 +48,67 @@ class ImportControllerTest extends TestCase
} }
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::__construct
* @covers \FireflyIII\Http\Controllers\ImportController::configure * @covers \FireflyIII\Http\Controllers\ImportController::configure
* @covers \FireflyIII\Http\Controllers\ImportController::makeImporter * @covers \FireflyIII\Http\Controllers\ImportController::makeConfigurator
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/ */
public function testConfigureWrongJob() public function testConfigured()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class); // mock stuff.
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $configurator = $this->mock(CsvConfigurator::class);
$configurator->shouldReceive('setJob')->once();
$configurator->shouldReceive('isJobConfigured')->once()->andReturn(true);
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.configure', ['settings'])); $response = $this->get(route('import.configure', ['configure']));
$response->assertStatus(302); $response->assertStatus(302);
$response->assertRedirect(route('import.status', ['configure']));
} }
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::download * @covers \FireflyIII\Http\Controllers\ImportController::download
*/ */
public function testDownload() public function testDownload()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.download', ['configure'])); $response = $this->get(route('import.download', ['configure']));
$response->assertStatus(200); $response->assertStatus(200);
$response->assertJson(
[
'delimiter' => 'tab',
'column-roles-complete' => false,
'column-mapping-complete' => false,
]
);
} }
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::finished * @covers \FireflyIII\Http\Controllers\ImportController::index
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/ */
public function testFinished() public function testIndex()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.finished', ['finished'])); $response = $this->get(route('import.index'));
$response->assertStatus(200); $response->assertStatus(200);
$response->assertSee('<ol class="breadcrumb">'); $response->assertSee('<ol class="breadcrumb">');
} }
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::finished * @covers \FireflyIII\Http\Controllers\ImportController::initialize
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/ */
public function testFinishedWrongJob() public function testInitialize()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class); $repository = $this->mock(ImportJobRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $path = resource_path('stubs/csv.csv');
$file = new UploadedFile($path, 'upload.csv', filesize($path), 'text/csv', null, true);
$configPath = resource_path('stubs/demo-configuration.json');
$configFile = new UploadedFile($path, 'configuration.json', filesize($configPath), 'application/json', null, true);
$job = new ImportJob;
$job->key = 'hello';
$repository->shouldReceive('create')->once()->andReturn($job);
$repository->shouldReceive('processFile')->once();
$repository->shouldReceive('processConfiguration')->once();
$repository->shouldReceive('updateStatus')->once();
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.finished', ['configure'])); $response = $this->post(route('import.initialize'), ['import_file_type' => 'csv', 'import_file' => $file, 'configuration_file' => $configFile]);
$response->assertStatus(302); $response->assertStatus(302);
} $response->assertRedirect(route('import.configure', ['hello']));
/**
* @covers \FireflyIII\Http\Controllers\ImportController::index
* @covers \FireflyIII\Http\Controllers\ImportController::__construct
*/
public function testIndex()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user());
$response = $this->get(route('import.index'));
$response->assertStatus(200);
} }
/** /**
@@ -173,9 +116,6 @@ class ImportControllerTest extends TestCase
*/ */
public function testJson() public function testJson()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.json', ['configure'])); $response = $this->get(route('import.json', ['configure']));
$response->assertStatus(200); $response->assertStatus(200);
@@ -186,13 +126,6 @@ class ImportControllerTest extends TestCase
*/ */
public function testJsonFinished() public function testJsonFinished()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$tagRepos = $this->mock(TagRepositoryInterface::class);
$tag = factory(Tag::class)->make();
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$tagRepos->shouldReceive('find')->once()->andReturn($tag);
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.json', ['finished'])); $response = $this->get(route('import.json', ['finished']));
$response->assertStatus(200); $response->assertStatus(200);
@@ -203,9 +136,6 @@ class ImportControllerTest extends TestCase
*/ */
public function testJsonRunning() public function testJsonRunning()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.json', ['running'])); $response = $this->get(route('import.json', ['running']));
$response->assertStatus(200); $response->assertStatus(200);
@@ -213,156 +143,35 @@ class ImportControllerTest extends TestCase
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::postConfigure * @covers \FireflyIII\Http\Controllers\ImportController::postConfigure
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/ */
public function testPostConfigure() public function testPostConfigure()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class); $configurator = $this->mock(CsvConfigurator::class);
$repository = $this->mock(ImportJobRepositoryInterface::class); $configurator->shouldReceive('setJob')->once();
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $configurator->shouldReceive('isJobConfigured')->once()->andReturn(false);
$configurator->shouldReceive('configureJob')->once()->andReturn(false);
$importer = $this->mock(CsvSetup::class);
$importer->shouldReceive('setJob')->once();
$importer->shouldReceive('saveImportConfiguration')->once();
$repository->shouldReceive('updateStatus')->once();
$data = [];
$this->be($this->user()); $this->be($this->user());
$response = $this->post(route('import.process-configuration', ['p-configure']), $data); $response = $this->post(route('import.process-configuration', ['running']));
$response->assertStatus(302); $response->assertStatus(302);
$response->assertRedirect(route('import.settings', ['p-configure'])); $response->assertRedirect(route('import.configure', ['running']));
} }
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::postConfigure * @covers \FireflyIII\Http\Controllers\ImportController::postConfigure
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/ */
public function testPostConfigureWrongJob() public function testPostConfigured()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class); $configurator = $this->mock(CsvConfigurator::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $configurator->shouldReceive('setJob')->once();
$configurator->shouldReceive('isJobConfigured')->once()->andReturn(true);
$data = [];
$this->be($this->user()); $this->be($this->user());
$response = $this->post(route('import.process-configuration', ['finished']), $data); $response = $this->post(route('import.process-configuration', ['running']));
$response->assertStatus(302); $response->assertStatus(302);
$response->assertRedirect(route('import.finished', ['finished'])); $response->assertRedirect(route('import.status', ['running']));
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::postSettings
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/
public function testPostSettings()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$importer = $this->mock(CsvSetup::class);
$importer->shouldReceive('setJob')->once();
$importer->shouldReceive('storeSettings')->once();
$data = [];
$this->be($this->user());
$response = $this->post(route('import.post-settings', ['p-settings']), $data);
$response->assertStatus(302);
$response->assertRedirect(route('import.settings', ['p-settings']));
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::postSettings
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/
public function testPostSettingsWrongJob()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$data = [];
$this->be($this->user());
$response = $this->post(route('import.post-settings', ['configure']), $data);
$response->assertStatus(302);
$response->assertRedirect(route('import.configure', ['configure']));
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::settings
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/
public function testSettings()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$repository = $this->mock(ImportJobRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$importer = $this->mock(CsvSetup::class);
$importer->shouldReceive('setJob')->once();
$importer->shouldReceive('requireUserSettings')->once()->andReturn(false);
$repository->shouldReceive('updateStatus')->once();
$this->be($this->user());
$response = $this->get(route('import.settings', ['settings']));
$response->assertStatus(302);
$response->assertRedirect(route('import.complete', ['settings']));
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::settings
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/
public function testSettingsUserSettings()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$importer = $this->mock(CsvSetup::class);
$importer->shouldReceive('setJob')->once();
$importer->shouldReceive('requireUserSettings')->once()->andReturn(true);
$importer->shouldReceive('getDataForSettings')->once()->andReturn([]);
$importer->shouldReceive('getViewForSettings')->once()->andReturn('error');
$this->be($this->user());
$response = $this->get(route('import.settings', ['settings']));
$response->assertStatus(200);
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::settings
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/
public function testSettingsWrongJob()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user());
$response = $this->get(route('import.settings', ['configure']));
$response->assertStatus(302);
$response->assertRedirect(route('import.configure', ['configure']));
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::settings
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/
public function testSettingsWrongJobAgain()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$this->be($this->user());
$response = $this->get(route('import.settings', ['complete']));
$response->assertStatus(302);
$response->assertRedirect(route('import.complete', ['complete']));
} }
/** /**
@@ -370,118 +179,51 @@ class ImportControllerTest extends TestCase
*/ */
public function testStart() public function testStart()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class); $importer = $this->mock(ImportRoutine::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $importer->shouldReceive('setJob')->once();
$importer->shouldReceive('run')->once()->andReturn(true);
/** @var ImportProcedureInterface $procedure */
$procedure = $this->mock(ImportProcedureInterface::class);
$procedure->shouldReceive('runImport');
$this->be($this->user()); $this->be($this->user());
$response = $this->post(route('import.start', ['complete'])); $response = $this->post(route('import.start', ['running']));
$response->assertStatus(200); $response->assertStatus(200);
} }
/**
* @covers \FireflyIII\Http\Controllers\ImportController::start
* @expectedExceptionMessage Job did not complete succesfully.
*/
public function testStartFailed()
{
$importer = $this->mock(ImportRoutine::class);
$importer->shouldReceive('setJob')->once();
$importer->shouldReceive('run')->once()->andReturn(false);
$this->be($this->user());
$response = $this->post(route('import.start', ['running']));
$response->assertStatus(500);
}
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::status * @covers \FireflyIII\Http\Controllers\ImportController::status
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/ */
public function testStatus() public function testStatus()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
// complete
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.status', ['complete'])); $response = $this->get(route('import.status', ['running']));
$response->assertStatus(200); $response->assertStatus(200);
} }
/** /**
* @covers \FireflyIII\Http\Controllers\ImportController::status * @covers \FireflyIII\Http\Controllers\ImportController::status
* @covers \FireflyIII\Http\Controllers\ImportController::jobInCorrectStep
* @covers \FireflyIII\Http\Controllers\ImportController::redirectToCorrectStep
*/ */
public function testStatusWrongJob() public function testStatusNew()
{ {
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
// complete
$this->be($this->user()); $this->be($this->user());
$response = $this->get(route('import.status', ['configure'])); $response = $this->get(route('import.status', ['new']));
$response->assertStatus(302); $response->assertStatus(302);
$response->assertRedirect(route('import.configure', ['configure'])); $response->assertRedirect(route('import.configure', ['new']));
} }
/**
* @covers \FireflyIII\Http\Controllers\ImportController::upload
*/
public function testUpload()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$userRepos = $this->mock(UserRepositoryInterface::class);
$repository = $this->mock(ImportJobRepositoryInterface::class);
$job = factory(ImportJob::class)->make();
$journalRepos->shouldReceive('first')->andReturn(new TransactionJournal);
$userRepos->shouldReceive('hasRole')->andReturn(false);
$repository->shouldReceive('create')->andReturn($job);
$path = resource_path('stubs/csv.csv');
$file = new UploadedFile($path, 'upload.csv', filesize($path), 'text/csv', null, true);
$this->be($this->user());
$response = $this->post(route('import.upload'), ['import_file_type' => 'csv', 'import_file' => $file]);
$response->assertStatus(302);
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::upload
*/
public function testUploadDemo()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$userRepos = $this->mock(UserRepositoryInterface::class);
$repository = $this->mock(ImportJobRepositoryInterface::class);
$job = factory(ImportJob::class)->make();
$journalRepos->shouldReceive('first')->andReturn(new TransactionJournal);
$userRepos->shouldReceive('hasRole')->andReturn(true);
$repository->shouldReceive('create')->andReturn($job);
$repository->shouldReceive('setConfiguration')->andReturn($job);
$path = resource_path('stubs/csv.csv');
$file = new UploadedFile($path, 'upload.csv', filesize($path), 'text/csv', null, true);
$this->be($this->user());
$response = $this->post(route('import.upload'), ['import_file_type' => 'csv', 'import_file' => $file]);
$response->assertStatus(302);
}
/**
* @covers \FireflyIII\Http\Controllers\ImportController::upload
*/
public function testUploadWithConfig()
{
$journalRepos = $this->mock(JournalRepositoryInterface::class);
$userRepos = $this->mock(UserRepositoryInterface::class);
$repository = $this->mock(ImportJobRepositoryInterface::class);
$job = factory(ImportJob::class)->make();
$journalRepos->shouldReceive('first')->andReturn(new TransactionJournal);
$userRepos->shouldReceive('hasRole')->andReturn(false);
$repository->shouldReceive('create')->andReturn($job);
$path = resource_path('stubs/csv.csv');
$file = new UploadedFile($path, 'upload.csv', filesize($path), 'text/csv', null, true);
$configPath = resource_path('stubs/demo-configuration.json');
$configFile = new UploadedFile($path, 'configuration.json', filesize($configPath), 'application/json', null, true);
$this->be($this->user());
$response = $this->post(route('import.upload'), ['import_file_type' => 'csv', 'import_file' => $file, 'configuration_file' => $configFile]);
$response->assertStatus(302);
}
} }

View File

@@ -132,6 +132,8 @@ class TagControllerTest extends TestCase
$repository->shouldReceive('lastUseDate')->andReturn(new Carbon)->once(); $repository->shouldReceive('lastUseDate')->andReturn(new Carbon)->once();
$repository->shouldReceive('earnedInPeriod')->andReturn('1')->once(); $repository->shouldReceive('earnedInPeriod')->andReturn('1')->once();
$collector->shouldReceive('removeFilter')->andReturnSelf()->times(3);
$collector->shouldReceive('setAllAssetAccounts')->andReturnSelf()->times(3); $collector->shouldReceive('setAllAssetAccounts')->andReturnSelf()->times(3);
$collector->shouldReceive('setLimit')->andReturnSelf()->times(3); $collector->shouldReceive('setLimit')->andReturnSelf()->times(3);
$collector->shouldReceive('setPage')->andReturnSelf()->times(3); $collector->shouldReceive('setPage')->andReturnSelf()->times(3);
@@ -165,6 +167,7 @@ class TagControllerTest extends TestCase
$repository->shouldReceive('earnedInPeriod')->andReturn('1')->once(); $repository->shouldReceive('earnedInPeriod')->andReturn('1')->once();
$repository->shouldReceive('sumOfTag')->andReturn('1')->once(); $repository->shouldReceive('sumOfTag')->andReturn('1')->once();
$collector->shouldReceive('removeFilter')->andReturnSelf()->times(3);
$collector->shouldReceive('setAllAssetAccounts')->andReturnSelf()->times(3); $collector->shouldReceive('setAllAssetAccounts')->andReturnSelf()->times(3);
$collector->shouldReceive('setLimit')->andReturnSelf()->times(3); $collector->shouldReceive('setLimit')->andReturnSelf()->times(3);
$collector->shouldReceive('setPage')->andReturnSelf()->times(3); $collector->shouldReceive('setPage')->andReturnSelf()->times(3);
@@ -194,6 +197,7 @@ class TagControllerTest extends TestCase
$journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal); $journalRepos->shouldReceive('first')->once()->andReturn(new TransactionJournal);
$repository->shouldReceive('firstUseDate')->andReturn(new Carbon)->once(); $repository->shouldReceive('firstUseDate')->andReturn(new Carbon)->once();
$collector->shouldReceive('removeFilter')->andReturnSelf()->times(3);
$repository->shouldReceive('sumOfTag')->andReturn('1')->once(); $repository->shouldReceive('sumOfTag')->andReturn('1')->once();
$collector->shouldReceive('setAllAssetAccounts')->andReturnSelf()->times(3); $collector->shouldReceive('setAllAssetAccounts')->andReturnSelf()->times(3);
$collector->shouldReceive('setLimit')->andReturnSelf()->times(3); $collector->shouldReceive('setLimit')->andReturnSelf()->times(3);