Files
shopPRO/tests
Jacek 5598888716 security: faza 4 - ochrona CSRF panelu administracyjnego
- Nowa klasa \Shared\Security\CsrfToken (generate/validate/regenerate)
- Token CSRF we wszystkich formularzach edycji (form-edit.php)
- Walidacja CSRF w FormRequestHandler::handleSubmit()
- Token CSRF w formularzu logowania i formularzach 2FA
- Walidacja CSRF w App::special_actions() dla żądań POST
- Regeneracja tokenu po udanym logowaniu (bezpośrednia i przez 2FA)
- Fix XSS: htmlspecialchars na $alert w unlogged-layout.php
- 7 nowych testów CsrfTokenTest (817 testów łącznie)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-12 10:06:40 +01:00
..

Testy shopPRO

Instalacja PHPUnit

Opcja 1: Przez Composer (zalecane)

composer install

Opcja 2: Ręcznie (jeśli nie masz Composera)

wget https://phar.phpunit.de/phpunit-9.phar
php phpunit-9.phar --version

Uruchamianie testów

Wszystkie testy

composer test
# lub
vendor/bin/phpunit

Konkretny plik

vendor/bin/phpunit tests/Unit/Domain/Product/ProductRepositoryTest.php

Z pokryciem kodu

composer test-coverage

Anatomia testu (AAA Pattern)

public function testGetQuantityReturnsCorrectValue()
{
    // Arrange - Przygotowanie
    $mockDb = $this->createMock(\medoo::class);
    $mockDb->method('get')->willReturn(42);
    $repository = new ProductRepository($mockDb);

    // Act - Wykonanie akcji
    $quantity = $repository->getQuantity(123);

    // Assert - Sprawdzenie wyniku
    $this->assertEquals(42, $quantity);
}

Najważniejsze asercje

$this->assertEquals(expected, actual);      // Równość wartości
$this->assertIsInt($value);                 // Typ
$this->assertNull($value);                  // Czy null
$this->assertTrue($condition);              // Czy prawda

Więcej: https://phpunit.de/documentation.html