mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-11-03 20:55:05 +00:00 
			
		
		
		
	Test more rule actions.
This commit is contained in:
		@@ -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
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user