Return error code for duplication errors

[PREMIUM-42]
This commit is contained in:
Pavel Dohnal
2018-02-05 14:34:15 +00:00
parent 17a25120d4
commit 8ff28fd974
2 changed files with 49 additions and 3 deletions

View File

@ -5,6 +5,8 @@ namespace MailPoet\Models;
if(!defined('ABSPATH')) exit;
class Model extends \Sudzy\ValidModel {
const DUPLICATE_RECORD = 23000;
protected $_errors;
protected $_new_record;
@ -26,13 +28,16 @@ class Model extends \Sudzy\ValidModel {
}
}
function setError($error = '') {
function setError($error = '', $error_code = null) {
if(!$error_code) {
$error_code = count($this->_errors);
}
if(!empty($error)) {
if(is_array($error)) {
$this->_errors = array_merge($this->_errors, $error);
$this->_errors = array_unique($this->_errors);
} else {
$this->_errors[] = $error;
$this->_errors[$error_code] = $error;
}
}
}
@ -54,7 +59,8 @@ class Model extends \Sudzy\ValidModel {
sprintf(
__('Another record already exists. Please specify a different "%1$s".', 'mailpoet'),
$column
)
),
Model::DUPLICATE_RECORD
);
} else {
$this->setError($e->getMessage());

View File

@ -43,6 +43,46 @@ class ModelTest extends \MailPoetTest {
);
}
function testSetErrorsWithoutCode() {
$model = MPModel::create();
$model->setError('error1');
$model->setError('error2');
expect($model->getErrors())->equals(array('error1', 'error2'));
}
function testSetErrorsAsArray() {
$model = MPModel::create();
$model->setError(array('error1'));
$model->setError(array('error2', 'error1'));
expect($model->getErrors())->equals(array('error1', 'error2'));
}
function testSetErrorsWithCode() {
$model = MPModel::create();
$model->setError('error1');
$model->setError('error2', 5);
expect($model->getErrors())->equals(array('error1', 5 => 'error2'));
}
function testSetErrorCodeForDuplicateRecords() {
$orm = Stub::makeEmpty(
'ORM',
array(
'save' => function() {
throw new \PDOException("error for key 'name'", MPModel::DUPLICATE_RECORD);
}
)
);
$model = MPModel::create();
$model->setError('error1');
$model->setError('error2', 5);
$model->set_orm($orm);
$model->save();
$errors = $model->getErrors();
expect($errors)->hasKey(MPModel::DUPLICATE_RECORD);
expect($errors[MPModel::DUPLICATE_RECORD])->contains('Please specify a different "name".');
}
function _after() {
\ORM::setDb(null);
}