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

View File

@ -62,7 +62,7 @@
v-for="day in calendar" v-for="day in calendar"
:key="day.dayOfMonth" :key="day.dayOfMonth"
class="border border-gray-300 text-lg font-semibold text-gray-900 py-4 px-2" 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> <div>
{{ day.dayOfMonth }} {{ day.dayOfMonth }}
@ -98,7 +98,7 @@
v-for="day in calendar" v-for="day in calendar"
:key="day.dayOfMonth" :key="day.dayOfMonth"
class="border border-gray-300" 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 <div
v-if="userVacation.vacations.includes(day.date)" v-if="userVacation.vacations.includes(day.date)"

View File

@ -1,18 +1,33 @@
<?php <?php
declare(strict_types=1); declare(strict_types=1);
namespace Tests\Feature; namespace Tests\Feature;
use Illuminate\Foundation\Testing\DatabaseMigrations; use Illuminate\Foundation\Testing\DatabaseMigrations;
use Illuminate\Support\Carbon; use Illuminate\Support\Carbon;
use Inertia\Testing\AssertableInertia as Assert; use Inertia\Testing\AssertableInertia as Assert;
use Tests\FeatureTestCase; use Tests\FeatureTestCase;
use Toby\Domain\Enums\VacationRequestState; use Toby\Domain\Enums\VacationRequestState;
use Toby\Domain\Enums\VacationType; use Toby\Domain\Enums\VacationType;
use Toby\Domain\PolishHolidaysRetriever;
use Toby\Eloquent\Models\User; use Toby\Eloquent\Models\User;
use Toby\Eloquent\Models\VacationRequest; use Toby\Eloquent\Models\VacationRequest;
use Toby\Eloquent\Models\YearPeriod; use Toby\Eloquent\Models\YearPeriod;
class VacationRequestTest extends FeatureTestCase class VacationRequestTest extends FeatureTestCase
{ {
use DatabaseMigrations; use DatabaseMigrations;
protected PolishHolidaysRetriever $polishHolidaysRetriever;
protected function setUp(): void
{
parent::setUp();
$this->polishHolidaysRetriever = $this->app->make(PolishHolidaysRetriever::class);
}
public function testUserCanSeeVacationRequestsList(): void public function testUserCanSeeVacationRequestsList(): void
{ {
$user = User::factory()->createQuietly(); $user = User::factory()->createQuietly();
@ -35,7 +50,9 @@ class VacationRequestTest extends FeatureTestCase
public function testUserCanCreateVacationRequest(): void public function testUserCanCreateVacationRequest(): void
{ {
$user = User::factory()->createQuietly(); $user = User::factory()->createQuietly();
$currentYearPeriod = YearPeriod::current(); $currentYearPeriod = YearPeriod::current();
$this->actingAs($user) $this->actingAs($user)
->post("/vacation-requests", [ ->post("/vacation-requests", [
"type" => VacationType::VACATION->value, "type" => VacationType::VACATION->value,
@ -83,7 +100,9 @@ class VacationRequestTest extends FeatureTestCase
$currentYearPeriod = YearPeriod::current(); $currentYearPeriod = YearPeriod::current();
$vacationRequest = VacationRequest::factory(["state" => VacationRequestState::WAITING_FOR_ADMINISTRATIVE]) $vacationRequest = VacationRequest::factory([
"state" => VacationRequestState::WAITING_FOR_ADMINISTRATIVE,
])
->for($user) ->for($user)
->for($currentYearPeriod) ->for($currentYearPeriod)
->create(); ->create();
@ -116,6 +135,48 @@ class VacationRequestTest extends FeatureTestCase
"state" => VacationRequestState::REJECTED, "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 public function testUserCannotCreateVacationRequestIfHeHasPendingVacationRequestInThisRange(): void
{ {
$user = User::factory()->createQuietly(); $user = User::factory()->createQuietly();
@ -201,4 +262,4 @@ class VacationRequestTest extends FeatureTestCase
"vacationRequest" => trans("The vacation request cannot be created at the turn of the year."), "vacationRequest" => trans("The vacation request cannot be created at the turn of the year."),
]); ]);
} }
} }

View File

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

View File

@ -1,5 +1,7 @@
<?php <?php
declare(strict_types=1); declare(strict_types=1);
namespace Tests\Unit; namespace Tests\Unit;
use Illuminate\Foundation\Testing\DatabaseMigrations; use Illuminate\Foundation\Testing\DatabaseMigrations;
@ -95,4 +97,4 @@ class VacationRequestStatesTest extends TestCase
$this->assertEquals(VacationRequestState::APPROVED, $vacationRequest->state); $this->assertEquals(VacationRequestState::APPROVED, $vacationRequest->state);
} }
} }