From 37dad63deefe67e9424c129b1c1ebddf754cf9ed Mon Sep 17 00:00:00 2001 From: "J. King" Date: Mon, 6 Mar 2017 16:34:38 -0500 Subject: [PATCH] Impelemented Result->getAll() - Fixes #45 - Renamed getSingle to getValue to avoid possible confusion - Added test to ensure getValue() always returns the first datum of each row rather than going column-to-column --- lib/Database.php | 14 +++++++------- lib/Db/Result.php | 3 ++- lib/Db/ResultSQLite3.php | 11 ++++++++++- tests/Db/SQLite3/TestDbResultSQLite3.php | 18 ++++++++++++++---- 4 files changed, 33 insertions(+), 13 deletions(-) diff --git a/lib/Database.php b/lib/Database.php index 27b17a53..ed6b9aae 100644 --- a/lib/Database.php +++ b/lib/Database.php @@ -173,7 +173,7 @@ class Database { public function userExists(string $user): bool { if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]); - return (bool) $this->db->prepare("SELECT count(*) from newssync_users where id is ?", "str")->run($user)->getSingle(); + return (bool) $this->db->prepare("SELECT count(*) from newssync_users where id is ?", "str")->run($user)->getValue(); } public function userAdd(string $user, string $password = null): string { @@ -212,7 +212,7 @@ class Database { public function userPasswordGet(string $user): string { if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]); if(!$this->userExists($user)) throw new User\Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]); - return (string) $this->db->prepare("SELECT password from newssync_users where id is ?", "str")->run($user)->getSingle(); + return (string) $this->db->prepare("SELECT password from newssync_users where id is ?", "str")->run($user)->getValue(); } public function userPasswordSet(string $user, string $password = null): string { @@ -249,7 +249,7 @@ class Database { public function userRightsGet(string $user): int { if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]); - return (int) $this->db->prepare("SELECT rights from newssync_users where id is ?", "str")->run($user)->getSingle(); + return (int) $this->db->prepare("SELECT rights from newssync_users where id is ?", "str")->run($user)->getValue(); } public function userRightsSet(string $user, int $rights): bool { @@ -273,7 +273,7 @@ class Database { // If the feed doesn't already exist in the database then add it to the database after determining its validity with PicoFeed. $qFeed = $this->db->prepare("SELECT id from newssync_feeds where url is ? and username is ? and password is ?", "str", "str", "str"); - $feed = $qFeed->run($url, $fetchUser, $fetchPassword)->getSingle(); + $feed = $qFeed->run($url, $fetchUser, $fetchPassword)->getValue(); if ($feed === null) { try { $reader = new Reader; @@ -310,19 +310,19 @@ class Database { // TODO: Populate newssync_articles with contents of what was obtained from PicoFeed. // Get the ID for the feed that was just added. - $feedID = $qFeed->run($url, $fetchUser, $fetchPassword)->getSingle(); + $feedID = $qFeed->run($url, $fetchUser, $fetchPassword)->getValue(); } // Add the feed to the user's subscriptions. $this->db->prepare("INSERT INTO newssync_subscriptions(owner,feed) values(?,?)", "str", "int")->run($user, $feedID); - $sub = $this->db->prepare("SELECT id from newssync_subscriptions where owner is ? and feed is ?", "str", "int")->run($user, $feedID)->getSingle(); + $sub = $this->db->prepare("SELECT id from newssync_subscriptions where owner is ? and feed is ?", "str", "int")->run($user, $feedID)->getValue(); $this->db->commit(); return $sub; } public function subscriptionRemove(int $id): bool { $this->db->begin(); - $user = $this->db->prepare("SELECT owner from newssync_subscriptions where id is ?", "int")->run($id)->getSingle(); + $user = $this->db->prepare("SELECT owner from newssync_subscriptions where id is ?", "int")->run($id)->getValue(); if($user===null) return false; if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]); return (bool) $this->db->prepare("DELETE from newssync_subscriptions where id is ?", "int")->run($id)->changes(); diff --git a/lib/Db/Result.php b/lib/Db/Result.php index ea34b39b..35a3d4d9 100644 --- a/lib/Db/Result.php +++ b/lib/Db/Result.php @@ -10,6 +10,7 @@ interface Result extends \Iterator { function valid(); function get(); - function getSingle(); + function getAll(); + function getValue(); function changes(); } \ No newline at end of file diff --git a/lib/Db/ResultSQLite3.php b/lib/Db/ResultSQLite3.php index caaec613..2bcc0b8e 100644 --- a/lib/Db/ResultSQLite3.php +++ b/lib/Db/ResultSQLite3.php @@ -11,7 +11,7 @@ class ResultSQLite3 implements Result { // actual public methods - public function getSingle() { + public function getValue() { $this->next(); if($this->valid()) { $keys = array_keys($this->cur); @@ -25,6 +25,15 @@ class ResultSQLite3 implements Result { return ($this->valid() ? $this->cur : null); } + public function getAll() { + $out = []; + foreach($this as $row) { + $out [] = $row; + } + if(sizeof($out) < 1) return null; + return $out; + } + public function changes() { return $this->rows; } diff --git a/tests/Db/SQLite3/TestDbResultSQLite3.php b/tests/Db/SQLite3/TestDbResultSQLite3.php index 6ec8f917..b16cd455 100644 --- a/tests/Db/SQLite3/TestDbResultSQLite3.php +++ b/tests/Db/SQLite3/TestDbResultSQLite3.php @@ -56,10 +56,19 @@ class TestDbResultSQLite3 extends \PHPUnit\Framework\TestCase { function testGetSingleValues() { $set = $this->c->query("SELECT 1867 as year union select 1970 as year union select 2112 as year"); $test = new Db\ResultSQLite3($set); - $this->assertEquals(1867, $test->getSingle()); - $this->assertEquals(1970, $test->getSingle()); - $this->assertEquals(2112, $test->getSingle()); - $this->assertSame(null, $test->getSingle()); + $this->assertEquals(1867, $test->getValue()); + $this->assertEquals(1970, $test->getValue()); + $this->assertEquals(2112, $test->getValue()); + $this->assertSame(null, $test->getValue()); + } + + function testGetFirstValuesOnly() { + $set = $this->c->query("SELECT 1867 as year, 19 as century union select 1970 as year, 20 as century union select 2112 as year, 22 as century"); + $test = new Db\ResultSQLite3($set); + $this->assertEquals(1867, $test->getValue()); + $this->assertEquals(1970, $test->getValue()); + $this->assertEquals(2112, $test->getValue()); + $this->assertSame(null, $test->getValue()); } function testGetRows() { @@ -72,5 +81,6 @@ class TestDbResultSQLite3 extends \PHPUnit\Framework\TestCase { $this->assertEquals($rows[0], $test->get()); $this->assertEquals($rows[1], $test->get()); $this->assertSame(null, $test->get()); + $this->assertEquals($rows, $test->getAll()); } } \ No newline at end of file