BasicTest.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?php
  2. declare(strict_types=1);
  3. namespace Sabre\HTTP\Auth;
  4. use Sabre\HTTP\Request;
  5. use Sabre\HTTP\Response;
  6. class BasicTest extends \PHPUnit\Framework\TestCase
  7. {
  8. public function testGetCredentials()
  9. {
  10. $request = new Request('GET', '/', [
  11. 'Authorization' => 'Basic '.base64_encode('user:pass:bla'),
  12. ]);
  13. $basic = new Basic('Dagger', $request, new Response());
  14. $this->assertEquals([
  15. 'user',
  16. 'pass:bla',
  17. ], $basic->getCredentials());
  18. }
  19. public function testGetInvalidCredentialsColonMissing()
  20. {
  21. $request = new Request('GET', '/', [
  22. 'Authorization' => 'Basic '.base64_encode('userpass'),
  23. ]);
  24. $basic = new Basic('Dagger', $request, new Response());
  25. $this->assertNull($basic->getCredentials());
  26. }
  27. public function testGetCredentialsNoHeader()
  28. {
  29. $request = new Request('GET', '/', []);
  30. $basic = new Basic('Dagger', $request, new Response());
  31. $this->assertNull($basic->getCredentials());
  32. }
  33. public function testGetCredentialsNotBasic()
  34. {
  35. $request = new Request('GET', '/', [
  36. 'Authorization' => 'QBasic '.base64_encode('user:pass:bla'),
  37. ]);
  38. $basic = new Basic('Dagger', $request, new Response());
  39. $this->assertNull($basic->getCredentials());
  40. }
  41. public function testRequireLogin()
  42. {
  43. $response = new Response();
  44. $request = new Request('GET', '/');
  45. $basic = new Basic('Dagger', $request, $response);
  46. $basic->requireLogin();
  47. $this->assertEquals('Basic realm="Dagger", charset="UTF-8"', $response->getHeader('WWW-Authenticate'));
  48. $this->assertEquals(401, $response->getStatus());
  49. }
  50. }