From 9f690216913fffc6b4c93545492ea26905a5fe61 Mon Sep 17 00:00:00 2001 From: Thomas Müller Date: Thu, 19 Nov 2015 17:18:22 +0100 Subject: lastInsertId() is properly working with Oracle if the table name is properly passed in --- tests/lib/repair/cleantags.php | 16 +--------------- tests/lib/repair/oldgroupmembershipsharestest.php | 21 +++------------------ tests/lib/repair/repairinvalidsharestest.php | 14 +++----------- 3 files changed, 7 insertions(+), 44 deletions(-) (limited to 'tests') diff --git a/tests/lib/repair/cleantags.php b/tests/lib/repair/cleantags.php index a511daa03d6..896dd333cc2 100644 --- a/tests/lib/repair/cleantags.php +++ b/tests/lib/repair/cleantags.php @@ -165,20 +165,6 @@ class CleanTags extends \Test\TestCase { * @return int */ protected function getLastInsertID($tableName, $idName) { - $id = $this->connection->lastInsertId(); - if ($id) { - return $id; - } - - // FIXME !!!! ORACLE WORKAROUND DO NOT COPY - // FIXME INSTEAD HELP FIXING DOCTRINE - // FIXME https://github.com/owncloud/core/issues/13303 - // FIXME ALSO FIX https://github.com/owncloud/core/commit/2dd85ec984c12d3be401518f22c90d2327bec07a - $qb = $this->connection->getQueryBuilder(); - $result = $qb->select($qb->createFunction('MAX(`' . $idName . '`)')) - ->from($tableName) - ->execute(); - - return (int) $result->fetchColumn(); + return $this->connection->lastInsertId("*PREFIX*$tableName"); } } diff --git a/tests/lib/repair/oldgroupmembershipsharestest.php b/tests/lib/repair/oldgroupmembershipsharestest.php index 74f68bd7899..272e1ef09c4 100644 --- a/tests/lib/repair/oldgroupmembershipsharestest.php +++ b/tests/lib/repair/oldgroupmembershipsharestest.php @@ -72,7 +72,7 @@ class OldGroupMembershipSharesTest extends \Test\TestCase { ->orderBy('id', 'ASC') ->execute(); $rows = $result->fetchAll(); - $this->assertSame([['id' => $parent], ['id' => $group2], ['id' => $user1], ['id' => $member], ['id' => $notAMember]], $rows); + $this->assertEquals([['id' => $parent], ['id' => $group2], ['id' => $user1], ['id' => $member], ['id' => $notAMember]], $rows); $result->closeCursor(); $repair->run(); @@ -83,7 +83,7 @@ class OldGroupMembershipSharesTest extends \Test\TestCase { ->orderBy('id', 'ASC') ->execute(); $rows = $result->fetchAll(); - $this->assertSame([['id' => $parent], ['id' => $group2], ['id' => $user1], ['id' => $member]], $rows); + $this->assertEquals([['id' => $parent], ['id' => $group2], ['id' => $user1], ['id' => $member]], $rows); $result->closeCursor(); } @@ -118,21 +118,6 @@ class OldGroupMembershipSharesTest extends \Test\TestCase { ->values($shareValues) ->execute(); - return $this->getLastShareId(); - } - - /** - * @return int - */ - protected function getLastShareId() { - // select because lastInsertId does not work with OCI - $query = $this->connection->getQueryBuilder(); - $result = $query->select('id') - ->from('share') - ->orderBy('id', 'DESC') - ->execute(); - $row = $result->fetch(); - $result->closeCursor(); - return $row['id']; + return $this->connection->lastInsertId('*PREFIX*share'); } } diff --git a/tests/lib/repair/repairinvalidsharestest.php b/tests/lib/repair/repairinvalidsharestest.php index 005a2db2344..e8dcaa4da97 100644 --- a/tests/lib/repair/repairinvalidsharestest.php +++ b/tests/lib/repair/repairinvalidsharestest.php @@ -162,7 +162,7 @@ class RepairInvalidSharesTest extends TestCase { ->orderBy('id', 'ASC') ->execute(); $rows = $result->fetchAll(); - $this->assertSame([['id' => $parent], ['id' => $validChild], ['id' => $invalidChild]], $rows); + $this->assertEquals([['id' => $parent], ['id' => $validChild], ['id' => $invalidChild]], $rows); $result->closeCursor(); $this->repair->run(); @@ -173,7 +173,7 @@ class RepairInvalidSharesTest extends TestCase { ->orderBy('id', 'ASC') ->execute(); $rows = $result->fetchAll(); - $this->assertSame([['id' => $parent], ['id' => $validChild]], $rows); + $this->assertEquals([['id' => $parent], ['id' => $validChild]], $rows); $result->closeCursor(); } @@ -181,15 +181,7 @@ class RepairInvalidSharesTest extends TestCase { * @return int */ protected function getLastShareId() { - // select because lastInsertId does not work with OCI - $query = $this->connection->getQueryBuilder(); - $result = $query->select('id') - ->from('share') - ->orderBy('id', 'DESC') - ->execute(); - $row = $result->fetch(); - $result->closeCursor(); - return $row['id']; + return $this->connection->lastInsertId('*PREFIX*share'); } } -- cgit v1.2.3