Add PHPUnit tests and update UI

- Add PHPUnit 11.0 testing framework
- Create unit tests for Database and Crawler classes
- Create integration tests for Crawler
- Add phpunit.xml configuration
- Change UI background color to rose
- All 9 tests passing

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
2025-10-03 14:13:04 +02:00
parent 2f301cec42
commit f568875b2c
8 changed files with 1986 additions and 3 deletions

View File

@@ -0,0 +1,48 @@
<?php
namespace Tests\Unit;
use PHPUnit\Framework\TestCase;
use App\Crawler;
use App\Database;
class CrawlerTest extends TestCase
{
private int $testJobId;
protected function setUp(): void
{
$db = Database::getInstance();
// Create a test job
$stmt = $db->prepare("INSERT INTO crawl_jobs (domain, status) VALUES (?, 'pending')");
$stmt->execute(['https://example.com']);
$this->testJobId = $db->lastInsertId();
}
protected function tearDown(): void
{
$db = Database::getInstance();
// Clean up test data
$stmt = $db->prepare("DELETE FROM crawl_jobs WHERE id = ?");
$stmt->execute([$this->testJobId]);
}
public function testCrawlerCanBeInstantiated(): void
{
$crawler = new Crawler($this->testJobId);
$this->assertInstanceOf(Crawler::class, $crawler);
}
public function testCrawlerCreatesJobWithCorrectStatus(): void
{
$db = Database::getInstance();
$stmt = $db->prepare("SELECT status FROM crawl_jobs WHERE id = ?");
$stmt->execute([$this->testJobId]);
$job = $stmt->fetch();
$this->assertEquals('pending', $job['status']);
}
}

View File

@@ -0,0 +1,57 @@
<?php
namespace Tests\Unit;
use PHPUnit\Framework\TestCase;
use App\Database;
use PDO;
class DatabaseTest extends TestCase
{
public function testGetInstanceReturnsPDO(): void
{
$db = Database::getInstance();
$this->assertInstanceOf(PDO::class, $db);
}
public function testGetInstanceReturnsSameInstance(): void
{
$db1 = Database::getInstance();
$db2 = Database::getInstance();
$this->assertSame($db1, $db2);
}
public function testDatabaseConnectionHasCorrectAttributes(): void
{
$db = Database::getInstance();
// Test error mode
$this->assertEquals(
PDO::ERRMODE_EXCEPTION,
$db->getAttribute(PDO::ATTR_ERRMODE)
);
// Test fetch mode
$this->assertEquals(
PDO::FETCH_ASSOC,
$db->getAttribute(PDO::ATTR_DEFAULT_FETCH_MODE)
);
}
public function testCanExecuteQuery(): void
{
$db = Database::getInstance();
$stmt = $db->query('SELECT 1 as test');
$result = $stmt->fetch();
$this->assertEquals(['test' => 1], $result);
}
public function testCanPrepareStatement(): void
{
$db = Database::getInstance();
$stmt = $db->prepare('SELECT ? as test');
$this->assertInstanceOf(\PDOStatement::class, $stmt);
}
}