This commit is contained in:
EwelinaLasowy 2022-02-09 11:25:23 +01:00
parent accce6af2b
commit aae3c7fcb2
5 changed files with 92 additions and 29 deletions

View File

@ -73,29 +73,29 @@ class DatabaseSeeder extends Seeder
$yearPeriods = YearPeriod::all();
foreach ($users as $user) {
VacationRequest::factory()
->count(10)
->for($user)
->sequence(fn() => [
"year_period_id" => $yearPeriods->random()->id,
])
->afterCreating(function (VacationRequest $vacationRequest): void {
$days = app(VacationDaysCalculator::class)->calculateDays(
$vacationRequest->yearPeriod,
$vacationRequest->from,
$vacationRequest->to,
);
foreach ($days as $day) {
$vacationRequest->vacations()->create([
"date" => $day,
"user_id" => $vacationRequest->user->id,
]);
}
})
->create();
}
// foreach ($users as $user) {
// VacationRequest::factory()
// ->count(10)
// ->for($user)
// ->sequence(fn() => [
// "year_period_id" => $yearPeriods->random()->id,
// ])
// ->afterCreating(function (VacationRequest $vacationRequest): void {
// $days = app(VacationDaysCalculator::class)->calculateDays(
// $vacationRequest->yearPeriod,
// $vacationRequest->from,
// $vacationRequest->to,
// );
//
// foreach ($days as $day) {
// $vacationRequest->vacations()->create([
// "date" => $day,
// "user_id" => $vacationRequest->user->id,
// ]);
// }
// })
// ->create();
// }
}
protected function generateAvatarsForUsers(Collection $users): void

View File

@ -62,7 +62,7 @@
v-for="day in calendar"
:key="day.dayOfMonth"
class="border border-gray-300 text-lg font-semibold text-gray-900 py-4 px-2"
:class="{ 'bg-blumilk-500 text-white': day.isToday}"
:class="{ 'text-blumilk-600 bg-blumilk-25 font-black': day.isToday}"
>
<div>
{{ day.dayOfMonth }}
@ -98,7 +98,7 @@
v-for="day in calendar"
:key="day.dayOfMonth"
class="border border-gray-300"
:class="{'bg-gray-100': day.isWeekend, 'bg-green-100': day.isHoliday, 'bg-blumilk-200': userVacation.vacations.includes(day.date) }"
:class="{'bg-gray-100': day.isWeekend, 'bg-green-100': day.isHoliday, 'bg-blumilk-500': userVacation.vacations.includes(day.date) }"
>
<div
v-if="userVacation.vacations.includes(day.date)"

View File

@ -1,18 +1,33 @@
<?php
declare(strict_types=1);
namespace Tests\Feature;
use Illuminate\Foundation\Testing\DatabaseMigrations;
use Illuminate\Support\Carbon;
use Inertia\Testing\AssertableInertia as Assert;
use Tests\FeatureTestCase;
use Toby\Domain\Enums\VacationRequestState;
use Toby\Domain\Enums\VacationType;
use Toby\Domain\PolishHolidaysRetriever;
use Toby\Eloquent\Models\User;
use Toby\Eloquent\Models\VacationRequest;
use Toby\Eloquent\Models\YearPeriod;
class VacationRequestTest extends FeatureTestCase
{
use DatabaseMigrations;
protected PolishHolidaysRetriever $polishHolidaysRetriever;
protected function setUp(): void
{
parent::setUp();
$this->polishHolidaysRetriever = $this->app->make(PolishHolidaysRetriever::class);
}
public function testUserCanSeeVacationRequestsList(): void
{
$user = User::factory()->createQuietly();
@ -35,7 +50,9 @@ class VacationRequestTest extends FeatureTestCase
public function testUserCanCreateVacationRequest(): void
{
$user = User::factory()->createQuietly();
$currentYearPeriod = YearPeriod::current();
$this->actingAs($user)
->post("/vacation-requests", [
"type" => VacationType::VACATION->value,
@ -83,7 +100,9 @@ class VacationRequestTest extends FeatureTestCase
$currentYearPeriod = YearPeriod::current();
$vacationRequest = VacationRequest::factory(["state" => VacationRequestState::WAITING_FOR_ADMINISTRATIVE])
$vacationRequest = VacationRequest::factory([
"state" => VacationRequestState::WAITING_FOR_ADMINISTRATIVE,
])
->for($user)
->for($currentYearPeriod)
->create();
@ -116,6 +135,48 @@ class VacationRequestTest extends FeatureTestCase
"state" => VacationRequestState::REJECTED,
]);
}
public function testUserCannotCreateVacationRequestAtWeekend(): void
{
$user = User::factory()->createQuietly();
$currentYearPeriod = YearPeriod::current();
$this->actingAs($user)
->post("/vacation-requests", [
"type" => VacationType::VACATION->value,
"from" => Carbon::create($currentYearPeriod->year, 2, 5)->toDateString(),
"to" => Carbon::create($currentYearPeriod->year, 2, 6)->toDateString(),
"comment" => "Vacation at weekend.",
])
->assertSessionHasErrors([
"vacationRequest" => trans("Vacation needs minimum one day."),
]);
}
public function testUserCannotCreateVacationRequestAtHoliday(): void
{
$user = User::factory()->createQuietly();
$currentYearPeriod = YearPeriod::current();
foreach ($this->polishHolidaysRetriever->getForYearPeriod($currentYearPeriod) as $holiday) {
$currentYearPeriod->holidays()->create([
"name" => $holiday["name"],
"date" => $holiday["date"],
]);
}
$this->actingAs($user)
->post("/vacation-requests", [
"type" => VacationType::VACATION->value,
"from" => Carbon::create($currentYearPeriod->year, 4, 18)->toDateString(),
"to" => Carbon::create($currentYearPeriod->year, 4, 18)->toDateString(),
"comment" => "Vacation at holiday.",
])
->assertSessionHasErrors([
"vacationRequest" => trans("Vacation needs minimum one day."),
]);
}
public function testUserCannotCreateVacationRequestIfHeHasPendingVacationRequestInThisRange(): void
{
$user = User::factory()->createQuietly();

View File

@ -17,7 +17,7 @@ abstract class FeatureTestCase extends BaseTestCase
{
parent::setUp();
Carbon::setTestNow(Carbon::now());
Carbon::setTestNow(Carbon::createFromDate(2022, 1, 1));
$this->createCurrentYearPeriod();
}
}

View File

@ -1,5 +1,7 @@
<?php
declare(strict_types=1);
namespace Tests\Unit;
use Illuminate\Foundation\Testing\DatabaseMigrations;