Expand test coverage.

This commit is contained in:
James Cole
2018-01-05 17:29:42 +01:00
parent c329ffa545
commit 3e9f98b43e
24 changed files with 1150 additions and 93 deletions

View File

@@ -32,6 +32,7 @@ class AmountTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Converter\Amount::convert()
* @covers \FireflyIII\Import\Converter\Amount::stripAmount()
*/
public function testConvert()
{

View File

@@ -0,0 +1,300 @@
<?php
/**
* CsvProcessorTest.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\Unit\Import\FileProcessor;
use FireflyIII\Import\FileProcessor\CsvProcessor;
use FireflyIII\Import\Specifics\AbnAmroDescription;
use FireflyIII\Models\ImportJob;
use FireflyIII\Repositories\ImportJob\ImportJobRepositoryInterface;
use Mockery;
use Tests\TestCase;
/**
* Class CsvProcessorTest
*/
class CsvProcessorTest extends TestCase
{
/**
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::__construct
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getObjects
* @expectedException \FireflyIII\Exceptions\FireflyException
* @expectedExceptionMessage Cannot call getObjects() without a job.
*/
public function testGetObjectsNoJob()
{
$processor = new CsvProcessor();
$processor->getObjects();
}
/**
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::run
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getImportArray
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getObjects
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::setJob
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::importRow
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::specifics
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getRowHash
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::annotateValue
* @expectedException \FireflyIII\Exceptions\FireflyException
* @expectedExceptionMessage "bad-role" is not a valid role.
*/
public function testRunBadRole()
{
// data
$config = [
'column-roles' => [
0 => 'bad-role',
],
];
$job = $this->getJob($config);
$csvFile = '20170101,-12.34,"Some description"';
// mock stuff
$repository = $this->mock(ImportJobRepositoryInterface::class);
$repository->shouldReceive('setUser')->withArgs([Mockery::any()])->once();
$repository->shouldReceive('getConfiguration')->andReturn($config);
$repository->shouldReceive('uploadFileContents')->withArgs([Mockery::any()])->andReturn($csvFile)->once();
$repository->shouldReceive('getExtendedStatus')->once()->andReturn([]);
$repository->shouldReceive('setExtendedStatus')->once()->andReturn($job);
// mock stuff for this single row:
$repository->shouldReceive('countByHash')->once()->withArgs([Mockery::any()])->andReturn(0);
$processor = new CsvProcessor();
$processor->setJob($job);
$processor->run();
}
/**
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::run
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getImportArray
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getObjects
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::setJob
*/
public function testRunBasic()
{
// data
$config = [];
$job = $this->getJob($config);
$csvFile = '';
// mock stuff
$repository = $this->mock(ImportJobRepositoryInterface::class);
$repository->shouldReceive('setUser')->withArgs([Mockery::any()])->once();
$repository->shouldReceive('getConfiguration')->andReturn($config);
$repository->shouldReceive('uploadFileContents')->withArgs([Mockery::any()])->andReturn($csvFile)->once();
$repository->shouldReceive('getExtendedStatus')->once()->andReturn([]);
$repository->shouldReceive('setExtendedStatus')->once()->andReturn($job);
$processor = new CsvProcessor();
$processor->setJob($job);
$processor->run();
$objects = $processor->getObjects();
$this->assertCount(0, $objects);
}
/**
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::run
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getImportArray
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getObjects
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::setJob
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::importRow
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::specifics
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getRowHash
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::annotateValue
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::rowAlreadyImported
*/
public function testRunExisting()
{
// data
$config = [];
$job = $this->getJob($config);
$csvFile = '20170101,-12.34,"Some description"';
// mock stuff
$repository = $this->mock(ImportJobRepositoryInterface::class);
$repository->shouldReceive('setUser')->withArgs([Mockery::any()])->once();
$repository->shouldReceive('getConfiguration')->andReturn($config);
$repository->shouldReceive('uploadFileContents')->withArgs([Mockery::any()])->andReturn($csvFile)->once();
$repository->shouldReceive('getExtendedStatus')->twice()->andReturn([]); // twice for update errors.
$repository->shouldReceive('setExtendedStatus')->twice()->andReturn($job);
// mock stuff for this single row:
$repository->shouldReceive('countByHash')->once()->withArgs([Mockery::any()])->andReturn(1);
$repository->shouldReceive('addStepsDone')->once()->withArgs([Mockery::any(), 5]);
$processor = new CsvProcessor();
$processor->setJob($job);
$processor->run();
$objects = $processor->getObjects();
$this->assertCount(0, $objects);
}
/**
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::run
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getImportArray
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getObjects
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::setJob
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::importRow
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::specifics
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getRowHash
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::annotateValue
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::rowAlreadyImported
* @expectedException \FireflyIII\Exceptions\FireflyException
* @expectedExceptionMessage "GoodBankDescription" is not a valid class name
*/
public function testRunInvalidSpecific()
{
// data
$config = [
'specifics' => ['GoodBankDescription' => 1],
];
$job = $this->getJob($config);
$csvFile = '20170101,-12.34,descr';
$row = explode(',', $csvFile);
// mock stuff
$repository = $this->mock(ImportJobRepositoryInterface::class);
$repository->shouldReceive('setUser')->withArgs([Mockery::any()])->once();
$repository->shouldReceive('getConfiguration')->andReturn($config);
$repository->shouldReceive('uploadFileContents')->withArgs([Mockery::any()])->andReturn($csvFile)->once();
$repository->shouldReceive('getExtendedStatus')->once()->andReturn([]);
$repository->shouldReceive('setExtendedStatus')->once()->andReturn($job);
// mock stuff for this single row:
$repository->shouldReceive('countByHash')->once()->withArgs([Mockery::any()])->andReturn(0);
// mock specific:
$processor = new CsvProcessor();
$processor->setJob($job);
$processor->run();
}
/**
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::run
* @expectedException \FireflyIII\Exceptions\FireflyException
* @expectedExceptionMessage Cannot call run() without a job.
*/
public function testRunNoJob()
{
$processor = new CsvProcessor();
$processor->run();
}
/**
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::run
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getImportArray
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getObjects
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::setJob
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::importRow
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::specifics
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getRowHash
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::annotateValue
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::rowAlreadyImported
*/
public function testRunSingle()
{
// data
$config = [];
$job = $this->getJob($config);
$csvFile = '20170101,-12.34,"Some description"';
// mock stuff
$repository = $this->mock(ImportJobRepositoryInterface::class);
$repository->shouldReceive('setUser')->withArgs([Mockery::any()])->once();
$repository->shouldReceive('getConfiguration')->andReturn($config);
$repository->shouldReceive('uploadFileContents')->withArgs([Mockery::any()])->andReturn($csvFile)->once();
$repository->shouldReceive('getExtendedStatus')->once()->andReturn([]);
$repository->shouldReceive('setExtendedStatus')->once()->andReturn($job);
// mock stuff for this single row:
$repository->shouldReceive('countByHash')->once()->withArgs([Mockery::any()])->andReturn(0);
$repository->shouldReceive('addStepsDone')->once()->withArgs([Mockery::any(), 1]);
$processor = new CsvProcessor();
$processor->setJob($job);
$processor->run();
$objects = $processor->getObjects();
$this->assertCount(1, $objects);
}
/**
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::run
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getImportArray
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getObjects
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::setJob
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::importRow
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::specifics
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::getRowHash
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::annotateValue
* @covers \FireflyIII\Import\FileProcessor\CsvProcessor::rowAlreadyImported
*/
public function testRunSpecific()
{
// data
$config = [
'specifics' => ['AbnAmroDescription' => 1],
];
$job = $this->getJob($config);
$csvFile = '20170101,-12.34,descr';
$row = explode(',', $csvFile);
// mock stuff
$repository = $this->mock(ImportJobRepositoryInterface::class);
$repository->shouldReceive('setUser')->withArgs([Mockery::any()])->once();
$repository->shouldReceive('getConfiguration')->andReturn($config);
$repository->shouldReceive('uploadFileContents')->withArgs([Mockery::any()])->andReturn($csvFile)->once();
$repository->shouldReceive('getExtendedStatus')->once()->andReturn([]);
$repository->shouldReceive('setExtendedStatus')->once()->andReturn($job);
// mock stuff for this single row:
$repository->shouldReceive('countByHash')->once()->withArgs([Mockery::any()])->andReturn(0);
$repository->shouldReceive('addStepsDone')->once()->withArgs([Mockery::any(), 1]);
// mock specific:
$specific = $this->mock(AbnAmroDescription::class);
$specific->shouldReceive('run')->once()->andReturn($row);
$processor = new CsvProcessor();
$processor->setJob($job);
$processor->run();
$objects = $processor->getObjects();
$this->assertCount(1, $objects);
}
/**
* @param array $config
*
* @return ImportJob
*/
protected function getJob(array $config): ImportJob
{
$job = new ImportJob;
$job->file_type = 'file';
$job->status = 'new';
$job->key = 'x' . rand(1, 100000);
$job->user()->associate($this->user());
$job->configuration = $config;
return $job;
}
}

View File

@@ -0,0 +1,67 @@
<?php
/**
* AssetAccountIbansTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\AssetAccountIbans;
use FireflyIII\Models\Account;
use FireflyIII\Models\AccountType;
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class AssetAccountIbansTest
*/
class AssetAccountIbansTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\AssetAccountIbans::getMap()
*/
public function testGetMapBasic()
{
$one = new Account;
$one->id = 1;
$one->name = 'Something';
$one->iban = 'IBAN';
$two = new Account;
$two->id = 2;
$two->name = 'Else';
$collection = new Collection([$one, $two]);
$repository = $this->mock(AccountRepositoryInterface::class);
$repository->shouldReceive('getAccountsByType')->withArgs([[AccountType::DEFAULT, AccountType::ASSET]])->andReturn($collection)->once();
$mapper = new AssetAccountIbans();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'IBAN (Something)',
2 => 'Else',
];
$this->assertEquals($result, $mapping);
}
}

View File

@@ -0,0 +1,67 @@
<?php
/**
* AssetAccountsTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\AssetAccounts;
use FireflyIII\Models\Account;
use FireflyIII\Models\AccountType;
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class AssetAccountsTest
*/
class AssetAccountsTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\AssetAccounts::getMap()
*/
public function testGetMapBasic()
{
$one = new Account;
$one->id = 1;
$one->name = 'Something';
$one->iban = 'IBAN';
$two = new Account;
$two->id = 2;
$two->name = 'Else';
$collection = new Collection([$one, $two]);
$repository = $this->mock(AccountRepositoryInterface::class);
$repository->shouldReceive('getAccountsByType')->withArgs([[AccountType::DEFAULT, AccountType::ASSET]])->andReturn($collection)->once();
$mapper = new AssetAccounts();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'Something (IBAN)',
2 => 'Else',
];
$this->assertEquals($result, $mapping);
}
}

View File

@@ -0,0 +1,68 @@
<?php
/**
* BillsTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\Bills;
use FireflyIII\Models\Account;
use FireflyIII\Models\Bill;
use FireflyIII\Repositories\Bill\BillRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class BillsTest
*/
class BillsTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\Bills::getMap()
*/
public function testGetMapBasic()
{
$one = new Bill();
$one->id = 1;
$one->name = 'Something';
$one->match = 'hi,bye';
$two = new Account;
$two->id = 2;
$two->name = 'Else';
$two->match = 'match';
$collection = new Collection([$one, $two]);
$repository = $this->mock(BillRepositoryInterface::class);
$repository->shouldReceive('getBills')->andReturn($collection)->once();
$mapper = new Bills();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'Something [hi,bye]',
2 => 'Else [match]',
];
$this->assertEquals($result, $mapping);
}
}

View File

@@ -0,0 +1,65 @@
<?php
/**
* BudgetsTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\Budgets;
use FireflyIII\Models\Budget;
use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class BudgetsTest
*/
class BudgetsTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\Budgets::getMap()
*/
public function testGetMapBasic()
{
$one = new Budget;
$one->id = 1;
$one->name = 'Something';
$two = new Budget;
$two->id = 2;
$two->name = 'Else';
$collection = new Collection([$one, $two]);
$repository = $this->mock(BudgetRepositoryInterface::class);
$repository->shouldReceive('getActiveBudgets')->andReturn($collection)->once();
$mapper = new Budgets();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'Something',
2 => 'Else',
];
$this->assertEquals($result, $mapping);
}
}

View File

@@ -0,0 +1,65 @@
<?php
/**
* CategoriesTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\Categories;
use FireflyIII\Models\Category;
use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class CategoriesTest
*/
class CategoriesTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\Categories::getMap()
*/
public function testGetMapBasic()
{
$one = new Category;
$one->id = 1;
$one->name = 'Something';
$two = new Category;
$two->id = 2;
$two->name = 'Else';
$collection = new Collection([$one, $two]);
$repository = $this->mock(CategoryRepositoryInterface::class);
$repository->shouldReceive('getCategories')->andReturn($collection)->once();
$mapper = new Categories();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'Something',
2 => 'Else',
];
$this->assertEquals($result, $mapping);
}
}

View File

@@ -0,0 +1,69 @@
<?php
/**
* OpposingAccountIbansTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\OpposingAccountIbans;
use FireflyIII\Models\Account;
use FireflyIII\Models\AccountType;
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class OpposingAccountIbansTest
*/
class OpposingAccountIbansTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\OpposingAccountIbans::getMap()
*/
public function testGetMapBasic()
{
$one = new Account;
$one->id = 1;
$one->name = 'Something';
$one->iban = 'IBAN';
$two = new Account;
$two->id = 2;
$two->name = 'Else';
$collection = new Collection([$one, $two]);
$repository = $this->mock(AccountRepositoryInterface::class);
$repository->shouldReceive('getAccountsByType')->withArgs(
[[AccountType::DEFAULT, AccountType::ASSET, AccountType::EXPENSE, AccountType::BENEFICIARY, AccountType::REVENUE,]]
)->andReturn($collection)->once();
$mapper = new OpposingAccountIbans();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'IBAN (Something)',
2 => 'Else',
];
$this->assertEquals($result, $mapping);
}
}

View File

@@ -0,0 +1,69 @@
<?php
/**
* OpposingAccountsTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\OpposingAccounts;
use FireflyIII\Models\Account;
use FireflyIII\Models\AccountType;
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class OpposingAccountsTest
*/
class OpposingAccountsTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\OpposingAccounts::getMap()
*/
public function testGetMapBasic()
{
$one = new Account;
$one->id = 1;
$one->name = 'Something';
$one->iban = 'IBAN';
$two = new Account;
$two->id = 2;
$two->name = 'Else';
$collection = new Collection([$one, $two]);
$repository = $this->mock(AccountRepositoryInterface::class);
$repository->shouldReceive('getAccountsByType')->withArgs(
[[AccountType::DEFAULT, AccountType::ASSET, AccountType::EXPENSE, AccountType::BENEFICIARY, AccountType::REVENUE,]]
)->andReturn($collection)->once();
$mapper = new OpposingAccounts();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'Something (IBAN)',
2 => 'Else',
];
$this->assertEquals($result, $mapping);
}
}

View File

@@ -0,0 +1,65 @@
<?php
/**
* TagsTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\Tags;
use FireflyIII\Models\Tag;
use FireflyIII\Repositories\Tag\TagRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class TagsTest
*/
class TagsTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\Tags::getMap()
*/
public function testGetMapBasic()
{
$one = new Tag;
$one->id = 1;
$one->tag = 'Something';
$two = new Tag;
$two->id = 2;
$two->tag = 'Else';
$collection = new Collection([$one, $two]);
$repository = $this->mock(TagRepositoryInterface::class);
$repository->shouldReceive('get')->andReturn($collection)->once();
$mapper = new Tags();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'Something',
2 => 'Else',
];
$this->assertEquals($result, $mapping);
}
}

View File

@@ -0,0 +1,67 @@
<?php
/**
* TransactionCurrenciesTest.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\Unit\Import\Mapper;
use FireflyIII\Import\Mapper\TransactionCurrencies;
use FireflyIII\Models\TransactionCurrency;
use FireflyIII\Repositories\Currency\CurrencyRepositoryInterface;
use Illuminate\Support\Collection;
use Tests\TestCase;
/**
* Class TransactionCurrenciesTest
*/
class TransactionCurrenciesTest extends TestCase
{
/**
* @covers \FireflyIII\Import\Mapper\TransactionCurrencies::getMap()
*/
public function testGetMapBasic()
{
$one = new TransactionCurrency;
$one->id = 1;
$one->name = 'Something';
$one->code = 'ABC';
$two = new TransactionCurrency;
$two->id = 2;
$two->name = 'Else';
$two->code = 'DEF';
$collection = new Collection([$one, $two]);
$repository = $this->mock(CurrencyRepositoryInterface::class);
$repository->shouldReceive('get')->andReturn($collection)->once();
$mapper = new TransactionCurrencies();
$mapping = $mapper->getMap();
$this->assertCount(3, $mapping);
// assert this is what the result looks like:
$result = [
0 => strval(trans('import.map_do_not_map')),
1 => 'Something (ABC)',
2 => 'Else (DEF)',
];
$this->assertEquals($result, $mapping);
}
}