added test for recurring

This commit is contained in:
Denis Duliçi 2021-10-09 18:34:37 +03:00
parent 771ae64f0e
commit a2c44a5d2a
5 changed files with 67 additions and 13 deletions

View File

@ -112,11 +112,6 @@ class RecurringCheck extends Command
foreach ($schedules as $schedule) {
$schedule_date = Date::parse($schedule->getStart()->format('Y-m-d'));
// Don't recur the future
if ($schedule_date->greaterThan($today)) {
continue;
}
$this->recur($model, $recur->recurable_type, $schedule_date);
}
}

View File

@ -35,7 +35,7 @@ class SendDocumentRecurringNotification
// Notify all users assigned to this company
foreach ($document->company->users as $user) {
if (!$user->can('read-notifications')) {
if ($user->cannot('read-notifications')) {
continue;
}

View File

@ -87,15 +87,15 @@ trait Recurring
->setFreq($this->getRecurringRuleFrequency())
->setInterval($this->getRecurringRuleInterval());
if ($set_until_date) {
$rule->setUntil($this->getRecurringRuleUntilDate());
}
// 0 means infinite
if ($this->count != 0) {
$rule->setCount($this->getRecurringRuleCount());
}
if ($set_until_date) {
$rule->setUntil($this->getRecurringRuleUntilDate());
}
return $rule;
}

View File

@ -203,10 +203,9 @@ class Document extends AbstractFactory
public function recurring()
{
return $this->state([
'recurring_frequency' => 'yes',
'recurring_frequency' => 'daily',
'recurring_interval' => '1',
'recurring_custom_frequency' => $this->faker->randomElement(['monthly', 'weekly']),
'recurring_count' => '1',
'recurring_count' => '7',
]);
}

View File

@ -0,0 +1,60 @@
<?php
namespace Tests\Feature\Commands;
use App\Jobs\Document\CreateDocument;
use App\Models\Document\Document;
use App\Notifications\Sale\Invoice as InvoiceNotification;
use App\Utilities\Date;
use Illuminate\Support\Facades\Notification;
use Tests\Feature\FeatureTestCase;
class RecurringCheckTest extends FeatureTestCase
{
public $recurring_count;
protected function setUp(): void
{
parent::setUp();
$this->recurring_count = 7;
}
public function testItShouldCreateCorrectNumberOfRecurringInvoices(): void
{
Notification::fake();
$this->dispatch(new CreateDocument($this->getRequest()));
Date::setTestNow(Date::now());
$this->artisan('recurring:check');
$this->assertDatabaseCount('documents', $this->recurring_count + 1);
Notification::assertSentToTimes($this->user, InvoiceNotification::class, $this->recurring_count);
}
public function testItShouldNotCreateAnyRecurringInvoice(): void
{
Notification::fake();
$this->dispatch(new CreateDocument($this->getRequest()));
Date::setTestNow(Date::now()->subDays($this->recurring_count + 1));
$this->artisan('recurring:check');
$this->assertDatabaseCount('documents', 1);
Notification::assertNotSentTo($this->user, InvoiceNotification::class);
}
public function getRequest(): array
{
return Document::factory()->invoice()->items()->recurring()->sent()->raw([
'issued_at' => Date::now()->subDays($this->recurring_count + 1),
'recurring_count' => '20',
]);
}
}