Skip to content

Commit

Permalink
Merge pull request #445 from utopia-php/feat-resizing-string-attributes
Browse files Browse the repository at this point in the history
Add Truncate Error class for resizing string attributes
  • Loading branch information
abnegate authored Aug 30, 2024
2 parents 3f17072 + 20745fc commit 87fa42f
Show file tree
Hide file tree
Showing 5 changed files with 18 additions and 7 deletions.
3 changes: 2 additions & 1 deletion src/Database/Adapter/MariaDB.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
use Utopia\Database\Exception as DatabaseException;
use Utopia\Database\Exception\Duplicate as DuplicateException;
use Utopia\Database\Exception\Timeout as TimeoutException;
use Utopia\Database\Exception\Truncate as TruncateException;
use Utopia\Database\Query;
use Utopia\Database\Validator\Authorization;

Expand Down Expand Up @@ -2247,7 +2248,7 @@ protected function processException(PDOException $e): void
// Data is too big for column resize
if (($e->getCode() === '22001' && isset($e->errorInfo[1]) && $e->errorInfo[1] === 1406) ||
($e->getCode() === '01000' && isset($e->errorInfo[1]) && $e->errorInfo[1] === 1265)) {
throw new DatabaseException('Resize would result in data truncation', $e->getCode(), $e);
throw new TruncateException('Resize would result in data truncation', $e->getCode(), $e);
}

// Duplicate index
Expand Down
3 changes: 2 additions & 1 deletion src/Database/Adapter/MySQL.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
use Utopia\Database\Exception as DatabaseException;
use Utopia\Database\Exception\Duplicate as DuplicateException;
use Utopia\Database\Exception\Timeout as TimeoutException;
use Utopia\Database\Exception\Truncate as TruncateException;

class MySQL extends MariaDB
{
Expand Down Expand Up @@ -112,7 +113,7 @@ protected function processException(PDOException $e): void
// Data is too big for column resize
if (($e->getCode() === '22001' && isset($e->errorInfo[1]) && $e->errorInfo[1] === 1406) ||
($e->getCode() === '01000' && isset($e->errorInfo[1]) && $e->errorInfo[1] === 1265)) {
throw new DatabaseException('Resize would result in data truncation', $e->getCode(), $e);
throw new TruncateException('Resize would result in data truncation', $e->getCode(), $e);
}

throw $e;
Expand Down
3 changes: 2 additions & 1 deletion src/Database/Adapter/Postgres.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
use Utopia\Database\Exception as DatabaseException;
use Utopia\Database\Exception\Duplicate;
use Utopia\Database\Exception\Timeout;
use Utopia\Database\Exception\Truncate as TruncateException;
use Utopia\Database\Query;
use Utopia\Database\Validator\Authorization;

Expand Down Expand Up @@ -2218,7 +2219,7 @@ protected function processException(PDOException $e): void

// Data is too big for column resize
if ($e->getCode() === '22001' && isset($e->errorInfo[1]) && $e->errorInfo[1] === 7) {
throw new DatabaseException('Resize would result in data truncation', $e->getCode(), $e);
throw new TruncateException('Resize would result in data truncation', $e->getCode(), $e);
}

throw $e;
Expand Down
9 changes: 9 additions & 0 deletions src/Database/Exception/Truncate.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
<?php

namespace Utopia\Database\Exception;

use Utopia\Database\Exception;

class Truncate extends Exception
{
}
7 changes: 3 additions & 4 deletions tests/e2e/Adapter/Base.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
use Utopia\Database\Exception\Restricted as RestrictedException;
use Utopia\Database\Exception\Structure as StructureException;
use Utopia\Database\Exception\Timeout as TimeoutException;
use Utopia\Database\Exception\Truncate as TruncateException;
use Utopia\Database\Helpers\ID;
use Utopia\Database\Helpers\Permission;
use Utopia\Database\Helpers\Role;
Expand Down Expand Up @@ -5957,8 +5958,7 @@ public function testUpdateAttributeSize(): void
try {
static::getDatabase()->updateAttribute('resize_test', 'resize_me', Database::VAR_STRING, 128, true);
$this->fail('Succeeded updating attribute size to smaller size with data that is too big');
} catch (DatabaseException $e) {
$this->assertEquals('Resize would result in data truncation', $e->getMessage());
} catch (TruncateException $e) {
}

// Test going down in size when data isn't too big.
Expand All @@ -5972,8 +5972,7 @@ public function testUpdateAttributeSize(): void
try {
static::getDatabase()->updateAttribute('resize_test', 'resize_me', Database::VAR_STRING, 128, true);
$this->fail('Succeeded updating attribute size to smaller size with data that is too big');
} catch (DatabaseException $e) {
$this->assertEquals('Resize would result in data truncation', $e->getMessage());
} catch (TruncateException $e) {
}
}

Expand Down

0 comments on commit 87fa42f

Please sign in to comment.