mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-08 17:02:41 +00:00
Fix most test failures
MySQL is still being stubborn. It may be a type-conversion issue.
This commit is contained in:
parent
51ce4ae92b
commit
2822864a85
3 changed files with 27 additions and 4 deletions
|
@ -165,7 +165,7 @@ class Driver extends \JKingWeb\Arsse\Db\AbstractDriver {
|
||||||
$drv->report_mode = \MYSQLI_REPORT_OFF;
|
$drv->report_mode = \MYSQLI_REPORT_OFF;
|
||||||
$this->db = mysqli_init();
|
$this->db = mysqli_init();
|
||||||
$this->db->options(\MYSQLI_SET_CHARSET_NAME, "utf8mb4");
|
$this->db->options(\MYSQLI_SET_CHARSET_NAME, "utf8mb4");
|
||||||
$this->db->options(\MYSQLI_OPT_INT_AND_FLOAT_NATIVE, false);
|
$this->db->options(\MYSQLI_OPT_INT_AND_FLOAT_NATIVE, true);
|
||||||
$this->db->options(\MYSQLI_OPT_CONNECT_TIMEOUT, ceil(Arsse::$conf->dbTimeoutConnect));
|
$this->db->options(\MYSQLI_OPT_CONNECT_TIMEOUT, ceil(Arsse::$conf->dbTimeoutConnect));
|
||||||
@$this->db->real_connect($host, $user, $password, $db, $port, $socket);
|
@$this->db->real_connect($host, $user, $password, $db, $port, $socket);
|
||||||
if ($this->db->connect_errno) {
|
if ($this->db->connect_errno) {
|
||||||
|
|
|
@ -415,9 +415,11 @@ abstract class AbstractTest extends \PHPUnit\Framework\TestCase {
|
||||||
foreach ($info['rows'] as $r) {
|
foreach ($info['rows'] as $r) {
|
||||||
$row = [];
|
$row = [];
|
||||||
foreach ($r as $c => $v) {
|
foreach ($r as $c => $v) {
|
||||||
|
// store any date values for later comparison
|
||||||
if ($types[$c] === "datetime") {
|
if ($types[$c] === "datetime") {
|
||||||
$dates[] = $v;
|
$dates[] = $v;
|
||||||
}
|
}
|
||||||
|
// serialize to CSV, null being represented by no value
|
||||||
if ($v === null) {
|
if ($v === null) {
|
||||||
$row[] = "";
|
$row[] = "";
|
||||||
} elseif (static::$stringOutput || is_string($v)) {
|
} elseif (static::$stringOutput || is_string($v)) {
|
||||||
|
@ -435,9 +437,11 @@ abstract class AbstractTest extends \PHPUnit\Framework\TestCase {
|
||||||
$data = $drv->prepare("SELECT $cols from $table")->run()->getAll();
|
$data = $drv->prepare("SELECT $cols from $table")->run()->getAll();
|
||||||
$types = $info['columns'];
|
$types = $info['columns'];
|
||||||
$act = [];
|
$act = [];
|
||||||
|
$extra = [];
|
||||||
foreach ($data as $r) {
|
foreach ($data as $r) {
|
||||||
$row = [];
|
$row = [];
|
||||||
foreach ($r as $c => $v) {
|
foreach ($r as $c => $v) {
|
||||||
|
// account for dates which might be off by one second
|
||||||
if ($types[$c] === "datetime") {
|
if ($types[$c] === "datetime") {
|
||||||
if (array_search($v, $dates, true) === false) {
|
if (array_search($v, $dates, true) === false) {
|
||||||
$v = Date::transform(Date::sub("PT1S", $v), "sql");
|
$v = Date::transform(Date::sub("PT1S", $v), "sql");
|
||||||
|
@ -457,8 +461,27 @@ abstract class AbstractTest extends \PHPUnit\Framework\TestCase {
|
||||||
$row[] = (string) $v;
|
$row[] = (string) $v;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$act[] = implode(",", $row);
|
$row = implode(",", $row);
|
||||||
|
// now search for the actual output row in the expected output
|
||||||
|
$found = array_keys($exp, $row, true);
|
||||||
|
foreach ($found as $k) {
|
||||||
|
if(!isset($act[$k])) {
|
||||||
|
$act[$k] = $row;
|
||||||
|
// skip to the next row
|
||||||
|
continue 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// if the row was not found, add it to a buffer which will be added to the actual output once all found rows are processed
|
||||||
|
$extra[] = $row;
|
||||||
}
|
}
|
||||||
|
// add any unfound rows to the end of the actual array
|
||||||
|
$base = sizeof($exp) + 1;
|
||||||
|
foreach ($extra as $k => $v) {
|
||||||
|
$act[$base + $k] = $v;
|
||||||
|
}
|
||||||
|
// sort the actual output by keys
|
||||||
|
ksort($act);
|
||||||
|
// finally perform the comparison to be shown to the tester
|
||||||
$this->assertSame($exp, $act, "Actual table $table does not match expectations");
|
$this->assertSame($exp, $act, "Actual table $table does not match expectations");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ trait MySQL {
|
||||||
protected static $dbResultClass = \JKingWeb\Arsse\Db\MySQL\Result::class;
|
protected static $dbResultClass = \JKingWeb\Arsse\Db\MySQL\Result::class;
|
||||||
protected static $dbStatementClass = \JKingWeb\Arsse\Db\MySQL\Statement::class;
|
protected static $dbStatementClass = \JKingWeb\Arsse\Db\MySQL\Statement::class;
|
||||||
protected static $dbDriverClass = \JKingWeb\Arsse\Db\MySQL\Driver::class;
|
protected static $dbDriverClass = \JKingWeb\Arsse\Db\MySQL\Driver::class;
|
||||||
protected static $stringOutput = true;
|
protected static $stringOutput = false;
|
||||||
|
|
||||||
public static function dbInterface() {
|
public static function dbInterface() {
|
||||||
if (!class_exists("mysqli")) {
|
if (!class_exists("mysqli")) {
|
||||||
|
@ -25,7 +25,7 @@ trait MySQL {
|
||||||
$drv = new \mysqli_driver;
|
$drv = new \mysqli_driver;
|
||||||
$drv->report_mode = \MYSQLI_REPORT_OFF;
|
$drv->report_mode = \MYSQLI_REPORT_OFF;
|
||||||
$d = mysqli_init();
|
$d = mysqli_init();
|
||||||
$d->options(\MYSQLI_OPT_INT_AND_FLOAT_NATIVE, false);
|
$d->options(\MYSQLI_OPT_INT_AND_FLOAT_NATIVE, true);
|
||||||
$d->options(\MYSQLI_SET_CHARSET_NAME, "utf8mb4");
|
$d->options(\MYSQLI_SET_CHARSET_NAME, "utf8mb4");
|
||||||
@$d->real_connect(Arsse::$conf->dbMySQLHost, Arsse::$conf->dbMySQLUser, Arsse::$conf->dbMySQLPass, Arsse::$conf->dbMySQLDb, Arsse::$conf->dbMySQLPort);
|
@$d->real_connect(Arsse::$conf->dbMySQLHost, Arsse::$conf->dbMySQLUser, Arsse::$conf->dbMySQLPass, Arsse::$conf->dbMySQLDb, Arsse::$conf->dbMySQLPort);
|
||||||
if ($d->connect_errno) {
|
if ($d->connect_errno) {
|
||||||
|
|
Loading…
Reference in a new issue