Fix bug where Validator::withData would also erase all rules

This commit is contained in:
Willem Wollebrants 2016-12-09 11:44:39 +01:00
parent 399004d172
commit f8290a8c59
2 changed files with 8 additions and 2 deletions

View File

@ -1204,8 +1204,8 @@ class Validator
public function withData($data, $fields = array())
{
$clone = clone $this;
$clone->reset();
$clone->_fields = !empty($fields) ? array_intersect_key($data, array_flip($fields)) : $data;
$clone->_errors = array();
return $clone;
}
}

View File

@ -1164,10 +1164,16 @@ class ValidateTest extends BaseTestCase
//validation failed, so must have errors
$this->assertFalse($v->validate());
$this->assertNotEmpty($v->errors());
//create copy with different data
//create copy with valid data
$v2 = $v->withData(array('name' => 'Chester Tester'));
$this->assertTrue($v2->validate());
$this->assertEmpty($v2->errors());
//create copy with invalid data
$v3 = $v->withData(array('firstname' => 'Chester'));
$this->assertFalse($v3->validate());
$this->assertNotEmpty($v3->errors());
}
}