Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/server.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/tests/lib
diff options
context:
space:
mode:
authorCôme Chilliet <91878298+come-nc@users.noreply.github.com>2022-03-29 10:38:21 +0300
committerGitHub <noreply@github.com>2022-03-29 10:38:21 +0300
commit4a4f250a2b733f915e8b465bc995ea8ac18a8fbc (patch)
treeef9ed30f7cfb7caf803bcc9a67f60ff9ba16a04d /tests/lib
parentbdfc6563ab1b4b61102afd29073927a0c25d1fd4 (diff)
parent7407a324d94afa7009a4efa3a8fbe71734e6ea85 (diff)
Merge pull request #31696 from nextcloud/fix/user_ldap-fix-migration-lengthcheck-oracle
Use getLengthExpression to measure field length instead of like
Diffstat (limited to 'tests/lib')
-rw-r--r--tests/lib/DB/QueryBuilder/FunctionBuilderTest.php50
1 files changed, 50 insertions, 0 deletions
diff --git a/tests/lib/DB/QueryBuilder/FunctionBuilderTest.php b/tests/lib/DB/QueryBuilder/FunctionBuilderTest.php
index 3f4b8bb7524..08392b09d8d 100644
--- a/tests/lib/DB/QueryBuilder/FunctionBuilderTest.php
+++ b/tests/lib/DB/QueryBuilder/FunctionBuilderTest.php
@@ -336,6 +336,56 @@ class FunctionBuilderTest extends TestCase {
$this->assertGreaterThan(1, $column);
}
+ public function octetLengthProvider() {
+ return [
+ ['', 0],
+ ['foobar', 6],
+ ['fé', 3],
+ ['šđčćž', 10],
+ ];
+ }
+
+ /**
+ * @dataProvider octetLengthProvider
+ */
+ public function testOctetLength(string $str, int $bytes) {
+ $query = $this->connection->getQueryBuilder();
+
+ $query->select($query->func()->octetLength($query->createNamedParameter($str, IQueryBuilder::PARAM_STR)));
+ $query->from('appconfig')
+ ->setMaxResults(1);
+
+ $result = $query->execute();
+ $column = $result->fetchOne();
+ $result->closeCursor();
+ $this->assertEquals($bytes, $column);
+ }
+
+ public function charLengthProvider() {
+ return [
+ ['', 0],
+ ['foobar', 6],
+ ['fé', 2],
+ ['šđčćž', 5],
+ ];
+ }
+
+ /**
+ * @dataProvider charLengthProvider
+ */
+ public function testCharLength(string $str, int $bytes) {
+ $query = $this->connection->getQueryBuilder();
+
+ $query->select($query->func()->charLength($query->createNamedParameter($str, IQueryBuilder::PARAM_STR)));
+ $query->from('appconfig')
+ ->setMaxResults(1);
+
+ $result = $query->execute();
+ $column = $result->fetchOne();
+ $result->closeCursor();
+ $this->assertEquals($bytes, $column);
+ }
+
private function setUpMinMax($value) {
$query = $this->connection->getQueryBuilder();