mirror of
https://github.com/snipe/snipe-it.git
synced 2025-03-05 20:52:15 -08:00
adds testing to unaccepted reminder command
This commit is contained in:
parent
281ff6ad5d
commit
97398f1e68
|
@ -65,14 +65,15 @@ class SendAcceptanceReminder extends Command
|
||||||
return $item['acceptance']->assignedTo ? $item['acceptance']->assignedTo->id : '';
|
return $item['acceptance']->assignedTo ? $item['acceptance']->assignedTo->id : '';
|
||||||
});
|
});
|
||||||
|
|
||||||
$no_mail_address = [];
|
|
||||||
|
|
||||||
foreach($unacceptedAssetGroups as $unacceptedAssetGroup) {
|
foreach($unacceptedAssetGroups as $unacceptedAssetGroup) {
|
||||||
// The [0] is weird, but it allows for the item_count to work and grabs the appropriate info for each user.
|
// The [0] is weird, but it allows for the item_count to work and grabs the appropriate info for each user.
|
||||||
// Collapsing and flattening the collection doesn't work above.
|
// Collapsing and flattening the collection doesn't work above.
|
||||||
$acceptance = $unacceptedAssetGroup[0]['acceptance'];
|
$acceptance = $unacceptedAssetGroup[0]['acceptance'];
|
||||||
$locale = $acceptance->assignedTo?->locale;
|
$locale = $acceptance->assignedTo?->locale;
|
||||||
$email = $acceptance->assignedTo?->email;
|
$email = $acceptance->assignedTo?->email;
|
||||||
|
if(!$email){
|
||||||
|
$this->info($acceptance->assignedTo->present()->fullName().' has no email address.');
|
||||||
|
}
|
||||||
$item_count = $unacceptedAssetGroup->count();
|
$item_count = $unacceptedAssetGroup->count();
|
||||||
|
|
||||||
if ($locale && $email) {
|
if ($locale && $email) {
|
||||||
|
@ -84,12 +85,9 @@ class SendAcceptanceReminder extends Command
|
||||||
$count++;
|
$count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($no_mail_address)) {
|
|
||||||
foreach($no_mail_address as $user) {
|
|
||||||
return $user.' has no email.';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->info($count.' users notified.');
|
$this->info($count.' users notified.');
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
53
tests/Feature/Console/SendAcceptanceReminderTest.php
Normal file
53
tests/Feature/Console/SendAcceptanceReminderTest.php
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Feature\Console;
|
||||||
|
|
||||||
|
use App\Mail\UnacceptedAssetReminderMail;
|
||||||
|
use App\Models\CheckoutAcceptance;
|
||||||
|
use App\Models\User;
|
||||||
|
use Illuminate\Support\Facades\Mail;
|
||||||
|
use Tests\TestCase;
|
||||||
|
class SendAcceptanceReminderTest extends TestCase
|
||||||
|
{
|
||||||
|
public function testAcceptanceReminderCommand()
|
||||||
|
{
|
||||||
|
Mail::fake();
|
||||||
|
$userA = User::factory()->create(['email' => 'userA@test.com']);
|
||||||
|
$userB = User::factory()->create(['email' => 'userB@test.com']);
|
||||||
|
|
||||||
|
CheckoutAcceptance::factory()->pending()->count(2)->create([
|
||||||
|
'assigned_to_id' => $userA->id,
|
||||||
|
]);
|
||||||
|
CheckoutAcceptance::factory()->pending()->create([
|
||||||
|
'assigned_to_id' => $userB->id,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->artisan('snipeit:acceptance-reminder')->assertExitCode(0);
|
||||||
|
|
||||||
|
Mail::assertSent(UnacceptedAssetReminderMail::class, function ($mail) {
|
||||||
|
return $mail->hasTo('userA@test.com');
|
||||||
|
});
|
||||||
|
|
||||||
|
Mail::assertSent(UnacceptedAssetReminderMail::class, function ($mail) {
|
||||||
|
return $mail->hasTo('userB@test.com');
|
||||||
|
});
|
||||||
|
|
||||||
|
Mail::assertSent(UnacceptedAssetReminderMail::class,2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAcceptanceReminderCommandHandlesUserWithoutEmail()
|
||||||
|
{
|
||||||
|
Mail::fake();
|
||||||
|
$userA = User::factory()->create(['email' => '']);
|
||||||
|
|
||||||
|
CheckoutAcceptance::factory()->pending()->create([
|
||||||
|
'assigned_to_id' => $userA->id,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->artisan('snipeit:acceptance-reminder')
|
||||||
|
->expectsOutput($userA->present()->fullName().' has no email address.')
|
||||||
|
->assertExitCode(0);
|
||||||
|
|
||||||
|
Mail::assertNotSent(UnacceptedAssetReminderMail::class);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue