Commit 9a214ffb authored by Peter Gribanov's avatar Peter Gribanov

Allow add previous exception in ConversionException

parent a0e23739
...@@ -26,11 +26,11 @@ class ConversionException extends DBALException ...@@ -26,11 +26,11 @@ class ConversionException extends DBALException
* *
* @return \Doctrine\DBAL\Types\ConversionException * @return \Doctrine\DBAL\Types\ConversionException
*/ */
public static function conversionFailed($value, $toType) public static function conversionFailed($value, $toType, ?Throwable $previous = null)
{ {
$value = strlen($value) > 32 ? substr($value, 0, 20) . '...' : $value; $value = strlen($value) > 32 ? substr($value, 0, 20) . '...' : $value;
return new self('Could not convert database value "' . $value . '" to Doctrine Type ' . $toType); return new self('Could not convert database value "' . $value . '" to Doctrine Type ' . $toType, 0, $previous);
} }
/** /**
...@@ -64,8 +64,12 @@ class ConversionException extends DBALException ...@@ -64,8 +64,12 @@ class ConversionException extends DBALException
* *
* @return \Doctrine\DBAL\Types\ConversionException * @return \Doctrine\DBAL\Types\ConversionException
*/ */
public static function conversionFailedInvalidType($value, $toType, array $possibleTypes) public static function conversionFailedInvalidType(
{ $value,
$toType,
array $possibleTypes,
?Throwable $previous = null
) {
$actualType = is_object($value) ? get_class($value) : gettype($value); $actualType = is_object($value) ? get_class($value) : gettype($value);
if (is_scalar($value)) { if (is_scalar($value)) {
...@@ -75,7 +79,7 @@ class ConversionException extends DBALException ...@@ -75,7 +79,7 @@ class ConversionException extends DBALException
$actualType, $actualType,
$toType, $toType,
implode(', ', $possibleTypes) implode(', ', $possibleTypes)
)); ), 0, $previous);
} }
return new self(sprintf( return new self(sprintf(
...@@ -83,7 +87,7 @@ class ConversionException extends DBALException ...@@ -83,7 +87,7 @@ class ConversionException extends DBALException
$actualType, $actualType,
$toType, $toType,
implode(', ', $possibleTypes) implode(', ', $possibleTypes)
)); ), 0, $previous);
} }
public static function conversionFailedSerialization($value, $format, $error) public static function conversionFailedSerialization($value, $format, $error)
......
...@@ -3,13 +3,23 @@ ...@@ -3,13 +3,23 @@
namespace Doctrine\Tests\DBAL\Types; namespace Doctrine\Tests\DBAL\Types;
use Doctrine\DBAL\Types\ConversionException; use Doctrine\DBAL\Types\ConversionException;
use Exception;
use PHPUnit\Framework\TestCase; use PHPUnit\Framework\TestCase;
use stdClass; use stdClass;
use Throwable;
use function tmpfile; use function tmpfile;
class ConversionExceptionTest extends TestCase class ConversionExceptionTest extends TestCase
{ {
public function testConversionFailedPreviousException() : void
{
$previous = $this->createMock(Throwable::class);
$exception = ConversionException::conversionFailed('foo', 'foo', $previous);
self::assertInstanceOf(ConversionException::class, $exception);
self::assertSame($previous, $exception->getPrevious());
}
/** /**
* @param mixed $scalarValue * @param mixed $scalarValue
* *
...@@ -44,9 +54,19 @@ class ConversionExceptionTest extends TestCase ...@@ -44,9 +54,19 @@ class ConversionExceptionTest extends TestCase
); );
} }
public function testConversionFailedInvalidTypePreviousException() : void
{
$previous = $this->createMock(Throwable::class);
$exception = ConversionException::conversionFailedInvalidType('foo', 'foo', ['bar', 'baz'], $previous);
self::assertInstanceOf(ConversionException::class, $exception);
self::assertSame($previous, $exception->getPrevious());
}
public function testConversionFailedFormatPreservesPreviousException() : void public function testConversionFailedFormatPreservesPreviousException() : void
{ {
$previous = new Exception(); $previous = $this->createMock(Throwable::class);
$exception = ConversionException::conversionFailedFormat('foo', 'bar', 'baz', $previous); $exception = ConversionException::conversionFailedFormat('foo', 'bar', 'baz', $previous);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment