mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-02-25 18:45:27 -06:00
Test more rule actions.
This commit is contained in:
parent
febe60b3d1
commit
139b3ffab4
@ -25,6 +25,7 @@ namespace FireflyIII\TransactionRules\Actions;
|
|||||||
use FireflyIII\Models\RuleAction;
|
use FireflyIII\Models\RuleAction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use Log;
|
use Log;
|
||||||
|
use DB;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class PrependDescription.
|
* Class PrependDescription.
|
||||||
@ -46,6 +47,8 @@ class PrependDescription implements ActionInterface
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Prepend description with X
|
* Prepend description with X
|
||||||
|
* @codeCoverageIgnore
|
||||||
|
* @deprecated
|
||||||
*
|
*
|
||||||
* @param TransactionJournal $journal
|
* @param TransactionJournal $journal
|
||||||
*
|
*
|
||||||
@ -65,6 +68,8 @@ class PrependDescription implements ActionInterface
|
|||||||
*/
|
*/
|
||||||
public function actOnArray(array $journal): bool
|
public function actOnArray(array $journal): bool
|
||||||
{
|
{
|
||||||
// TODO: Implement actOnArray() method.
|
$description = sprintf('%s%s', $this->action->action_value, $journal['description']);
|
||||||
|
DB::table('transaction_journals')->where('id', $journal['transaction_journal_id'])->limit(1)->update(['description' => $description]);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -74,6 +74,21 @@ class PrependNotes implements ActionInterface
|
|||||||
*/
|
*/
|
||||||
public function actOnArray(array $journal): bool
|
public function actOnArray(array $journal): bool
|
||||||
{
|
{
|
||||||
// TODO: Implement actOnArray() method.
|
$dbNote = Note
|
||||||
|
::
|
||||||
|
where('noteable_id', (int) $journal['transaction_journal_id'])
|
||||||
|
->where('noteable_type', TransactionJournal::class)
|
||||||
|
->first(['notes.*']);
|
||||||
|
if (null === $dbNote) {
|
||||||
|
$dbNote = new Note;
|
||||||
|
$dbNote->noteable_id = (int) $journal['transaction_journal_id'];
|
||||||
|
$dbNote->noteable_type = TransactionJournal::class;
|
||||||
|
$dbNote->text = '';
|
||||||
|
}
|
||||||
|
Log::debug(sprintf('RuleAction PrependNotes prepended "%s" to "%s".', $this->action->action_value, $dbNote->text));
|
||||||
|
$text = sprintf('%s%s', $this->action->action_value, $dbNote->text);
|
||||||
|
$dbNote->text = $text;
|
||||||
|
$dbNote->save();
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,8 @@ namespace FireflyIII\TransactionRules\Actions;
|
|||||||
use FireflyIII\Models\RuleAction;
|
use FireflyIII\Models\RuleAction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use Log;
|
use Log;
|
||||||
|
use DB;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class RemoveAllTags.
|
* Class RemoveAllTags.
|
||||||
@ -44,7 +46,8 @@ class RemoveAllTags implements ActionInterface
|
|||||||
* Remove all tags
|
* Remove all tags
|
||||||
*
|
*
|
||||||
* @param TransactionJournal $journal
|
* @param TransactionJournal $journal
|
||||||
*
|
* @deprecated
|
||||||
|
* @codeCoverageIgnore
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
public function act(TransactionJournal $journal): bool
|
public function act(TransactionJournal $journal): bool
|
||||||
@ -61,6 +64,9 @@ class RemoveAllTags implements ActionInterface
|
|||||||
*/
|
*/
|
||||||
public function actOnArray(array $journal): bool
|
public function actOnArray(array $journal): bool
|
||||||
{
|
{
|
||||||
// TODO: Implement actOnArray() method.
|
Log::debug(sprintf('RuleAction ClearCategory removed all tags from journal %d.', $journal['transaction_journal_id']));
|
||||||
|
DB::table('tag_transaction_journal')->where('transaction_journal_id', $journal['transaction_journal_id'])->delete();
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,15 +24,15 @@ namespace FireflyIII\TransactionRules\Actions;
|
|||||||
|
|
||||||
use FireflyIII\Models\RuleAction;
|
use FireflyIII\Models\RuleAction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
|
use FireflyIII\User;
|
||||||
use Log;
|
use Log;
|
||||||
|
use DB;
|
||||||
/**
|
/**
|
||||||
* Class RemoveTag.
|
* Class RemoveTag.
|
||||||
*/
|
*/
|
||||||
class RemoveTag implements ActionInterface
|
class RemoveTag implements ActionInterface
|
||||||
{
|
{
|
||||||
/** @var RuleAction The rule action */
|
private RuleAction $action;
|
||||||
private $action;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TriggerInterface constructor.
|
* TriggerInterface constructor.
|
||||||
@ -46,7 +46,8 @@ class RemoveTag implements ActionInterface
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove tag X
|
* Remove tag X
|
||||||
*
|
* @deprecated
|
||||||
|
* @codeCoverageIgnore
|
||||||
* @param TransactionJournal $journal
|
* @param TransactionJournal $journal
|
||||||
*
|
*
|
||||||
* @return bool
|
* @return bool
|
||||||
@ -74,6 +75,22 @@ class RemoveTag implements ActionInterface
|
|||||||
*/
|
*/
|
||||||
public function actOnArray(array $journal): bool
|
public function actOnArray(array $journal): bool
|
||||||
{
|
{
|
||||||
// TODO: Implement actOnArray() method.
|
// if tag does not exist, no need to continue:
|
||||||
|
$name = $this->action->action_value;
|
||||||
|
$user = User::find($journal['user_id']);
|
||||||
|
$tag = $user->tags()->where('tag', $name)->first();
|
||||||
|
|
||||||
|
if (null !== $tag) {
|
||||||
|
Log::debug(sprintf('RuleAction RemoveTag removed tag #%d ("%s") from journal #%d.', $tag->id, $tag->tag, $journal['transaction_journal_id']));
|
||||||
|
DB::table('tag_transaction_journal')
|
||||||
|
->where('transaction_journal_id', $journal['transaction_journal_id'])
|
||||||
|
->where('tag_id', $tag->id)
|
||||||
|
->delete();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
Log::debug(sprintf('RuleAction RemoveTag tried to remove tag "%s" from journal #%d but no such tag exists.', $name, $journal['transaction_journal_id']));
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,15 +25,16 @@ namespace FireflyIII\TransactionRules\Actions;
|
|||||||
use FireflyIII\Models\RuleAction;
|
use FireflyIII\Models\RuleAction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use FireflyIII\Models\TransactionType;
|
use FireflyIII\Models\TransactionType;
|
||||||
|
use FireflyIII\User;
|
||||||
use Log;
|
use Log;
|
||||||
|
use DB;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class SetBudget.
|
* Class SetBudget.
|
||||||
*/
|
*/
|
||||||
class SetBudget implements ActionInterface
|
class SetBudget implements ActionInterface
|
||||||
{
|
{
|
||||||
/** @var RuleAction The rule action */
|
private RuleAction $action;
|
||||||
private $action;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TriggerInterface constructor.
|
* TriggerInterface constructor.
|
||||||
@ -49,7 +50,8 @@ class SetBudget implements ActionInterface
|
|||||||
* Set budget.
|
* Set budget.
|
||||||
*
|
*
|
||||||
* @param TransactionJournal $journal
|
* @param TransactionJournal $journal
|
||||||
*
|
* @deprecated
|
||||||
|
* @codeCoverageIgnore
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
public function act(TransactionJournal $journal): bool
|
public function act(TransactionJournal $journal): bool
|
||||||
@ -89,6 +91,34 @@ class SetBudget implements ActionInterface
|
|||||||
*/
|
*/
|
||||||
public function actOnArray(array $journal): bool
|
public function actOnArray(array $journal): bool
|
||||||
{
|
{
|
||||||
// TODO: Implement actOnArray() method.
|
$user = User::find($journal['user_id']);
|
||||||
|
$search = $this->action->action_value;
|
||||||
|
|
||||||
|
$budget = $user->budgets()->where('name', $search)->first();
|
||||||
|
if (null === $budget) {
|
||||||
|
Log::debug(sprintf('RuleAction SetBudget could not set budget of journal #%d to "%s" because no such budget exists.', $journal['transaction_journal_id'], $search));
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (TransactionType::WITHDRAWAL !== $journal['transaction_type_type']) {
|
||||||
|
Log::debug(
|
||||||
|
sprintf(
|
||||||
|
'RuleAction SetBudget could not set budget of journal #%d to "%s" because journal is a %s.',
|
||||||
|
$journal['transaction_journal_id'],
|
||||||
|
$search,
|
||||||
|
$journal['transaction_type_type']
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
Log::debug(sprintf('RuleAction SetBudget set the budget of journal #%d to budget #%d ("%s").', $journal['transaction_journal_id'], $budget->id, $budget->name));
|
||||||
|
|
||||||
|
DB::table('budget_transaction_journal')->where('transaction_journal_id', '=', $journal['transaction_journal_id'])->delete();
|
||||||
|
DB::table('budget_transaction_journal')->insert(['transaction_journal_id' => $journal['transaction_journal_id'], 'budget_id' => $budget->id]);
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,15 +25,17 @@ namespace FireflyIII\TransactionRules\Actions;
|
|||||||
use FireflyIII\Factory\CategoryFactory;
|
use FireflyIII\Factory\CategoryFactory;
|
||||||
use FireflyIII\Models\RuleAction;
|
use FireflyIII\Models\RuleAction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
|
use FireflyIII\Models\TransactionType;
|
||||||
|
use FireflyIII\User;
|
||||||
use Log;
|
use Log;
|
||||||
|
use DB;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class SetCategory.
|
* Class SetCategory.
|
||||||
*/
|
*/
|
||||||
class SetCategory implements ActionInterface
|
class SetCategory implements ActionInterface
|
||||||
{
|
{
|
||||||
/** @var RuleAction The rule action */
|
private RuleAction $action;
|
||||||
private $action;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TriggerInterface constructor.
|
* TriggerInterface constructor.
|
||||||
@ -49,7 +51,8 @@ class SetCategory implements ActionInterface
|
|||||||
* Set category X
|
* Set category X
|
||||||
*
|
*
|
||||||
* @param TransactionJournal $journal
|
* @param TransactionJournal $journal
|
||||||
*
|
* @deprecated
|
||||||
|
* @codeCoverageIgnore
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
public function act(TransactionJournal $journal): bool
|
public function act(TransactionJournal $journal): bool
|
||||||
@ -78,6 +81,21 @@ class SetCategory implements ActionInterface
|
|||||||
*/
|
*/
|
||||||
public function actOnArray(array $journal): bool
|
public function actOnArray(array $journal): bool
|
||||||
{
|
{
|
||||||
// TODO: Implement actOnArray() method.
|
$user = User::find($journal['user_id']);
|
||||||
|
$search = $this->action->action_value;
|
||||||
|
|
||||||
|
$category = $user->categories()->where('name', $search)->first();
|
||||||
|
if (null === $category) {
|
||||||
|
Log::debug(sprintf('RuleAction SetCategory could not set category of journal #%d to "%s" because no such category exists.', $journal['transaction_journal_id'], $search));
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
Log::debug(sprintf('RuleAction SetCategory set the category of journal #%d to category #%d ("%s").', $journal['transaction_journal_id'], $category->id, $category->name));
|
||||||
|
|
||||||
|
DB::table('category_transaction_journal')->where('transaction_journal_id', '=', $journal['transaction_journal_id'])->delete();
|
||||||
|
DB::table('category_transaction_journal')->insert(['transaction_journal_id' => $journal['transaction_journal_id'], 'category_id' => $category->id]);
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ class AppendDescriptionTest extends TestCase
|
|||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\AppendDescription
|
* @covers \FireflyIII\TransactionRules\Actions\AppendDescription
|
||||||
*/
|
*/
|
||||||
public function testActExistingTag(): void
|
public function testAct(): void
|
||||||
{
|
{
|
||||||
/** @var TransactionJournal $journal */
|
/** @var TransactionJournal $journal */
|
||||||
$journal = $this->user()->transactionJournals()->where('description', 'Rule action test transaction.')->first();
|
$journal = $this->user()->transactionJournals()->where('description', 'Rule action test transaction.')->first();
|
||||||
|
@ -37,9 +37,6 @@ use Tests\TestCase;
|
|||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* Class ConvertToTransferTest
|
* Class ConvertToTransferTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class ConvertToTransferTest extends TestCase
|
class ConvertToTransferTest extends TestCase
|
||||||
{
|
{
|
||||||
|
@ -38,9 +38,6 @@ use Tests\TestCase;
|
|||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* Class ConvertToWithdrawalTest
|
* Class ConvertToWithdrawalTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class ConvertToWithdrawalTest extends TestCase
|
class ConvertToWithdrawalTest extends TestCase
|
||||||
{
|
{
|
||||||
|
@ -24,47 +24,40 @@ namespace Tests\Unit\TransactionRules\Actions;
|
|||||||
|
|
||||||
use FireflyIII\Models\RuleAction;
|
use FireflyIII\Models\RuleAction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
|
use FireflyIII\TransactionRules\Actions\AppendDescription;
|
||||||
use FireflyIII\TransactionRules\Actions\PrependDescription;
|
use FireflyIII\TransactionRules\Actions\PrependDescription;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class PrependDescriptionTest
|
* Class PrependDescriptionTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class PrependDescriptionTest extends TestCase
|
class PrependDescriptionTest extends TestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Set up test
|
|
||||||
*/
|
|
||||||
public function setUp(): void
|
|
||||||
{
|
|
||||||
self::markTestIncomplete('Incomplete for refactor.');
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\PrependDescription
|
* @covers \FireflyIII\TransactionRules\Actions\PrependDescription
|
||||||
*/
|
*/
|
||||||
public function testAct(): void
|
public function testAct(): void
|
||||||
{
|
{
|
||||||
// get journal, give fixed description
|
/** @var TransactionJournal $journal */
|
||||||
$description = 'text' . $this->randomInt();
|
$journal = $this->user()->transactionJournals()->where('description', 'Rule action test transaction.')->first();
|
||||||
$prepend = 'prepend' . $this->randomInt();
|
$original = $journal->description;
|
||||||
$journal = $this->getRandomWithdrawal();
|
|
||||||
$journal->description = $description;
|
|
||||||
$journal->save();
|
$array = [
|
||||||
|
'transaction_journal_id' => $journal->id,
|
||||||
|
'description' => $original,
|
||||||
|
];
|
||||||
|
|
||||||
// fire the action:
|
|
||||||
$ruleAction = new RuleAction;
|
$ruleAction = new RuleAction;
|
||||||
$ruleAction->action_value = $prepend;
|
$ruleAction->action_value = 'PREPEND';
|
||||||
$action = new PrependDescription($ruleAction);
|
$action = new PrependDescription($ruleAction);
|
||||||
$result = $action->act($journal);
|
$result = $action->actOnArray($array);
|
||||||
$this->assertTrue($result);
|
$this->assertTrue($result);
|
||||||
$journal = TransactionJournal::find($journal->id);
|
|
||||||
|
|
||||||
// assert result
|
$journal = TransactionJournal::find($journal->id);
|
||||||
$this->assertEquals($prepend . $description, $journal->description);
|
$this->assertEquals(sprintf('%s%s', $ruleAction->action_value, $original), $journal->description);
|
||||||
|
|
||||||
|
$journal->description = $original;
|
||||||
|
$journal->save();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -27,74 +27,40 @@ use FireflyIII\Models\RuleAction;
|
|||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use FireflyIII\TransactionRules\Actions\PrependNotes;
|
use FireflyIII\TransactionRules\Actions\PrependNotes;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
use DB;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class PrependNotesTest
|
* Class PrependNotesTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
* TODO doesnt test if prepends or appends.
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class PrependNotesTest extends TestCase
|
class PrependNotesTest extends TestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Set up test
|
|
||||||
*/
|
|
||||||
public function setUp(): void
|
|
||||||
{
|
|
||||||
self::markTestIncomplete('Incomplete for refactor.');
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\PrependNotes
|
* @covers \FireflyIII\TransactionRules\Actions\PrependNotes
|
||||||
*/
|
*/
|
||||||
public function testAct(): void
|
public function testAct(): void
|
||||||
{
|
{
|
||||||
// give journal some notes.
|
// give journal some notes.
|
||||||
$journal = $this->getRandomWithdrawal();
|
$journal = $this->user()->transactionJournals()->where('description','Rule action note test transaction.')->first();
|
||||||
$note = $journal->notes()->first();
|
|
||||||
$start = 'Default note text';
|
// make sure all notes deleted:
|
||||||
$toPrepend = 'This is prepended';
|
DB::table('notes')->where('noteable_id', $journal->id)->where('noteable_type', TransactionJournal::class)->delete();
|
||||||
if (null === $note) {
|
|
||||||
$note = new Note();
|
// array for action:
|
||||||
$note->noteable()->associate($journal);
|
$array = [
|
||||||
}
|
'transaction_journal_id' => $journal->id
|
||||||
$note->text = $start;
|
];
|
||||||
$note->save();
|
$toAppend = 'Text to append to note.';
|
||||||
|
|
||||||
// fire the action:
|
// fire the action:
|
||||||
$ruleAction = new RuleAction;
|
$ruleAction = new RuleAction;
|
||||||
$ruleAction->action_value = $toPrepend;
|
$ruleAction->action_value = $toAppend;
|
||||||
$action = new PrependNotes($ruleAction);
|
$action = new PrependNotes($ruleAction);
|
||||||
$result = $action->act($journal);
|
$result = $action->actOnArray($array);
|
||||||
$this->assertTrue($result);
|
$this->assertTrue($result);
|
||||||
|
|
||||||
$newNote = $journal->notes()->first();
|
$newNote = $journal->notes()->first();
|
||||||
$this->assertEquals($toPrepend . $start, $newNote->text);
|
$this->assertEquals($toAppend, $newNote->text);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\PrependNotes
|
|
||||||
*/
|
|
||||||
public function testActNewNote(): void
|
|
||||||
{
|
|
||||||
// give journal some notes.
|
|
||||||
$journal = $this->getRandomWithdrawal();
|
|
||||||
$note = $journal->notes()->first();
|
|
||||||
if (null !== $note) {
|
|
||||||
$note->forceDelete();
|
|
||||||
}
|
|
||||||
$toPrepend = 'This is appended';
|
|
||||||
|
|
||||||
// fire the action:
|
|
||||||
$ruleAction = new RuleAction;
|
|
||||||
$ruleAction->action_value = $toPrepend;
|
|
||||||
$action = new PrependNotes($ruleAction);
|
|
||||||
$result = $action->act($journal);
|
|
||||||
$this->assertTrue($result);
|
|
||||||
|
|
||||||
$newNote = $journal->notes()->first();
|
|
||||||
$this->assertEquals($toPrepend, $newNote->text);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -22,48 +22,37 @@ declare(strict_types=1);
|
|||||||
|
|
||||||
namespace Tests\Unit\TransactionRules\Actions;
|
namespace Tests\Unit\TransactionRules\Actions;
|
||||||
|
|
||||||
use DB;
|
|
||||||
use FireflyIII\Models\RuleAction;
|
use FireflyIII\Models\RuleAction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
|
||||||
use FireflyIII\TransactionRules\Actions\RemoveAllTags;
|
use FireflyIII\TransactionRules\Actions\RemoveAllTags;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class RemoveAllTagsTest
|
* Class RemoveAllTagsTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class RemoveAllTagsTest extends TestCase
|
class RemoveAllTagsTest extends TestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Set up test
|
|
||||||
*/
|
|
||||||
public function setUp(): void
|
|
||||||
{
|
|
||||||
self::markTestIncomplete('Incomplete for refactor.');
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\RemoveAllTags
|
* @covers \FireflyIII\TransactionRules\Actions\RemoveAllTags
|
||||||
*/
|
*/
|
||||||
public function testAct(): void
|
public function testAct(): void
|
||||||
{
|
{
|
||||||
// find journal with at least one tag
|
// find journal
|
||||||
$journalIds = DB::table('tag_transaction_journal')->get(['transaction_journal_id'])->pluck('transaction_journal_id')->toArray();
|
$withdrawal = $this->getRandomWithdrawal();
|
||||||
$journalId = (int)$journalIds[0];
|
$tag = $this->getRandomTag();
|
||||||
/** @var TransactionJournal $journal */
|
|
||||||
$journal = TransactionJournal::find($journalId);
|
$withdrawal->tags()->sync([$tag->id]);
|
||||||
|
|
||||||
|
$array = [
|
||||||
|
'transaction_journal_id' => $withdrawal->id,
|
||||||
|
];
|
||||||
|
|
||||||
// fire the action:
|
// fire the action:
|
||||||
$ruleAction = new RuleAction;
|
$ruleAction = new RuleAction;
|
||||||
$ruleAction->action_value = null;
|
$ruleAction->action_value = null;
|
||||||
$action = new RemoveAllTags($ruleAction);
|
$action = new RemoveAllTags($ruleAction);
|
||||||
$result = $action->act($journal);
|
$result = $action->actOnArray($array);
|
||||||
$this->assertTrue($result);
|
$this->assertTrue($result);
|
||||||
|
|
||||||
$this->assertEquals(0, $journal->tags()->count());
|
$this->assertEquals(0, $withdrawal->tags()->count());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,74 +22,39 @@ declare(strict_types=1);
|
|||||||
|
|
||||||
namespace Tests\Unit\TransactionRules\Actions;
|
namespace Tests\Unit\TransactionRules\Actions;
|
||||||
|
|
||||||
use DB;
|
|
||||||
use FireflyIII\Models\RuleAction;
|
use FireflyIII\Models\RuleAction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
|
||||||
use FireflyIII\TransactionRules\Actions\RemoveTag;
|
use FireflyIII\TransactionRules\Actions\RemoveTag;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class RemoveTagTest
|
* Class RemoveTagTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class RemoveTagTest extends TestCase
|
class RemoveTagTest extends TestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Set up test
|
|
||||||
*/
|
|
||||||
public function setUp(): void
|
|
||||||
{
|
|
||||||
self::markTestIncomplete('Incomplete for refactor.');
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\RemoveTag
|
* @covers \FireflyIII\TransactionRules\Actions\RemoveTag
|
||||||
*/
|
*/
|
||||||
public function testAct(): void
|
public function testAct(): void
|
||||||
{
|
{ // find journal
|
||||||
|
$withdrawal = $this->getRandomWithdrawal();
|
||||||
|
$tag = $this->getRandomTag();
|
||||||
|
|
||||||
|
$withdrawal->tags()->sync([$tag->id]);
|
||||||
|
|
||||||
|
$array = [
|
||||||
|
'transaction_journal_id' => $withdrawal->id,
|
||||||
|
'user_id' => 1,
|
||||||
|
];
|
||||||
|
|
||||||
// find journal with at least one tag
|
|
||||||
$journalIds = DB::table('tag_transaction_journal')->get(['transaction_journal_id'])->pluck('transaction_journal_id')->toArray();
|
|
||||||
$journalId = (int)$journalIds[0];
|
|
||||||
/** @var TransactionJournal $journal */
|
|
||||||
$journal = TransactionJournal::find($journalId);
|
|
||||||
$originalCount = $journal->tags()->count();
|
|
||||||
$firstTag = $journal->tags()->first();
|
|
||||||
|
|
||||||
// fire the action:
|
// fire the action:
|
||||||
$ruleAction = new RuleAction;
|
$ruleAction = new RuleAction;
|
||||||
$ruleAction->action_value = $firstTag->tag;
|
$ruleAction->action_value = $tag->tag;
|
||||||
$action = new RemoveTag($ruleAction);
|
$action = new RemoveTag($ruleAction);
|
||||||
$result = $action->act($journal);
|
$result = $action->actOnArray($array);
|
||||||
$this->assertTrue($result);
|
$this->assertTrue($result);
|
||||||
foreach ($journal->tags()->get() as $tag) {
|
|
||||||
$this->assertNotEquals($firstTag->id, $tag->id);
|
$this->assertEquals(0, $withdrawal->tags()->count());
|
||||||
}
|
|
||||||
$this->assertEquals($originalCount - 1, $journal->tags()->count());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\RemoveTag
|
|
||||||
*/
|
|
||||||
public function testActNoTag(): void
|
|
||||||
{
|
|
||||||
// get journal, link al tags:
|
|
||||||
/** @var TransactionJournal $journal */
|
|
||||||
$journal = $this->getRandomWithdrawal();
|
|
||||||
$tags = $journal->user->tags()->get();
|
|
||||||
$journal->tags()->sync($tags->pluck('id')->toArray());
|
|
||||||
$this->assertEquals($tags->count(), $journal->tags()->get()->count());
|
|
||||||
|
|
||||||
// fire the action:
|
|
||||||
$ruleAction = new RuleAction;
|
|
||||||
$ruleAction->action_value = $this->randomInt() . 'nosuchtag';
|
|
||||||
$action = new RemoveTag($ruleAction);
|
|
||||||
$result = $action->act($journal);
|
|
||||||
$this->assertTrue($result);
|
|
||||||
$this->assertEquals($tags->count(), $journal->tags()->count());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -30,21 +30,9 @@ use Tests\TestCase;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Class SetBudgetTest
|
* Class SetBudgetTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class SetBudgetTest extends TestCase
|
class SetBudgetTest extends TestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Set up test
|
|
||||||
*/
|
|
||||||
public function setUp(): void
|
|
||||||
{
|
|
||||||
self::markTestIncomplete('Incomplete for refactor.');
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\SetBudget
|
* @covers \FireflyIII\TransactionRules\Actions\SetBudget
|
||||||
@ -52,9 +40,15 @@ class SetBudgetTest extends TestCase
|
|||||||
public function testAct(): void
|
public function testAct(): void
|
||||||
{
|
{
|
||||||
// get journal, remove all budgets
|
// get journal, remove all budgets
|
||||||
$journal = $this->getRandomWithdrawal();
|
$journal = $this->user()->transactionJournals()->where('description','Groceries with no budget')->first();
|
||||||
$budget = $this->getRandomBudget();
|
$budget = $this->getRandomBudget();
|
||||||
|
|
||||||
|
$array = [
|
||||||
|
'user_id' => $this->user()->id,
|
||||||
|
'transaction_journal_id' => $journal->id,
|
||||||
|
'transaction_type_type' => $journal->transactionType->type,
|
||||||
|
];
|
||||||
|
|
||||||
$journal->budgets()->sync([]);
|
$journal->budgets()->sync([]);
|
||||||
$this->assertEquals(0, $journal->budgets()->count());
|
$this->assertEquals(0, $journal->budgets()->count());
|
||||||
|
|
||||||
@ -62,50 +56,12 @@ class SetBudgetTest extends TestCase
|
|||||||
$ruleAction = new RuleAction;
|
$ruleAction = new RuleAction;
|
||||||
$ruleAction->action_value = $budget->name;
|
$ruleAction->action_value = $budget->name;
|
||||||
$action = new SetBudget($ruleAction);
|
$action = new SetBudget($ruleAction);
|
||||||
$result = $action->act($journal);
|
$result = $action->actOnArray($array);
|
||||||
$this->assertTrue($result);
|
$this->assertTrue($result);
|
||||||
$this->assertEquals(1, $journal->budgets()->count());
|
$this->assertEquals(1, $journal->budgets()->count());
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\SetBudget
|
|
||||||
*/
|
|
||||||
public function testActNull(): void
|
|
||||||
{
|
|
||||||
// get journal, remove all budgets
|
|
||||||
$journal = $this->getRandomWithdrawal();
|
|
||||||
|
|
||||||
$journal->budgets()->sync([]);
|
$journal->budgets()->sync([]);
|
||||||
$this->assertEquals(0, $journal->budgets()->count());
|
$this->assertEquals(0, $journal->budgets()->count());
|
||||||
|
|
||||||
// fire the action:
|
|
||||||
$ruleAction = new RuleAction;
|
|
||||||
$ruleAction->action_value = 'non-existing budget #' . $this->randomInt();
|
|
||||||
$action = new SetBudget($ruleAction);
|
|
||||||
$result = $action->act($journal);
|
|
||||||
$this->assertFalse($result);
|
|
||||||
$this->assertEquals(0, $journal->budgets()->count());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\SetBudget
|
|
||||||
*/
|
|
||||||
public function testActDeposit(): void
|
|
||||||
{
|
|
||||||
// get journal, remove all budgets
|
|
||||||
$journal = $this->getRandomDeposit();
|
|
||||||
$budget = $this->getRandomBudget();
|
|
||||||
|
|
||||||
$journal->budgets()->detach();
|
|
||||||
$this->assertEquals(0, $journal->budgets()->count());
|
|
||||||
|
|
||||||
// fire the action:
|
|
||||||
$ruleAction = new RuleAction;
|
|
||||||
$ruleAction->action_value = $budget->name;
|
|
||||||
$action = new SetBudget($ruleAction);
|
|
||||||
$result = $action->act($journal);
|
|
||||||
$this->assertTrue($result);
|
|
||||||
$this->assertEquals(0, $journal->budgets()->count());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -29,70 +29,36 @@ use Tests\TestCase;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Class SetCategoryTest
|
* Class SetCategoryTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class SetCategoryTest extends TestCase
|
class SetCategoryTest extends TestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Set up test
|
|
||||||
*/
|
|
||||||
public function setUp(): void
|
|
||||||
{
|
|
||||||
self::markTestIncomplete('Incomplete for refactor.');
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\SetCategory
|
* @covers \FireflyIII\TransactionRules\Actions\SetCategory
|
||||||
*/
|
*/
|
||||||
public function testAct(): void
|
public function testAct(): void
|
||||||
{
|
{
|
||||||
// get journal, remove all budgets
|
// get journal, remove all budgets
|
||||||
$journal = $this->getRandomWithdrawal();
|
$journal = $this->user()->transactionJournals()->where('description','Groceries with no category')->first();
|
||||||
$category = $this->getRandomCategory();
|
$category = $this->getRandomCategory();
|
||||||
|
|
||||||
$factory = $this->mock(CategoryFactory::class);
|
$array = [
|
||||||
$factory->shouldReceive('setUser');
|
'user_id' => $this->user()->id,
|
||||||
$factory->shouldReceive('findOrCreate')->andReturn($category);
|
'transaction_journal_id' => $journal->id,
|
||||||
|
'transaction_type_type' => $journal->transactionType->type,
|
||||||
|
];
|
||||||
|
|
||||||
$journal->categories()->detach();
|
$journal->budgets()->sync([]);
|
||||||
$this->assertEquals(0, $journal->categories()->count());
|
$this->assertEquals(0, $journal->categories()->count());
|
||||||
|
|
||||||
// fire the action:
|
// fire the action:
|
||||||
$ruleAction = new RuleAction;
|
$ruleAction = new RuleAction;
|
||||||
$ruleAction->action_value = $category->name;
|
$ruleAction->action_value = $category->name;
|
||||||
$action = new SetCategory($ruleAction);
|
$action = new SetCategory($ruleAction);
|
||||||
$result = $action->act($journal);
|
$result = $action->actOnArray($array);
|
||||||
$this->assertTrue($result);
|
$this->assertTrue($result);
|
||||||
|
|
||||||
$this->assertEquals(1, $journal->categories()->count());
|
$this->assertEquals(1, $journal->categories()->count());
|
||||||
}
|
|
||||||
/**
|
|
||||||
* @covers \FireflyIII\TransactionRules\Actions\SetCategory
|
|
||||||
*/
|
|
||||||
public function testActNull(): void
|
|
||||||
{
|
|
||||||
$factory = $this->mock(CategoryFactory::class);
|
|
||||||
$factory->shouldReceive('setUser');
|
|
||||||
$factory->shouldReceive('findOrCreate')->andReturnNull();
|
|
||||||
|
|
||||||
|
|
||||||
// get journal, remove all budgets
|
|
||||||
$journal = $this->getRandomWithdrawal();
|
|
||||||
$category = $this->getRandomCategory();
|
|
||||||
$journal->categories()->detach();
|
|
||||||
$this->assertEquals(0, $journal->categories()->count());
|
|
||||||
|
|
||||||
// fire the action:
|
|
||||||
$ruleAction = new RuleAction;
|
|
||||||
$ruleAction->action_value = $category->name;
|
|
||||||
$action = new SetCategory($ruleAction);
|
|
||||||
$result = $action->act($journal);
|
|
||||||
$this->assertFalse($result);
|
|
||||||
|
|
||||||
|
$journal->categories()->sync([]);
|
||||||
$this->assertEquals(0, $journal->categories()->count());
|
$this->assertEquals(0, $journal->categories()->count());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,9 +29,6 @@ use Tests\TestCase;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Class SetDescriptionTest
|
* Class SetDescriptionTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class SetDescriptionTest extends TestCase
|
class SetDescriptionTest extends TestCase
|
||||||
{
|
{
|
||||||
|
@ -35,9 +35,6 @@ use Tests\TestCase;
|
|||||||
* Try split journal
|
* Try split journal
|
||||||
*
|
*
|
||||||
* Class SetDestinationAccountTest
|
* Class SetDestinationAccountTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class SetDestinationAccountTest extends TestCase
|
class SetDestinationAccountTest extends TestCase
|
||||||
{
|
{
|
||||||
|
@ -30,9 +30,6 @@ use Tests\TestCase;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Class SetNotesTest
|
* Class SetNotesTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class SetNotesTest extends TestCase
|
class SetNotesTest extends TestCase
|
||||||
{
|
{
|
||||||
|
@ -33,9 +33,6 @@ use Tests\TestCase;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Class SetSourceAccountTest
|
* Class SetSourceAccountTest
|
||||||
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
||||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
||||||
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
||||||
*/
|
*/
|
||||||
class SetSourceAccountTest extends TestCase
|
class SetSourceAccountTest extends TestCase
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user