2018-11-22 19:55:54 -05:00
< ? php
2024-12-27 20:28:38 -05:00
2018-11-22 19:55:54 -05:00
/** @ license MIT
* Copyright 2017 J . King , Dustin Wilson et al .
* See LICENSE and AUTHORS files for details */
declare ( strict_types = 1 );
2021-04-14 11:17:01 -04:00
2018-11-22 19:55:54 -05:00
namespace JKingWeb\Arsse\TestCase\Db ;
use JKingWeb\Arsse\Db\Result ;
abstract class BaseResult extends \JKingWeb\Arsse\Test\AbstractTest {
2018-12-20 18:06:28 -05:00
protected static $insertDefault = " INSERT INTO arsse_test default values " ;
2020-11-03 17:52:20 -05:00
protected static $selectBlob = " SELECT x'DEADBEEF' as \" blob \" " ;
2020-11-09 16:49:42 -05:00
protected static $selectNullBlob = " SELECT null as \" blob \" " ;
2018-11-27 14:26:33 -05:00
protected static $interface ;
2018-11-22 19:55:54 -05:00
protected $resultClass ;
abstract protected function makeResult ( string $q ) : array ;
2019-10-16 14:42:43 -04:00
public static function setUpBeforeClass () : void {
2018-11-27 14:26:33 -05:00
// establish a clean baseline
static :: clearData ();
static :: setConf ();
2019-01-12 12:43:06 -05:00
static :: $interface = static :: dbInterface ();
2018-11-27 14:26:33 -05:00
}
2020-03-01 15:16:50 -05:00
2019-10-16 14:42:43 -04:00
public function setUp () : void {
2021-02-27 15:24:02 -05:00
parent :: setUp ();
2018-11-22 19:55:54 -05:00
self :: setConf ();
2018-11-27 14:26:33 -05:00
if ( ! static :: $interface ) {
$this -> markTestSkipped ( static :: $implementation . " database driver not available " );
2018-11-22 19:55:54 -05:00
}
2018-11-27 14:26:33 -05:00
// completely clear the database
2019-01-12 12:43:06 -05:00
static :: dbRaze ( static :: $interface );
$this -> resultClass = static :: $dbResultClass ;
2018-11-22 19:55:54 -05:00
}
2019-10-16 14:42:43 -04:00
public static function tearDownAfterClass () : void {
2018-12-10 13:17:04 -05:00
if ( static :: $interface ) {
// completely clear the database
2019-01-12 12:43:06 -05:00
static :: dbRaze ( static :: $interface );
2018-12-10 13:17:04 -05:00
}
static :: $interface = null ;
2021-02-27 15:24:02 -05:00
self :: clearData ( true );
2018-11-22 19:55:54 -05:00
}
2020-01-20 13:52:48 -05:00
public function testConstructResult () : void {
2018-11-22 19:55:54 -05:00
$this -> assertInstanceOf ( Result :: class , new $this -> resultClass ( ... $this -> makeResult ( " SELECT 1 " )));
}
2020-01-20 13:52:48 -05:00
public function testGetChangeCountAndLastInsertId () : void {
2018-12-06 17:46:00 -05:00
$this -> makeResult ( static :: $createMeta );
2018-12-20 18:06:28 -05:00
$r = new $this -> resultClass ( ... $this -> makeResult ( " INSERT INTO arsse_meta( \" key \" ,value) values('test', 1) " ));
2018-12-06 17:46:00 -05:00
$this -> assertSame ( 1 , $r -> changes ());
2024-12-25 10:11:28 -05:00
// FIXME: In PHP 8.4 the result seems to have changed for the SQLite3 class
// $this->assertSame(0, $r->lastId());
2018-12-06 17:46:00 -05:00
}
2020-01-20 13:52:48 -05:00
public function testGetChangeCountAndLastInsertIdBis () : void {
2018-12-06 17:46:00 -05:00
$this -> makeResult ( static :: $createTest );
2018-12-20 18:06:28 -05:00
$r = new $this -> resultClass ( ... $this -> makeResult ( static :: $insertDefault ));
2018-12-06 17:46:00 -05:00
$this -> assertSame ( 1 , $r -> changes ());
$this -> assertSame ( 1 , $r -> lastId ());
2018-12-20 18:06:28 -05:00
$r = new $this -> resultClass ( ... $this -> makeResult ( static :: $insertDefault ));
2018-12-06 17:46:00 -05:00
$this -> assertSame ( 1 , $r -> changes ());
$this -> assertSame ( 2 , $r -> lastId ());
2018-11-22 19:55:54 -05:00
}
2020-01-20 13:52:48 -05:00
public function testIterateOverResults () : void {
2018-11-22 19:55:54 -05:00
$exp = [ 0 => 1 , 1 => 2 , 2 => 3 ];
2019-01-12 12:43:06 -05:00
$exp = static :: $stringOutput ? $this -> stringify ( $exp ) : $exp ;
2018-11-22 19:55:54 -05:00
foreach ( new $this -> resultClass ( ... $this -> makeResult ( " SELECT 1 as col union select 2 as col union select 3 as col " )) as $index => $row ) {
$rows [ $index ] = $row [ 'col' ];
}
$this -> assertSame ( $exp , $rows );
}
2020-01-20 13:52:48 -05:00
public function testIterateOverResultsTwice () : void {
2018-11-22 19:55:54 -05:00
$exp = [ 0 => 1 , 1 => 2 , 2 => 3 ];
2019-01-12 12:43:06 -05:00
$exp = static :: $stringOutput ? $this -> stringify ( $exp ) : $exp ;
2018-11-22 19:55:54 -05:00
$result = new $this -> resultClass ( ... $this -> makeResult ( " SELECT 1 as col union select 2 as col union select 3 as col " ));
foreach ( $result as $index => $row ) {
$rows [ $index ] = $row [ 'col' ];
}
$this -> assertSame ( $exp , $rows );
$this -> assertException ( " resultReused " , " Db " );
foreach ( $result as $row ) {
$rows [] = $row [ 'col' ];
}
}
2020-01-20 13:52:48 -05:00
public function testGetSingleValues () : void {
2018-11-22 19:55:54 -05:00
$exp = [ 1867 , 1970 , 2112 ];
2019-01-12 12:43:06 -05:00
$exp = static :: $stringOutput ? $this -> stringify ( $exp ) : $exp ;
2018-12-06 17:46:00 -05:00
$test = new $this -> resultClass ( ... $this -> makeResult ( " SELECT 1867 as year union all select 1970 as year union all select 2112 as year " ));
2018-11-22 19:55:54 -05:00
$this -> assertSame ( $exp [ 0 ], $test -> getValue ());
$this -> assertSame ( $exp [ 1 ], $test -> getValue ());
$this -> assertSame ( $exp [ 2 ], $test -> getValue ());
$this -> assertSame ( null , $test -> getValue ());
}
2020-01-20 13:52:48 -05:00
public function testGetFirstValuesOnly () : void {
2018-11-22 19:55:54 -05:00
$exp = [ 1867 , 1970 , 2112 ];
2019-01-12 12:43:06 -05:00
$exp = static :: $stringOutput ? $this -> stringify ( $exp ) : $exp ;
2018-12-06 17:46:00 -05:00
$test = new $this -> resultClass ( ... $this -> makeResult ( " SELECT 1867 as year, 19 as century union all select 1970 as year, 20 as century union all select 2112 as year, 22 as century " ));
2018-11-22 19:55:54 -05:00
$this -> assertSame ( $exp [ 0 ], $test -> getValue ());
$this -> assertSame ( $exp [ 1 ], $test -> getValue ());
$this -> assertSame ( $exp [ 2 ], $test -> getValue ());
$this -> assertSame ( null , $test -> getValue ());
}
2020-01-20 13:52:48 -05:00
public function testGetRows () : void {
2018-11-22 19:55:54 -05:00
$exp = [
[ 'album' => '2112' , 'track' => '2112' ],
[ 'album' => 'Clockwork Angels' , 'track' => 'The Wreckers' ],
];
$test = new $this -> resultClass ( ... $this -> makeResult ( " SELECT '2112' as album, '2112' as track union select 'Clockwork Angels' as album, 'The Wreckers' as track " ));
$this -> assertSame ( $exp [ 0 ], $test -> getRow ());
$this -> assertSame ( $exp [ 1 ], $test -> getRow ());
$this -> assertSame ( null , $test -> getRow ());
}
2020-01-20 13:52:48 -05:00
public function testGetAllRows () : void {
2018-11-22 19:55:54 -05:00
$exp = [
[ 'album' => '2112' , 'track' => '2112' ],
[ 'album' => 'Clockwork Angels' , 'track' => 'The Wreckers' ],
];
$test = new $this -> resultClass ( ... $this -> makeResult ( " SELECT '2112' as album, '2112' as track union select 'Clockwork Angels' as album, 'The Wreckers' as track " ));
$this -> assertEquals ( $exp , $test -> getAll ());
}
2020-11-03 17:52:20 -05:00
public function testGetBlobRow () : void {
$exp = [ 'blob' => hex2bin ( " DEADBEEF " )];
2020-11-03 18:57:26 -05:00
$test = new $this -> resultClass ( ... $this -> makeResult ( static :: $selectBlob ));
2020-11-03 17:52:20 -05:00
$this -> assertEquals ( $exp , $test -> getRow ());
}
public function testGetBlobValue () : void {
$exp = hex2bin ( " DEADBEEF " );
2020-11-03 18:57:26 -05:00
$test = new $this -> resultClass ( ... $this -> makeResult ( static :: $selectBlob ));
2020-11-03 17:52:20 -05:00
$this -> assertEquals ( $exp , $test -> getValue ());
}
2020-11-09 16:49:42 -05:00
public function testGetNullBlobRow () : void {
$exp = [ 'blob' => null ];
$test = new $this -> resultClass ( ... $this -> makeResult ( static :: $selectNullBlob ));
$this -> assertEquals ( $exp , $test -> getRow ());
}
public function testGetNullBlobValue () : void {
$test = new $this -> resultClass ( ... $this -> makeResult ( static :: $selectNullBlob ));
$this -> assertNull ( $test -> getValue ());
}
2018-11-22 19:55:54 -05:00
}