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; if(!defined('ABSPATH')) exit;
class Model extends \Sudzy\ValidModel { class Model extends \Sudzy\ValidModel {
const DUPLICATE_RECORD = 23000;
protected $_errors; protected $_errors;
protected $_new_record; 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(!empty($error)) {
if(is_array($error)) { if(is_array($error)) {
$this->_errors = array_merge($this->_errors, $error); $this->_errors = array_merge($this->_errors, $error);
$this->_errors = array_unique($this->_errors); $this->_errors = array_unique($this->_errors);
} else { } else {
$this->_errors[] = $error; $this->_errors[$error_code] = $error;
} }
} }
} }
@ -54,7 +59,8 @@ class Model extends \Sudzy\ValidModel {
sprintf( sprintf(
__('Another record already exists. Please specify a different "%1$s".', 'mailpoet'), __('Another record already exists. Please specify a different "%1$s".', 'mailpoet'),
$column $column
) ),
Model::DUPLICATE_RECORD
); );
} else { } else {
$this->setError($e->getMessage()); $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() { function _after() {
\ORM::setDb(null); \ORM::setDb(null);
} }