chore: code refactor via rector

This commit is contained in:
idevakk
2025-11-14 02:01:01 -08:00
parent 90ab79b3a2
commit ae795880ed
148 changed files with 1520 additions and 1486 deletions

View File

@@ -3,14 +3,15 @@
namespace Tests\Feature;
// Simple test to check if Laravel application is working
use Illuminate\Foundation\Application;
use Tests\TestCase;
class ApplicationTest extends TestCase
{
/** @test */
public function it_checks_if_application_is_running()
public function it_checks_if_application_is_running(): void
{
$this->assertInstanceOf(\Illuminate\Foundation\Application::class, $this->app);
$this->assertInstanceOf(Application::class, $this->app);
$this->assertEquals('ZEmailnator', config('app.name'));
}
}

View File

@@ -10,7 +10,7 @@ use Tests\TestCase;
class AppControllerTest extends TestCase
{
/** @test */
public function it_redirects_to_home_when_no_email_exists_in_mailbox()
public function it_redirects_to_home_when_no_email_exists_in_mailbox(): void
{
$response = $this->get('/mailbox');
@@ -18,7 +18,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_creates_custom_email_from_url_when_enabled()
public function it_creates_custom_email_from_url_when_enabled(): void
{
$email = 'custom@example.com';
@@ -28,7 +28,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_validates_email_parameter_in_mailbox_route()
public function it_validates_email_parameter_in_mailbox_route(): void
{
$response = $this->get('/mailbox/invalid-email');
@@ -37,7 +37,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_redirects_to_home_when_mailbox_slug_is_disabled()
public function it_redirects_to_home_when_mailbox_slug_is_disabled(): void
{
Config::set('app.settings.configuration_settings', json_encode([
'disable_mailbox_slug' => true,
@@ -49,7 +49,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_switches_email_successfully()
public function it_switches_email_successfully(): void
{
$email = 'newemail@example.com';
@@ -59,7 +59,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_redirects_to_home_when_switching_email_with_disabled_mailbox_slug()
public function it_redirects_to_home_when_switching_email_with_disabled_mailbox_slug(): void
{
Config::set('app.settings.configuration_settings', json_encode([
'disable_mailbox_slug' => true,
@@ -73,7 +73,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_deletes_email_successfully()
public function it_deletes_email_successfully(): void
{
$email = 'delete@example.com';
@@ -83,7 +83,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_redirects_to_home_when_deleting_email_without_parameter()
public function it_redirects_to_home_when_deleting_email_without_parameter(): void
{
$response = $this->get('/delete');
@@ -91,7 +91,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_switches_locale_successfully()
public function it_switches_locale_successfully(): void
{
$locale = 'es';
@@ -102,7 +102,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_aborts_with_400_for_invalid_locale()
public function it_aborts_with_400_for_invalid_locale(): void
{
$invalidLocale = 'invalid';
@@ -112,7 +112,7 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_redirects_back_after_locale_switch()
public function it_redirects_back_after_locale_switch(): void
{
$locale = 'fr';
@@ -123,12 +123,11 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_handles_get_string_between_method_correctly()
public function it_handles_get_string_between_method_correctly(): void
{
$controller = new AppController;
$reflection = new ReflectionClass($controller);
$method = $reflection->getMethod('getStringBetween');
$method->setAccessible(true);
$string = 'Hello [world] test';
$result = $method->invoke($controller, $string, '[', ']');
@@ -137,12 +136,11 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_handles_get_string_between_with_missing_end()
public function it_handles_get_string_between_with_missing_end(): void
{
$controller = new AppController;
$reflection = new ReflectionClass($controller);
$method = $reflection->getMethod('getStringBetween');
$method->setAccessible(true);
$string = 'Hello [world test';
$result = $method->invoke($controller, $string, '[', ']');
@@ -151,12 +149,11 @@ class AppControllerTest extends TestCase
}
/** @test */
public function it_handles_get_string_between_with_no_match()
public function it_handles_get_string_between_with_no_match(): void
{
$controller = new AppController;
$reflection = new ReflectionClass($controller);
$method = $reflection->getMethod('getStringBetween');
$method->setAccessible(true);
$string = 'Hello world test';
$result = $method->invoke($controller, $string, '[', ']');

View File

@@ -2,6 +2,8 @@
namespace Tests\Feature\Controllers;
use Carbon\Carbon;
use Exception;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Http;
use Illuminate\Support\Facades\Log;
@@ -35,7 +37,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_rejects_webhook_with_invalid_data_type()
public function it_rejects_webhook_with_invalid_data_type(): void
{
$invalidData = [
'type' => 'invalid_type',
@@ -49,7 +51,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_rejects_webhook_with_missing_data_type()
public function it_rejects_webhook_with_missing_data_type(): void
{
$dataWithoutType = [
'email' => 'test@example.com',
@@ -63,7 +65,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_rejects_webhook_with_no_data()
public function it_rejects_webhook_with_no_data(): void
{
$response = $this->postJson('/webhook/oxapay', []);
@@ -72,7 +74,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_rejects_webhook_with_invalid_hmac_signature()
public function it_rejects_webhook_with_invalid_hmac_signature(): void
{
$validData = [
'type' => 'invoice',
@@ -84,7 +86,7 @@ class WebhookControllerTest extends TestCase
'date' => time(),
];
$postData = json_encode($validData);
json_encode($validData);
$invalidHmac = 'invalid_hmac_signature';
$response = $this->postJson('/webhook/oxapay', $validData, [
@@ -96,7 +98,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_processes_valid_invoice_webhook_successfully()
public function it_processes_valid_invoice_webhook_successfully(): void
{
$validData = [
'type' => 'invoice',
@@ -121,7 +123,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_processes_valid_payment_link_webhook_successfully()
public function it_processes_valid_payment_link_webhook_successfully(): void
{
$validData = [
'type' => 'payment_link',
@@ -146,7 +148,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_processes_valid_payout_webhook_successfully()
public function it_processes_valid_payout_webhook_successfully(): void
{
$validData = [
'type' => 'payout',
@@ -173,7 +175,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_handles_webhook_processing_errors_gracefully()
public function it_handles_webhook_processing_errors_gracefully(): void
{
// Use invalid date format to trigger error handling
$validData = [
@@ -201,7 +203,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_logs_invoice_payment_details_correctly()
public function it_logs_invoice_payment_details_correctly(): void
{
$validData = [
'type' => 'invoice',
@@ -227,7 +229,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_logs_payout_details_correctly()
public function it_logs_payout_details_correctly(): void
{
$validData = [
'type' => 'payout',
@@ -255,7 +257,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_logs_invalid_data_warnings()
public function it_logs_invalid_data_warnings(): void
{
$invalidData = [
'type' => 'invalid_type',
@@ -268,7 +270,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_logs_invalid_hmac_signature_warnings()
public function it_logs_invalid_hmac_signature_warnings(): void
{
$validData = [
'type' => 'invoice',
@@ -276,10 +278,7 @@ class WebhookControllerTest extends TestCase
'amount' => '100',
'currency' => 'USD',
];
$postData = json_encode($validData);
$apiSecretKey = 'test_merchant_key';
$validHmac = hash_hmac('sha512', $postData, $apiSecretKey);
json_encode($validData);
$invalidHmac = 'invalid_hmac';
$response = $this->postJson('/webhook/oxapay', $validData, [
@@ -290,7 +289,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_handles_webhook_processing_exceptions()
public function it_handles_webhook_processing_exceptions(): void
{
$validData = [
'type' => 'invoice',
@@ -311,9 +310,9 @@ class WebhookControllerTest extends TestCase
// Telegram notification for error is handled by error logging
// Simulate an exception during processing by mocking a method that gets called
$this->mock(\Carbon\Carbon::class)
$this->mock(Carbon::class)
->shouldReceive('createFromTimestamp')
->andThrow(new \Exception('Date processing error'));
->andThrow(new Exception('Date processing error'));
$response = $this->postJson('/webhook/oxapay', $validData, [
'HMAC' => $validHmac,
@@ -324,7 +323,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_uses_correct_api_key_based_on_webhook_type()
public function it_uses_correct_api_key_based_on_webhook_type(): void
{
$invoiceData = [
'type' => 'invoice',
@@ -364,7 +363,7 @@ class WebhookControllerTest extends TestCase
}
/** @test */
public function it_handles_missing_optional_fields_gracefully()
public function it_handles_missing_optional_fields_gracefully(): void
{
$minimalData = [
'type' => 'invoice',

View File

@@ -16,7 +16,7 @@ class ExampleTest extends TestCase
}
/** @test */
public function the_application_returns_a_successful_response()
public function the_application_returns_a_successful_response(): void
{
$response = $this->get('/');

View File

@@ -2,6 +2,27 @@
namespace Tests\Feature\Filament;
use App\Filament\Resources\TicketResource\Pages\ListTickets;
use App\Filament\Resources\TicketResource\Pages\EditTicket;
use App\Filament\Resources\TicketResource\RelationManagers\ResponsesRelationManager;
use App\Filament\Resources\TicketResource;
use App\Filament\Resources\PlanResource\Pages\ListPlans;
use App\Filament\Resources\PlanResource\Pages\EditPlan;
use App\Filament\Resources\BlogResource\Pages\ListBlogs;
use App\Filament\Resources\BlogResource\Pages\EditBlog;
use App\Filament\Resources\CategoryResource\Pages\ListCategories;
use App\Filament\Resources\CategoryResource\Pages\CreateCategory;
use App\Filament\Resources\CategoryResource\Pages\EditCategory;
use App\Filament\Resources\PageResource\Pages\ListPages;
use App\Filament\Resources\PageResource\Pages\CreatePage;
use App\Filament\Resources\PageResource\Pages\EditPage;
use App\Filament\Resources\MenuResource\Pages\ListMenus;
use App\Filament\Resources\MenuResource\Pages\CreateMenu;
use App\Filament\Resources\UserResource\Pages\ListUsers;
use App\Filament\Resources\UserResource;
use App\Filament\Resources\PlanResource;
use App\Filament\Resources\BlogResource;
use App\Filament\Resources\UserResource\Pages\CreateUser;
use App\Filament\Resources\BlogResource\Pages\CreateBlog;
use App\Filament\Resources\PlanResource\Pages\CreatePlan;
use App\Filament\Resources\TicketResource\Pages\CreateTicket;
@@ -13,12 +34,12 @@ use App\Models\Plan;
use App\Models\Ticket;
use App\Models\TicketResponse;
use App\Models\User;
use Filament\Facades\Filament;
use Livewire\Livewire;
use Tests\TestCase;
class ResourcesTest extends TestCase
{
public $adminUser;
protected function setUp(): void
{
parent::setUp();
@@ -37,47 +58,47 @@ class ResourcesTest extends TestCase
// Ticket Resource Tests
/** @test */
public function it_renders_ticket_resource_list_page()
public function it_renders_ticket_resource_list_page(): void
{
Livewire::test(\App\Filament\Resources\TicketResource\Pages\ListTickets::class)
Livewire::test(ListTickets::class)
->assertSuccessful();
}
/** @test */
public function it_displays_tickets_in_table()
public function it_displays_tickets_in_table(): void
{
$tickets = Ticket::factory()->count(5)->create();
Livewire::test(\App\Filament\Resources\TicketResource\Pages\ListTickets::class)
Livewire::test(ListTickets::class)
->assertCanSeeTableRecords($tickets);
}
/** @test */
public function it_can_search_tickets_by_subject()
public function it_can_search_tickets_by_subject(): void
{
$ticket1 = Ticket::factory()->create(['subject' => 'Login Issue']);
$ticket2 = Ticket::factory()->create(['subject' => 'Payment Problem']);
Ticket::factory()->create(['subject' => 'Login Issue']);
Ticket::factory()->create(['subject' => 'Payment Problem']);
Livewire::test(\App\Filament\Resources\TicketResource\Pages\ListTickets::class)
Livewire::test(ListTickets::class)
->searchTable('Login')
->assertSee('Login Issue')
->assertDontSee('Payment Problem');
}
/** @test */
public function it_can_filter_tickets_by_status()
public function it_can_filter_tickets_by_status(): void
{
$pendingTicket = Ticket::factory()->create(['status' => 'pending']);
$closedTicket = Ticket::factory()->create(['status' => 'closed']);
Livewire::test(\App\Filament\Resources\TicketResource\Pages\ListTickets::class)
Livewire::test(ListTickets::class)
->filterTable('status', 'pending')
->assertCanSeeTableRecords([$pendingTicket])
->assertCanNotSeeTableRecords([$closedTicket]);
}
/** @test */
public function it_can_create_new_ticket()
public function it_can_create_new_ticket(): void
{
$user = User::factory()->create();
$ticketData = [
@@ -96,7 +117,7 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_validates_ticket_creation()
public function it_validates_ticket_creation(): void
{
Livewire::test(CreateTicket::class)
->fillForm([
@@ -110,7 +131,7 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_edit_existing_ticket()
public function it_can_edit_existing_ticket(): void
{
$ticket = Ticket::factory()->create();
@@ -119,7 +140,7 @@ class ResourcesTest extends TestCase
'status' => 'closed',
];
Livewire::test(\App\Filament\Resources\TicketResource\Pages\EditTicket::class, ['record' => $ticket->id])
Livewire::test(EditTicket::class, ['record' => $ticket->id])
->fillForm($updatedData)
->call('save')
->assertHasNoFormErrors();
@@ -128,35 +149,35 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_delete_ticket()
public function it_can_delete_ticket(): void
{
$ticket = Ticket::factory()->create();
Livewire::test(\App\Filament\Resources\TicketResource\Pages\ListTickets::class)
Livewire::test(ListTickets::class)
->callTableAction('delete', $ticket);
$this->assertModelMissing($ticket);
}
/** @test */
public function it_can_view_ticket_responses_relation()
public function it_can_view_ticket_responses_relation(): void
{
$ticket = Ticket::factory()->create();
$responses = TicketResponse::factory()->count(3)->create(['ticket_id' => $ticket->id]);
TicketResponse::factory()->count(3)->create(['ticket_id' => $ticket->id]);
// Test that relation manager is configured correctly
$this->assertContains(
\App\Filament\Resources\TicketResource\RelationManagers\ResponsesRelationManager::class,
\App\Filament\Resources\TicketResource::getRelations()
ResponsesRelationManager::class,
TicketResource::getRelations()
);
}
/** @test */
public function it_can_close_ticket_from_action()
public function it_can_close_ticket_from_action(): void
{
$ticket = Ticket::factory()->create(['status' => 'pending']);
Livewire::test(\App\Filament\Resources\TicketResource\Pages\ListTickets::class)
Livewire::test(ListTickets::class)
->callTableAction('close', $ticket);
$ticket->refresh();
@@ -164,11 +185,11 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_reopen_ticket_from_action()
public function it_can_reopen_ticket_from_action(): void
{
$ticket = Ticket::factory()->create(['status' => 'closed']);
Livewire::test(\App\Filament\Resources\TicketResource\Pages\ListTickets::class)
Livewire::test(ListTickets::class)
->callTableAction('reopen', $ticket);
$ticket->refresh();
@@ -177,35 +198,35 @@ class ResourcesTest extends TestCase
// Plan Resource Tests
/** @test */
public function it_renders_plan_resource_list_page()
public function it_renders_plan_resource_list_page(): void
{
Livewire::test(\App\Filament\Resources\PlanResource\Pages\ListPlans::class)
Livewire::test(ListPlans::class)
->assertSuccessful();
}
/** @test */
public function it_displays_plans_in_table()
public function it_displays_plans_in_table(): void
{
$plans = Plan::factory()->count(5)->create();
Livewire::test(\App\Filament\Resources\PlanResource\Pages\ListPlans::class)
Livewire::test(ListPlans::class)
->assertCanSeeTableRecords($plans);
}
/** @test */
public function it_can_search_plans_by_name()
public function it_can_search_plans_by_name(): void
{
$plan1 = Plan::factory()->create(['name' => 'Basic Plan']);
$plan2 = Plan::factory()->create(['name' => 'Premium Plan']);
Livewire::test(\App\Filament\Resources\PlanResource\Pages\ListPlans::class)
Livewire::test(ListPlans::class)
->searchTable('Basic')
->assertCanSeeTableRecords([$plan1])
->assertCanNotSeeTableRecords([$plan2]);
}
/** @test */
public function it_can_create_new_plan()
public function it_can_create_new_plan(): void
{
$planData = [
'name' => 'Test Plan',
@@ -229,7 +250,7 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_validates_plan_creation()
public function it_validates_plan_creation(): void
{
Livewire::test(CreatePlan::class)
->fillForm([
@@ -242,7 +263,7 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_edit_existing_plan()
public function it_can_edit_existing_plan(): void
{
$plan = Plan::factory()->create();
@@ -258,7 +279,7 @@ class ResourcesTest extends TestCase
'accept_oxapay' => 0,
];
Livewire::test(\App\Filament\Resources\PlanResource\Pages\EditPlan::class, ['record' => $plan->id])
Livewire::test(EditPlan::class, ['record' => $plan->id])
->fillForm($updatedData)
->call('save')
->assertHasNoFormErrors();
@@ -267,23 +288,23 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_delete_plan()
public function it_can_delete_plan(): void
{
$plan = Plan::factory()->create();
Livewire::test(\App\Filament\Resources\PlanResource\Pages\ListPlans::class)
Livewire::test(ListPlans::class)
->callTableAction('delete', $plan);
$this->assertModelMissing($plan);
}
/** @test */
public function it_can_filter_plans_by_payment_methods()
public function it_can_filter_plans_by_payment_methods(): void
{
$stripePlan = Plan::factory()->create(['accept_stripe' => 1]);
$shoppyPlan = Plan::factory()->create(['accept_shoppy' => 1]);
Plan::factory()->create(['accept_stripe' => 1]);
Plan::factory()->create(['accept_shoppy' => 1]);
$livewire = Livewire::test(\App\Filament\Resources\PlanResource\Pages\ListPlans::class)
$livewire = Livewire::test(ListPlans::class)
->filterTable('payment_method', 'stripe');
// Test that filtering doesn't crash and returns a response
@@ -291,11 +312,11 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_toggle_monthly_billing_setting()
public function it_can_toggle_monthly_billing_setting(): void
{
$plan = Plan::factory()->create(['monthly_billing' => true]);
Livewire::test(\App\Filament\Resources\PlanResource\Pages\EditPlan::class, ['record' => $plan->id])
Livewire::test(EditPlan::class, ['record' => $plan->id])
->fillForm([
'name' => $plan->name,
'product_id' => $plan->product_id,
@@ -316,35 +337,35 @@ class ResourcesTest extends TestCase
// Blog Resource Tests
/** @test */
public function it_renders_blog_resource_list_page()
public function it_renders_blog_resource_list_page(): void
{
Livewire::test(\App\Filament\Resources\BlogResource\Pages\ListBlogs::class)
Livewire::test(ListBlogs::class)
->assertSuccessful();
}
/** @test */
public function it_displays_blog_posts_in_table()
public function it_displays_blog_posts_in_table(): void
{
$blogs = Blog::factory()->count(5)->create();
Livewire::test(\App\Filament\Resources\BlogResource\Pages\ListBlogs::class)
Livewire::test(ListBlogs::class)
->assertCanSeeTableRecords($blogs);
}
/** @test */
public function it_can_search_blog_posts_by_title()
public function it_can_search_blog_posts_by_title(): void
{
$blog1 = Blog::factory()->create(['post' => 'Laravel Tutorial']);
$blog2 = Blog::factory()->create(['post' => 'Vue.js Guide']);
Livewire::test(\App\Filament\Resources\BlogResource\Pages\ListBlogs::class)
Livewire::test(ListBlogs::class)
->searchTable('Laravel')
->assertCanSeeTableRecords([$blog1])
->assertCanNotSeeTableRecords([$blog2]);
}
/** @test */
public function it_can_create_new_blog_post()
public function it_can_create_new_blog_post(): void
{
$category = Category::factory()->create();
$blogData = [
@@ -364,7 +385,7 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_validates_blog_post_creation()
public function it_validates_blog_post_creation(): void
{
Livewire::test(CreateBlog::class)
->fillForm([
@@ -376,7 +397,7 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_edit_existing_blog_post()
public function it_can_edit_existing_blog_post(): void
{
$blog = Blog::factory()->create();
@@ -388,7 +409,7 @@ class ResourcesTest extends TestCase
'category_id' => $blog->category_id,
];
Livewire::test(\App\Filament\Resources\BlogResource\Pages\EditBlog::class, ['record' => $blog->id])
Livewire::test(EditBlog::class, ['record' => $blog->id])
->fillForm($updatedData)
->call('save')
->assertHasNoFormErrors();
@@ -397,34 +418,34 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_delete_blog_post()
public function it_can_delete_blog_post(): void
{
$blog = Blog::factory()->create();
Livewire::test(\App\Filament\Resources\BlogResource\Pages\ListBlogs::class)
Livewire::test(ListBlogs::class)
->callTableAction('delete', $blog);
$this->assertModelMissing($blog);
}
/** @test */
public function it_can_filter_blog_posts_by_status()
public function it_can_filter_blog_posts_by_status(): void
{
$publishedBlog = Blog::factory()->create(['is_published' => true]);
$draftBlog = Blog::factory()->create(['is_published' => false]);
Livewire::test(\App\Filament\Resources\BlogResource\Pages\ListBlogs::class)
Livewire::test(ListBlogs::class)
->filterTable('is_published', true)
->assertCanSeeTableRecords([$publishedBlog])
->assertCanNotSeeTableRecords([$draftBlog]);
}
/** @test */
public function it_can_toggle_published_status()
public function it_can_toggle_published_status(): void
{
$blog = Blog::factory()->create(['is_published' => false]);
Livewire::test(\App\Filament\Resources\BlogResource\Pages\ListBlogs::class)
Livewire::test(ListBlogs::class)
->callTableAction('togglePublished', $blog);
$blog->refresh();
@@ -432,34 +453,34 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_view_category_relation()
public function it_can_view_category_relation(): void
{
$category = Category::factory()->create();
$blog = Blog::factory()->create(['category_id' => $category->id]);
Livewire::test(\App\Filament\Resources\BlogResource\Pages\ListBlogs::class)
Livewire::test(ListBlogs::class)
->assertTableColumnStateSet('category.name', $category->name, $blog);
}
// Category Resource Tests
/** @test */
public function it_renders_category_resource_list_page()
public function it_renders_category_resource_list_page(): void
{
Livewire::test(\App\Filament\Resources\CategoryResource\Pages\ListCategories::class)
Livewire::test(ListCategories::class)
->assertSuccessful();
}
/** @test */
public function it_displays_categories_in_table()
public function it_displays_categories_in_table(): void
{
$categories = Category::factory()->count(5)->create();
Livewire::test(\App\Filament\Resources\CategoryResource\Pages\ListCategories::class)
Livewire::test(ListCategories::class)
->assertCanSeeTableRecords($categories);
}
/** @test */
public function it_can_create_new_category()
public function it_can_create_new_category(): void
{
$categoryData = [
'name' => 'Test Category',
@@ -467,7 +488,7 @@ class ResourcesTest extends TestCase
'is_active' => 1,
];
Livewire::test(\App\Filament\Resources\CategoryResource\Pages\CreateCategory::class)
Livewire::test(CreateCategory::class)
->fillForm($categoryData)
->call('create')
->assertHasNoFormErrors();
@@ -476,9 +497,9 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_validates_category_creation()
public function it_validates_category_creation(): void
{
Livewire::test(\App\Filament\Resources\CategoryResource\Pages\CreateCategory::class)
Livewire::test(CreateCategory::class)
->fillForm([
'name' => '',
'slug' => '',
@@ -488,7 +509,7 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_edit_existing_category()
public function it_can_edit_existing_category(): void
{
$category = Category::factory()->create();
@@ -497,7 +518,7 @@ class ResourcesTest extends TestCase
'is_active' => 1,
];
Livewire::test(\App\Filament\Resources\CategoryResource\Pages\EditCategory::class, ['record' => $category->id])
Livewire::test(EditCategory::class, ['record' => $category->id])
->fillForm($updatedData)
->call('save')
->assertHasNoFormErrors();
@@ -506,32 +527,32 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_delete_category()
public function it_can_delete_category(): void
{
$category = Category::factory()->create();
Livewire::test(\App\Filament\Resources\CategoryResource\Pages\ListCategories::class)
Livewire::test(ListCategories::class)
->callTableAction('delete', $category);
$this->assertModelMissing($category);
}
/** @test */
public function it_can_view_blogs_count()
public function it_can_view_blogs_count(): void
{
$category = Category::factory()->create();
Blog::factory()->count(3)->create(['category_id' => $category->id]);
Livewire::test(\App\Filament\Resources\CategoryResource\Pages\ListCategories::class)
Livewire::test(ListCategories::class)
->assertTableColumnStateSet('blogs_count', 3, $category);
}
/** @test */
public function it_can_toggle_category_status()
public function it_can_toggle_category_status(): void
{
$category = Category::factory()->create(['is_active' => true]);
Livewire::test(\App\Filament\Resources\CategoryResource\Pages\ListCategories::class)
Livewire::test(ListCategories::class)
->callTableAction('toggleStatus', $category);
$category->refresh();
@@ -540,23 +561,23 @@ class ResourcesTest extends TestCase
// Page Resource Tests
/** @test */
public function it_renders_page_resource_list_page()
public function it_renders_page_resource_list_page(): void
{
Livewire::test(\App\Filament\Resources\PageResource\Pages\ListPages::class)
Livewire::test(ListPages::class)
->assertSuccessful();
}
/** @test */
public function it_displays_pages_in_table()
public function it_displays_pages_in_table(): void
{
$pages = Page::factory()->count(5)->create();
Livewire::test(\App\Filament\Resources\PageResource\Pages\ListPages::class)
Livewire::test(ListPages::class)
->assertCanSeeTableRecords($pages);
}
/** @test */
public function it_can_create_new_page()
public function it_can_create_new_page(): void
{
$pageData = [
'title' => 'Test Page',
@@ -565,7 +586,7 @@ class ResourcesTest extends TestCase
'is_published' => 1,
];
Livewire::test(\App\Filament\Resources\PageResource\Pages\CreatePage::class)
Livewire::test(CreatePage::class)
->fillForm($pageData)
->call('create')
->assertHasNoFormErrors();
@@ -574,9 +595,9 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_validates_page_creation()
public function it_validates_page_creation(): void
{
Livewire::test(\App\Filament\Resources\PageResource\Pages\CreatePage::class)
Livewire::test(CreatePage::class)
->fillForm([
'title' => '',
'slug' => '',
@@ -587,7 +608,7 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_edit_existing_page()
public function it_can_edit_existing_page(): void
{
$page = Page::factory()->create();
@@ -601,7 +622,7 @@ class ResourcesTest extends TestCase
'meta' => '{"description":"Updated page description","keywords":"updated,page"}',
];
Livewire::test(\App\Filament\Resources\PageResource\Pages\EditPage::class, ['record' => $page->id])
Livewire::test(EditPage::class, ['record' => $page->id])
->fillForm($updatedData)
->call('save')
->assertHasNoFormErrors();
@@ -610,34 +631,34 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_delete_page()
public function it_can_delete_page(): void
{
$page = Page::factory()->create();
Livewire::test(\App\Filament\Resources\PageResource\Pages\ListPages::class)
Livewire::test(ListPages::class)
->callTableAction('delete', $page);
$this->assertModelMissing($page);
}
/** @test */
public function it_can_filter_pages_by_publication_status()
public function it_can_filter_pages_by_publication_status(): void
{
$publishedPage = Page::factory()->create(['is_published' => true]);
$draftPage = Page::factory()->create(['is_published' => false]);
Livewire::test(\App\Filament\Resources\PageResource\Pages\ListPages::class)
Livewire::test(ListPages::class)
->filterTable('is_published', true)
->assertCanSeeTableRecords([$publishedPage])
->assertCanNotSeeTableRecords([$draftPage]);
}
/** @test */
public function it_can_toggle_page_publication_status()
public function it_can_toggle_page_publication_status(): void
{
$page = Page::factory()->create(['is_published' => true]);
Livewire::test(\App\Filament\Resources\PageResource\Pages\ListPages::class)
Livewire::test(ListPages::class)
->callTableAction('togglePublished', $page);
$page->refresh();
@@ -646,23 +667,23 @@ class ResourcesTest extends TestCase
// Menu Resource Tests
/** @test */
public function it_renders_menu_resource_list_page()
public function it_renders_menu_resource_list_page(): void
{
Livewire::test(\App\Filament\Resources\MenuResource\Pages\ListMenus::class)
Livewire::test(ListMenus::class)
->assertSuccessful();
}
/** @test */
public function it_displays_menu_items_in_table()
public function it_displays_menu_items_in_table(): void
{
$menus = Menu::factory()->count(5)->create();
Livewire::test(\App\Filament\Resources\MenuResource\Pages\ListMenus::class)
Livewire::test(ListMenus::class)
->assertCanSeeTableRecords($menus);
}
/** @test */
public function it_can_create_new_menu_item()
public function it_can_create_new_menu_item(): void
{
$menuData = [
'name' => 'Test Menu',
@@ -670,7 +691,7 @@ class ResourcesTest extends TestCase
'new_tab' => false,
];
Livewire::test(\App\Filament\Resources\MenuResource\Pages\CreateMenu::class)
Livewire::test(CreateMenu::class)
->fillForm($menuData)
->call('create')
->assertHasNoFormErrors();
@@ -679,9 +700,9 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_validates_menu_item_creation()
public function it_validates_menu_item_creation(): void
{
Livewire::test(\App\Filament\Resources\MenuResource\Pages\CreateMenu::class)
Livewire::test(CreateMenu::class)
->fillForm([
'name' => '',
'url' => '',
@@ -691,78 +712,78 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_delete_menu_item()
public function it_can_delete_menu_item(): void
{
$menu = Menu::factory()->create();
Livewire::test(\App\Filament\Resources\MenuResource\Pages\ListMenus::class)
Livewire::test(ListMenus::class)
->callTableAction('delete', $menu);
$this->assertModelMissing($menu);
}
/** @test */
public function it_displays_menu_items_alphabetically()
public function it_displays_menu_items_alphabetically(): void
{
$menu1 = Menu::factory()->create(['name' => 'Zebra']);
$menu2 = Menu::factory()->create(['name' => 'Apple']);
Livewire::test(\App\Filament\Resources\MenuResource\Pages\ListMenus::class)
Livewire::test(ListMenus::class)
->sortTable('name')
->assertCanSeeTableRecords([$menu2, $menu1], inOrder: true);
}
/** @test */
public function it_can_handle_parent_child_relationships()
public function it_can_handle_parent_child_relationships(): void
{
$parentMenu = Menu::factory()->create(['parent' => null]);
$childMenu = Menu::factory()->create(['parent' => $parentMenu->id]);
Livewire::test(\App\Filament\Resources\MenuResource\Pages\ListMenus::class)
Livewire::test(ListMenus::class)
->assertTableColumnStateSet('parentname.name', $parentMenu->name, $childMenu);
}
// General Filament Tests
/** @test */
public function it_can_navigate_between_resources()
public function it_can_navigate_between_resources(): void
{
Livewire::test(\App\Filament\Resources\UserResource\Pages\ListUsers::class)
Livewire::test(ListUsers::class)
->assertSuccessful();
Livewire::test(\App\Filament\Resources\TicketResource\Pages\ListTickets::class)
Livewire::test(ListTickets::class)
->assertSuccessful();
Livewire::test(\App\Filament\Resources\PlanResource\Pages\ListPlans::class)
Livewire::test(ListPlans::class)
->assertSuccessful();
}
/** @test */
public function it_can_use_global_search()
public function it_can_use_global_search(): void
{
$user = User::factory()->create(['name' => 'John Doe']);
User::factory()->create(['name' => 'John Doe']);
Livewire::test(\App\Filament\Resources\UserResource\Pages\ListUsers::class)
Livewire::test(ListUsers::class)
->assertSuccessful();
}
/** @test */
public function it_can_search_users_in_table()
public function it_can_search_users_in_table(): void
{
$user1 = User::factory()->create(['name' => 'John Doe']);
$user2 = User::factory()->create(['name' => 'Jane Smith']);
Livewire::test(\App\Filament\Resources\UserResource\Pages\ListUsers::class)
Livewire::test(ListUsers::class)
->searchTable('John')
->assertCanSeeTableRecords([$user1])
->assertCanNotSeeTableRecords([$user2]);
}
/** @test */
public function it_handles_bulk_actions_correctly()
public function it_handles_bulk_actions_correctly(): void
{
$users = User::factory()->count(3)->create();
Livewire::test(\App\Filament\Resources\UserResource\Pages\ListUsers::class)
Livewire::test(ListUsers::class)
->callTableBulkAction('delete', $users);
foreach ($users as $user) {
@@ -771,31 +792,31 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_validates_access_control()
public function it_validates_access_control(): void
{
// Test with non-admin user - currently access control allows all authenticated users
$normalUser = User::factory()->create(['level' => 0]);
$this->actingAs($normalUser);
Livewire::test(\App\Filament\Resources\UserResource\Pages\ListUsers::class)
Livewire::test(ListUsers::class)
->assertStatus(200); // Access control currently allows access
}
/** @test */
public function it_displays_correct_navigation_structure()
public function it_displays_correct_navigation_structure(): void
{
$this->assertEquals('heroicon-o-users', \App\Filament\Resources\UserResource::getNavigationIcon());
$this->assertEquals('heroicon-o-ticket', \App\Filament\Resources\TicketResource::getNavigationIcon());
$this->assertEquals('heroicon-o-rectangle-stack', \App\Filament\Resources\PlanResource::getNavigationIcon());
$this->assertEquals('heroicon-m-newspaper', \App\Filament\Resources\BlogResource::getNavigationIcon());
$this->assertEquals('heroicon-o-users', UserResource::getNavigationIcon());
$this->assertEquals('heroicon-o-ticket', TicketResource::getNavigationIcon());
$this->assertEquals('heroicon-o-rectangle-stack', PlanResource::getNavigationIcon());
$this->assertEquals('heroicon-m-newspaper', BlogResource::getNavigationIcon());
}
/** @test */
public function it_handles_form_submissions_with_relationships()
public function it_handles_form_submissions_with_relationships(): void
{
$category = Category::factory()->create();
Livewire::test(\App\Filament\Resources\BlogResource\Pages\CreateBlog::class)
Livewire::test(CreateBlog::class)
->fillForm([
'post' => 'Test Blog',
'slug' => 'test-blog',
@@ -813,16 +834,16 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_handles_file_uploads_in_forms()
public function it_handles_file_uploads_in_forms(): void
{
// Test file upload functionality if implemented
$this->assertTrue(true); // Placeholder
}
/** @test */
public function it_displays_proper_error_messages()
public function it_displays_proper_error_messages(): void
{
Livewire::test(\App\Filament\Resources\UserResource\Pages\CreateUser::class)
Livewire::test(CreateUser::class)
->fillForm([
'name' => '',
'email' => 'invalid-email',
@@ -833,11 +854,11 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_handles_pagination_correctly()
public function it_handles_pagination_correctly(): void
{
User::factory()->count(25)->create();
Livewire::test(\App\Filament\Resources\UserResource\Pages\ListUsers::class)
Livewire::test(ListUsers::class)
->assertSuccessful()
->assertSeeHtml('fi-pagination')
->assertSee('1')
@@ -846,11 +867,11 @@ class ResourcesTest extends TestCase
}
/** @test */
public function it_can_sort_users_by_different_columns()
public function it_can_sort_users_by_different_columns(): void
{
User::factory()->count(5)->create();
Livewire::test(\App\Filament\Resources\UserResource\Pages\ListUsers::class)
Livewire::test(ListUsers::class)
->sortTable('name')
->assertSuccessful();
}

View File

@@ -2,18 +2,20 @@
namespace Tests\Feature\Filament;
use App\Filament\Resources\UserResource\RelationManagers\LogsRelationManager;
use App\Filament\Resources\UserResource\RelationManagers\UsageLogsRelationManager;
use App\Filament\Resources\UserResource;
use App\Filament\Resources\UserResource\Pages\CreateUser;
use App\Filament\Resources\UserResource\Pages\EditUser;
use App\Filament\Resources\UserResource\Pages\ListUsers;
use App\Models\Log;
use App\Models\User;
use Filament\Facades\Filament;
use Livewire\Livewire;
use Tests\TestCase;
class UserResourceTest extends TestCase
{
public $adminUser;
protected function setUp(): void
{
parent::setUp();
@@ -31,14 +33,14 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_renders_user_resource_list_page()
public function it_renders_user_resource_list_page(): void
{
Livewire::test(ListUsers::class)
->assertSuccessful();
}
/** @test */
public function it_displays_users_in_table()
public function it_displays_users_in_table(): void
{
$users = User::factory()->count(5)->create();
@@ -47,7 +49,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_search_users_by_name()
public function it_can_search_users_by_name(): void
{
$user1 = User::factory()->create(['name' => 'John Doe']);
$user2 = User::factory()->create(['name' => 'Jane Smith']);
@@ -59,7 +61,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_search_users_by_email()
public function it_can_search_users_by_email(): void
{
$user1 = User::factory()->create(['email' => 'john@example.com']);
$user2 = User::factory()->create(['email' => 'jane@example.com']);
@@ -71,7 +73,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_sort_users_by_name()
public function it_can_sort_users_by_name(): void
{
$user1 = User::factory()->create(['name' => 'Alice']);
$user2 = User::factory()->create(['name' => 'Bob']);
@@ -82,7 +84,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_sort_users_by_email()
public function it_can_sort_users_by_email(): void
{
$user1 = User::factory()->create(['email' => 'alice@example.com']);
$user2 = User::factory()->create(['email' => 'bob@example.com']);
@@ -93,7 +95,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_filter_users_by_verification_status()
public function it_can_filter_users_by_verification_status(): void
{
$verifiedUser = User::factory()->create(['email_verified_at' => now()]);
$unverifiedUser = User::factory()->create(['email_verified_at' => null]);
@@ -105,14 +107,14 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_filter_users_by_level()
public function it_can_filter_users_by_level(): void
{
$normalUser = User::factory()->create(['level' => 0]);
$bannedUser = User::factory()->create(['level' => 1]);
$adminUser = User::factory()->create(['level' => 9]);
User::factory()->create(['level' => 0]);
User::factory()->create(['level' => 1]);
User::factory()->create(['level' => 9]);
// The level filter doesn't exist in UserResource, so let's test the subscription status filter instead
$subscribedUser = User::factory()->create();
User::factory()->create();
$nonSubscribedUser = User::factory()->create();
Livewire::test(ListUsers::class)
@@ -121,7 +123,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_create_new_user()
public function it_can_create_new_user(): void
{
// Test that CreateUser page renders successfully
// UserResource form doesn't include password fields, so we test the page exists
@@ -130,7 +132,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_validates_user_creation()
public function it_validates_user_creation(): void
{
Livewire::test(CreateUser::class)
->fillForm([
@@ -143,7 +145,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_validates_email_uniqueness_on_creation()
public function it_validates_email_uniqueness_on_creation(): void
{
// Test that CreateUser page renders successfully
// Email uniqueness is handled by Laravel validation, not form testing
@@ -152,7 +154,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_edit_existing_user()
public function it_can_edit_existing_user(): void
{
$user = User::factory()->create();
@@ -171,7 +173,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_validates_user_editing()
public function it_validates_user_editing(): void
{
$user = User::factory()->create();
@@ -186,10 +188,10 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_validates_email_uniqueness_on_edit_excluding_current_user()
public function it_validates_email_uniqueness_on_edit_excluding_current_user(): void
{
$user1 = User::factory()->create(['email' => 'user1@example.com']);
$user2 = User::factory()->create(['email' => 'user2@example.com']);
User::factory()->create(['email' => 'user2@example.com']);
// Test that we can edit user with valid data
Livewire::test(EditUser::class, ['record' => $user1->id])
@@ -203,25 +205,25 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_can_edit_user()
public function it_can_edit_user(): void
{
$user = User::factory()->create();
User::factory()->create();
Livewire::test(ListUsers::class)
->assertTableActionExists('edit');
}
/** @test */
public function it_can_bulk_delete_users()
public function it_can_bulk_delete_users(): void
{
$users = User::factory()->count(3)->create();
User::factory()->count(3)->create();
Livewire::test(ListUsers::class)
->assertTableBulkActionExists('delete');
}
/** @test */
public function it_displays_user_verification_status_correctly()
public function it_displays_user_verification_status_correctly(): void
{
$verifiedUser = User::factory()->create(['email_verified_at' => now()]);
$unverifiedUser = User::factory()->create(['email_verified_at' => null]);
@@ -232,7 +234,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_displays_user_level_badges_correctly()
public function it_displays_user_level_badges_correctly(): void
{
$normalUser = User::factory()->create(['level' => 0]);
$bannedUser = User::factory()->create(['level' => 1]);
@@ -245,7 +247,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_shows_email_verification_timestamp_in_form()
public function it_shows_email_verification_timestamp_in_form(): void
{
$user = User::factory()->create(['email_verified_at' => '2024-01-01 12:00:00']);
@@ -255,7 +257,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_shows_not_verified_status_in_form()
public function it_shows_not_verified_status_in_form(): void
{
$user = User::factory()->create(['email_verified_at' => null]);
@@ -264,7 +266,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_displays_stripe_information_when_available()
public function it_displays_stripe_information_when_available(): void
{
$user = User::factory()->create([
'stripe_id' => 'cus_123456',
@@ -281,7 +283,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_displays_trial_end_date_when_available()
public function it_displays_trial_end_date_when_available(): void
{
$user = User::factory()->create(['trial_ends_at' => '2024-12-31 23:59:59']);
@@ -290,22 +292,22 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_has_relation_managers_configured()
public function it_has_relation_managers_configured(): void
{
$this->assertIsArray(UserResource::getRelations());
$this->assertContains('App\Filament\Resources\UserResource\RelationManagers\LogsRelationManager', UserResource::getRelations());
$this->assertContains('App\Filament\Resources\UserResource\RelationManagers\UsageLogsRelationManager', UserResource::getRelations());
$this->assertContains(LogsRelationManager::class, UserResource::getRelations());
$this->assertContains(UsageLogsRelationManager::class, UserResource::getRelations());
}
/** @test */
public function it_has_bulk_update_level_action()
public function it_has_bulk_update_level_action(): void
{
Livewire::test(ListUsers::class)
->assertTableBulkActionExists('updateLevel');
}
/** @test */
public function it_searches_across_multiple_fields()
public function it_searches_across_multiple_fields(): void
{
$user1 = User::factory()->create(['name' => 'John Doe', 'email' => 'john@example.com']);
$user2 = User::factory()->create(['name' => 'Jane Smith', 'email' => 'jane@example.com']);
@@ -317,7 +319,7 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_handles_relationship_data_correctly()
public function it_handles_relationship_data_correctly(): void
{
$user = User::factory()->create();
Log::factory()->count(3)->create(['user_id' => $user->id]);
@@ -327,14 +329,14 @@ class UserResourceTest extends TestCase
}
/** @test */
public function it_displays_correct_navigation_icon_and_group()
public function it_displays_correct_navigation_icon_and_group(): void
{
$this->assertEquals('heroicon-o-users', UserResource::getNavigationIcon());
$this->assertEquals('Admin', UserResource::getNavigationGroup());
}
/** @test */
public function it_uses_correct_model()
public function it_uses_correct_model(): void
{
$this->assertEquals(User::class, UserResource::getModel());
}

View File

@@ -4,7 +4,6 @@ namespace Tests\Feature\Livewire\Auth;
use App\Livewire\Auth\Login;
use App\Models\User;
use Illuminate\Auth\Events\Lockout;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\RateLimiter;
use Illuminate\Support\Facades\Session;
@@ -13,6 +12,7 @@ use Tests\TestCase;
class LoginTest extends TestCase
{
public $user;
protected function setUp(): void
{
parent::setUp();
@@ -24,7 +24,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_renders_the_login_component()
public function it_renders_the_login_component(): void
{
$component = Livewire::test(Login::class);
@@ -34,7 +34,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_validates_required_email_field()
public function it_validates_required_email_field(): void
{
$component = Livewire::test(Login::class);
@@ -44,7 +44,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_validates_email_format()
public function it_validates_email_format(): void
{
$component = Livewire::test(Login::class);
@@ -54,7 +54,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_validates_required_password_field()
public function it_validates_required_password_field(): void
{
$component = Livewire::test(Login::class);
@@ -64,7 +64,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_authenticates_user_with_valid_credentials()
public function it_authenticates_user_with_valid_credentials(): void
{
$component = Livewire::test(Login::class);
@@ -77,7 +77,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_fails_authentication_with_invalid_credentials()
public function it_fails_authentication_with_invalid_credentials(): void
{
$component = Livewire::test(Login::class);
@@ -88,7 +88,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_handles_rate_limiting()
public function it_handles_rate_limiting(): void
{
// Clear any existing rate limit attempts
RateLimiter::clear('login:'.request()->ip());
@@ -110,7 +110,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_redirects_authenticated_users_away()
public function it_redirects_authenticated_users_away(): void
{
$this->actingAs($this->user);
@@ -121,7 +121,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_handles_lockout_event()
public function it_handles_lockout_event(): void
{
// Clear any existing rate limit attempts
RateLimiter::clear('login:'.request()->ip());
@@ -143,7 +143,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_clears_session_after_successful_login()
public function it_clears_session_after_successful_login(): void
{
Session::put('old_url', '/some-page');
@@ -159,7 +159,7 @@ class LoginTest extends TestCase
}
/** @test */
public function it_remember_me_functionality_works()
public function it_remember_me_functionality_works(): void
{
$component = Livewire::test(Login::class);

View File

@@ -14,7 +14,7 @@ use Tests\TestCase;
class RegisterTest extends TestCase
{
/** @test */
public function it_renders_the_register_component()
public function it_renders_the_register_component(): void
{
$component = Livewire::test(Register::class);
@@ -25,7 +25,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_validates_required_name_field()
public function it_validates_required_name_field(): void
{
$component = Livewire::test(Register::class);
@@ -38,7 +38,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_validates_required_email_field()
public function it_validates_required_email_field(): void
{
$component = Livewire::test(Register::class);
@@ -51,7 +51,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_validates_email_format()
public function it_validates_email_format(): void
{
$component = Livewire::test(Register::class);
@@ -65,7 +65,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_validates_required_password_field()
public function it_validates_required_password_field(): void
{
$component = Livewire::test(Register::class);
@@ -78,7 +78,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_validates_password_confirmation()
public function it_validates_password_confirmation(): void
{
$component = Livewire::test(Register::class);
@@ -92,7 +92,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_creates_user_with_valid_data()
public function it_creates_user_with_valid_data(): void
{
Event::fake();
@@ -110,12 +110,12 @@ class RegisterTest extends TestCase
'email' => 'test@gmail.com',
]);
$this->assertAuthenticatedAs(User::where('email', 'test@gmail.com')->first());
$this->assertAuthenticatedAs(User::query()->where('email', 'test@gmail.com')->first());
Event::assertDispatched(Registered::class);
}
/** @test */
public function it_hashes_password_before_storing()
public function it_hashes_password_before_storing(): void
{
$component = Livewire::test(Register::class);
@@ -126,12 +126,12 @@ class RegisterTest extends TestCase
->set('password_confirmation', 'Password123!')
->call('register');
$user = User::where('email', 'test@gmail.com')->first();
$user = User::query()->where('email', 'test@gmail.com')->first();
$this->assertTrue(Hash::check('Password123!', $user->password));
}
/** @test */
public function it_prevents_duplicate_email_registration()
public function it_prevents_duplicate_email_registration(): void
{
// Create existing user
User::factory()->create(['email' => 'test@gmail.com']);
@@ -148,7 +148,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_redirects_after_successful_registration()
public function it_redirects_after_successful_registration(): void
{
$component = Livewire::test(Register::class);
@@ -163,7 +163,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_logs_in_user_after_registration()
public function it_logs_in_user_after_registration(): void
{
$component = Livewire::test(Register::class);
@@ -179,7 +179,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_handles_maximum_name_length()
public function it_handles_maximum_name_length(): void
{
$component = Livewire::test(Register::class);
@@ -193,7 +193,7 @@ class RegisterTest extends TestCase
}
/** @test */
public function it_handles_password_validation()
public function it_handles_password_validation(): void
{
$component = Livewire::test(Register::class);

View File

@@ -2,6 +2,7 @@
namespace Tests\Feature\Livewire;
use App\Livewire\Dashboard\Dashboard;
use App\Models\Plan;
use App\Models\User;
use Illuminate\Support\Facades\Auth;
@@ -10,6 +11,7 @@ use Tests\TestCase;
class DashboardTest extends TestCase
{
public $user;
protected function setUp(): void
{
parent::setUp();
@@ -30,18 +32,18 @@ class DashboardTest extends TestCase
}
/** @test */
public function it_renders_dashboard_component()
public function it_renders_dashboard_component(): void
{
$component = Livewire::test(\App\Livewire\Dashboard\Dashboard::class);
$component = Livewire::test(Dashboard::class);
$component->assertStatus(200);
$component->assertViewIs('livewire.dashboard.dashboard');
}
/** @test */
public function it_displays_user_information()
public function it_displays_user_information(): void
{
$component = Livewire::test(\App\Livewire\Dashboard\Dashboard::class);
$component = Livewire::test(Dashboard::class);
// Check that dashboard renders with usage statistics
$component->assertSee('Mailbox Created');
@@ -50,9 +52,9 @@ class DashboardTest extends TestCase
}
/** @test */
public function it_shows_subscription_status()
public function it_shows_subscription_status(): void
{
$component = Livewire::test(\App\Livewire\Dashboard\Dashboard::class);
$component = Livewire::test(Dashboard::class);
// Test that the component displays subscription pricing section (since user is not subscribed)
$component->assertSee('Purchase Subscription');

View File

@@ -2,7 +2,12 @@
namespace Tests\Feature\Livewire;
use App\Models\Email;
use App\Livewire\Home;
use App\Livewire\Frontend\Mailbox;
use Exception;
use App\Models\Blog;
use App\Livewire\ListBlog;
use App\Models\Page;
use App\Models\ZEmail;
use Illuminate\Support\Facades\Cookie;
use Livewire\Livewire;
@@ -11,18 +16,18 @@ use Tests\TestCase;
class FrontendTest extends TestCase
{
/** @test */
public function it_renders_home_component()
public function it_renders_home_component(): void
{
$component = Livewire::test(\App\Livewire\Home::class);
$component = Livewire::test(Home::class);
$component->assertStatus(200);
$component->assertViewIs('livewire.home');
}
/** @test */
public function it_checks_for_messages_in_home_component()
public function it_checks_for_messages_in_home_component(): void
{
$component = Livewire::test(\App\Livewire\Home::class);
$component = Livewire::test(Home::class);
// Test that the component can render without errors
$component->assertStatus(200);
@@ -30,7 +35,7 @@ class FrontendTest extends TestCase
}
/** @test */
public function it_renders_mailbox_component_with_existing_email()
public function it_renders_mailbox_component_with_existing_email(): void
{
// Mock existing email in cookie
Cookie::queue('email', 'test@example.com', 43800);
@@ -40,32 +45,32 @@ class FrontendTest extends TestCase
->shouldReceive('getEmail')
->andReturn('test@example.com');
$component = Livewire::test(\App\Livewire\Frontend\Mailbox::class);
$component = Livewire::test(Mailbox::class);
// Component might redirect if email validation fails, so check for either status or redirect
try {
$component->assertStatus(200);
} catch (\Exception $e) {
} catch (Exception) {
$component->assertRedirect('/');
}
}
/** @test */
public function it_redirects_home_when_no_email_in_mailbox()
public function it_redirects_home_when_no_email_in_mailbox(): void
{
// Ensure no email cookie exists
Cookie::queue('email', '', -1);
$component = Livewire::test(\App\Livewire\Frontend\Mailbox::class);
$component = Livewire::test(Mailbox::class);
$component->assertRedirect('/');
}
/** @test */
public function it_renders_blog_component()
public function it_renders_blog_component(): void
{
// Create a blog post with the slug we're testing
$blog = \App\Models\Blog::factory()->create(['slug' => 'test-slug']);
Blog::factory()->create(['slug' => 'test-slug']);
$component = Livewire::test(\App\Livewire\Blog::class, ['slug' => 'test-slug']);
@@ -73,18 +78,18 @@ class FrontendTest extends TestCase
}
/** @test */
public function it_renders_list_blog_component()
public function it_renders_list_blog_component(): void
{
$component = Livewire::test(\App\Livewire\ListBlog::class);
$component = Livewire::test(ListBlog::class);
$component->assertStatus(200);
}
/** @test */
public function it_renders_page_component()
public function it_renders_page_component(): void
{
// Create a page with the slug we're testing and ensure it's published
$page = \App\Models\Page::factory()->create([
Page::factory()->create([
'slug' => 'test-slug',
'is_published' => true,
]);