ulogger-server/.tests/tests/SetupTest.php

60 lines
2.1 KiB
PHP
Raw Normal View History

<?php
2021-04-22 19:47:52 +02:00
use GuzzleHttp\Exception\GuzzleException;
require_once(__DIR__ . "/../lib/UloggerAPITestCase.php");
class SetupTest extends UloggerAPITestCase {
private $script = "/scripts/setup.php";
2021-04-22 19:47:52 +02:00
/**
* @throws GuzzleException
*/
public function testPrePhase(): void {
$response = $this->http->get($this->script);
2021-04-22 19:47:52 +02:00
self::assertEquals(200, $response->getStatusCode(), "Unexpected status code");
$body = (string) $response->getBody();
2021-04-22 19:47:52 +02:00
self::assertStringContainsString("<input type=\"hidden\" name=\"command\" value=\"setup\">", $body);
}
2021-04-22 19:47:52 +02:00
/**
* @throws GuzzleException
*/
public function testSetupPhase(): void {
$options = [
"http_errors" => false,
"form_params" => [ "command" => "setup" ]
];
$response = $this->http->post($this->script, $options);
2021-04-22 19:47:52 +02:00
self::assertEquals(200, $response->getStatusCode(), "Unexpected status code");
$body = (string) $response->getBody();
2021-04-22 19:47:52 +02:00
self::assertStringContainsString("<input type=\"hidden\" name=\"command\" value=\"adduser\">", $body);
}
2021-04-22 19:47:52 +02:00
/**
* @throws GuzzleException
*/
public function testAdduserPhase(): void {
$options = [
"http_errors" => false,
"form_params" => [
"command" => "adduser",
"login" => $this->testUser,
"pass" => $this->testPass,
"pass2" => $this->testPass
]
];
$response = $this->http->post($this->script, $options);
2021-04-22 19:47:52 +02:00
self::assertEquals(200, $response->getStatusCode(), "Unexpected status code");
$body = (string) $response->getBody();
2021-04-22 19:47:52 +02:00
self::assertStringContainsString("<span class=\"ok\">", $body);
self::assertEquals(2, $this->getConnection()->getRowCount("users"), "Wrong row count");
2020-02-19 18:42:44 +01:00
$expected = [ "id" => 2, "login" => $this->testUser, "admin" => 1 ];
$actual = $this->getConnection()->createQueryTable("users", "SELECT id, login, admin FROM users WHERE id = 2");
$this->assertTableContains($expected, $actual, "Wrong actual table data");
2021-04-22 19:47:52 +02:00
self::assertTrue(password_verify($this->testPass, $this->pdoGetColumn("SELECT password FROM users WHERE id = 2")), "Wrong actual password hash");
}
}
?>