| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575 |
- <?php
- /**
- * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
- * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
- *
- * Licensed under The MIT License
- * For full copyright and license information, please see the LICENSE.txt
- * Redistributions of files must retain the above copyright notice.
- *
- * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
- * @link http://cakephp.org CakePHP(tm) Project
- * @since CakePHP(tm) v 3.0
- * @license http://www.opensource.org/licenses/mit-license.php MIT License
- */
- namespace Cake\Test\TestCase\View\Form;
- use Cake\Collection\Collection;
- use Cake\Network\Request;
- use Cake\ORM\Entity;
- use Cake\ORM\Table;
- use Cake\ORM\TableRegistry;
- use Cake\TestSuite\TestCase;
- use Cake\Validation\Validator;
- use Cake\View\Form\EntityContext;
- use ArrayObject;
- /**
- * Test stub.
- */
- class Article extends Entity {
- }
- /**
- * Entity context test case.
- */
- class EntityContextTest extends TestCase {
- /**
- * Fixtures to use.
- *
- * @var array
- */
- public $fixtures = ['core.article', 'core.comment'];
- /**
- * setup method.
- *
- * @return void
- */
- public function setUp() {
- parent::setUp();
- $this->request = new Request();
- }
- /**
- * Test operations that lack a table argument.
- *
- * @return void
- */
- public function testOperationsNoTableArg() {
- $row = new Article([
- 'title' => 'Test entity',
- 'body' => 'Something new'
- ]);
- $row->errors('title', ['Title is required.']);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- ]);
- $result = $context->val('title');
- $this->assertEquals($row->title, $result);
- $result = $context->error('title');
- $this->assertEquals($row->errors('title'), $result);
- }
- /**
- * Data provider for testing collections.
- *
- * @return array
- */
- public static function collectionProvider() {
- $one = new Entity([
- 'title' => 'First post',
- 'body' => 'Stuff',
- 'user' => new Entity(['username' => 'mark'])
- ]);
- $one->errors('title', 'Required field');
- $two = new Entity([
- 'title' => 'Second post',
- 'body' => 'Some text',
- 'user' => new Entity(['username' => 'jose'])
- ]);
- $two->errors('body', 'Not long enough');
- return [
- 'array' => [[$one, $two]],
- 'basic iterator' => [new ArrayObject([$one, $two])],
- 'collection' => [new Collection([$one, $two])],
- ];
- }
- /**
- * Test operations on a collection of entities.
- *
- * @dataProvider collectionProvider
- * @return void
- */
- public function testValOnCollections($collection) {
- $context = new EntityContext($this->request, [
- 'entity' => $collection,
- 'table' => 'Articles',
- ]);
- $result = $context->val('0.title');
- $this->assertEquals('First post', $result);
- $result = $context->val('0.user.username');
- $this->assertEquals('mark', $result);
- $result = $context->val('1.title');
- $this->assertEquals('Second post', $result);
- $result = $context->val('1.user.username');
- $this->assertEquals('jose', $result);
- }
- /**
- * Test error operations on a collection of entities.
- *
- * @dataProvider collectionProvider
- * @return void
- */
- public function testErrorsOnCollections($collection) {
- $context = new EntityContext($this->request, [
- 'entity' => $collection,
- 'table' => 'Articles',
- ]);
- $this->assertTrue($context->hasError('0.title'));
- $this->assertEquals(['Required field'], $context->error('0.title'));
- $this->assertFalse($context->hasError('0.body'));
- $this->assertFalse($context->hasError('1.title'));
- $this->assertEquals(['Not long enough'], $context->error('1.body'));
- $this->assertTrue($context->hasError('1.body'));
- }
- /**
- * Test schema operations on a collection of entities.
- *
- * @dataProvider collectionProvider
- * @return void
- */
- public function testSchemaOnCollections($collection) {
- $this->_setupTables();
- $context = new EntityContext($this->request, [
- 'entity' => $collection,
- 'table' => 'Articles',
- ]);
- $this->assertEquals('string', $context->type('0.title'));
- $this->assertEquals('text', $context->type('1.body'));
- $this->assertEquals('string', $context->type('0.user.username'));
- $this->assertEquals('string', $context->type('1.user.username'));
- $this->assertNull($context->type('0.nope'));
- $expected = ['length' => 255, 'precision' => null];
- $this->assertEquals($expected, $context->attributes('0.user.username'));
- }
- /**
- * Test validation operations on a collection of entities.
- *
- * @dataProvider collectionProvider
- * @return void
- */
- public function testValidatorsOnCollections($collection) {
- $this->_setupTables();
- $context = new EntityContext($this->request, [
- 'entity' => $collection,
- 'table' => 'Articles',
- 'validator' => [
- 'Articles' => 'create',
- 'Users' => 'custom',
- ]
- ]);
- $this->assertTrue($context->isRequired('0.title'));
- $this->assertFalse($context->isRequired('1.body'));
- $this->assertTrue($context->isRequired('0.user.username'));
- }
- /**
- * Test reading data.
- *
- * @return void
- */
- public function testValBasic() {
- $row = new Entity([
- 'title' => 'Test entity',
- 'body' => 'Something new'
- ]);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- ]);
- $result = $context->val('title');
- $this->assertEquals($row->title, $result);
- $result = $context->val('body');
- $this->assertEquals($row->body, $result);
- $result = $context->val('nope');
- $this->assertNull($result);
- }
- /**
- * Test reading values from associated entities.
- *
- * @return void
- */
- public function testValAssociated() {
- $row = new Entity([
- 'title' => 'Test entity',
- 'user' => new Entity([
- 'username' => 'mark',
- 'fname' => 'Mark'
- ]),
- 'comments' => [
- new Entity(['comment' => 'Test comment']),
- new Entity(['comment' => 'Second comment']),
- ]
- ]);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- ]);
- $result = $context->val('user.fname');
- $this->assertEquals($row->user->fname, $result);
- $result = $context->val('comments.0.comment');
- $this->assertEquals($row->comments[0]->comment, $result);
- $result = $context->val('comments.1.comment');
- $this->assertEquals($row->comments[1]->comment, $result);
- $result = $context->val('comments.0.nope');
- $this->assertNull($result);
- $result = $context->val('comments.0.nope.no_way');
- $this->assertNull($result);
- }
- /**
- * Test validator as a string.
- *
- * @return void
- */
- public function testIsRequiredStringValidator() {
- $this->_setupTables();
- $context = new EntityContext($this->request, [
- 'entity' => new Entity(),
- 'table' => 'Articles',
- 'validator' => 'create',
- ]);
- $this->assertTrue($context->isRequired('title'));
- $this->assertFalse($context->isRequired('body'));
- $this->assertFalse($context->isRequired('Herp.derp.derp'));
- $this->assertFalse($context->isRequired('nope'));
- }
- /**
- * Test isRequired on associated entities.
- *
- * @return void
- */
- public function testIsRequiredAssociatedHasMany() {
- $this->_setupTables();
- $comments = TableRegistry::get('Comments');
- $validator = $comments->validator();
- $validator->add('user_id', 'number', [
- 'rule' => 'numeric',
- ]);
- $row = new Entity([
- 'title' => 'My title',
- 'comments' => [
- new Entity(['comment' => 'First comment']),
- new Entity(['comment' => 'Second comment']),
- ]
- ]);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- 'validator' => 'default',
- ]);
- $this->assertTrue($context->isRequired('comments.0.user_id'));
- $this->assertFalse($context->isRequired('comments.0.other'));
- }
- /**
- * Test isRequired on associated entities with custom validators.
- *
- * @return void
- */
- public function testIsRequiredAssociatedValidator() {
- $this->_setupTables();
- $row = new Entity([
- 'title' => 'My title',
- 'comments' => [
- new Entity(['comment' => 'First comment']),
- new Entity(['comment' => 'Second comment']),
- ]
- ]);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- 'validator' => [
- 'Articles' => 'create',
- 'Comments' => 'custom'
- ]
- ]);
- $this->assertTrue($context->isRequired('title'));
- $this->assertFalse($context->isRequired('body'));
- $this->assertTrue($context->isRequired('comments.0.comment'));
- $this->assertTrue($context->isRequired('comments.1.comment'));
- }
- /**
- * Test isRequired on associated entities.
- *
- * @return void
- */
- public function testIsRequiredAssociatedBelongsTo() {
- $this->_setupTables();
- $row = new Entity([
- 'title' => 'My title',
- 'user' => new Entity(['username' => 'Mark']),
- ]);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- 'validator' => [
- 'Articles' => 'create',
- 'Users' => 'custom'
- ]
- ]);
- $this->assertTrue($context->isRequired('user.username'));
- $this->assertFalse($context->isRequired('user.first_name'));
- }
- /**
- * Test type() basic
- *
- * @return void
- */
- public function testType() {
- $this->_setupTables();
- $row = new Entity([
- 'title' => 'My title',
- 'body' => 'Some content',
- ]);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- ]);
- $this->assertEquals('string', $context->type('title'));
- $this->assertEquals('text', $context->type('body'));
- $this->assertEquals('integer', $context->type('user_id'));
- $this->assertNull($context->type('nope'));
- }
- /**
- * Test getting types for associated records.
- *
- * @return void
- */
- public function testTypeAssociated() {
- $this->_setupTables();
- $row = new Entity([
- 'title' => 'My title',
- 'user' => new Entity(['username' => 'Mark']),
- ]);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- ]);
- $this->assertEquals('string', $context->type('user.username'));
- $this->assertEquals('text', $context->type('user.bio'));
- $this->assertNull($context->type('user.nope'));
- }
- /**
- * Test attributes for fields.
- *
- * @return void
- */
- public function testAttributes() {
- $this->_setupTables();
- $row = new Entity([
- 'title' => 'My title',
- 'user' => new Entity(['username' => 'Mark']),
- ]);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- ]);
- $expected = [
- 'length' => 255, 'precision' => null
- ];
- $this->assertEquals($expected, $context->attributes('title'));
- $expected = [
- 'length' => null, 'precision' => null
- ];
- $this->assertEquals($expected, $context->attributes('body'));
- $expected = [
- 'length' => 10, 'precision' => 3
- ];
- $this->assertEquals($expected, $context->attributes('user.rating'));
- }
- /**
- * Test hasError
- *
- * @return void
- */
- public function testHasError() {
- $this->_setupTables();
- $row = new Entity([
- 'title' => 'My title',
- 'user' => new Entity(['username' => 'Mark']),
- ]);
- $row->errors('title', []);
- $row->errors('body', 'Gotta have one');
- $row->errors('user_id', ['Required field']);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- ]);
- $this->assertFalse($context->hasError('title'));
- $this->assertFalse($context->hasError('nope'));
- $this->assertTrue($context->hasError('body'));
- $this->assertTrue($context->hasError('user_id'));
- }
- /**
- * Test hasError on associated records
- *
- * @return void
- */
- public function testHasErrorAssociated() {
- $this->_setupTables();
- $row = new Entity([
- 'title' => 'My title',
- 'user' => new Entity(['username' => 'Mark']),
- ]);
- $row->errors('title', []);
- $row->errors('body', 'Gotta have one');
- $row->user->errors('username', ['Required']);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- ]);
- $this->assertTrue($context->hasError('user.username'));
- $this->assertFalse($context->hasError('user.nope'));
- $this->assertFalse($context->hasError('no.nope'));
- }
- /**
- * Test error
- *
- * @return void
- */
- public function testError() {
- $this->_setupTables();
- $row = new Entity([
- 'title' => 'My title',
- 'user' => new Entity(['username' => 'Mark']),
- ]);
- $row->errors('title', []);
- $row->errors('body', 'Gotta have one');
- $row->errors('user_id', ['Required field']);
- $row->user->errors('username', ['Required']);
- $context = new EntityContext($this->request, [
- 'entity' => $row,
- 'table' => 'Articles',
- ]);
- $this->assertEquals([], $context->error('title'));
- $expected = ['Gotta have one'];
- $this->assertEquals($expected, $context->error('body'));
- $expected = ['Required'];
- $this->assertEquals($expected, $context->error('user.username'));
- }
- /**
- * Setup tables for tests.
- *
- * @return void
- */
- protected function _setupTables() {
- $articles = TableRegistry::get('Articles');
- $articles->belongsTo('Users');
- $articles->hasMany('Comments');
- $comments = TableRegistry::get('Comments');
- $users = TableRegistry::get('Users');
- $articles->schema([
- 'id' => ['type' => 'integer', 'length' => 11, 'null' => false],
- 'title' => ['type' => 'string', 'length' => 255],
- 'user_id' => ['type' => 'integer', 'length' => 11, 'null' => false],
- 'body' => ['type' => 'text']
- ]);
- $users->schema([
- 'id' => ['type' => 'integer', 'length' => 11],
- 'username' => ['type' => 'string', 'length' => 255],
- 'bio' => ['type' => 'text'],
- 'rating' => ['type' => 'decimal', 'length' => 10, 'precision' => 3],
- ]);
- $validator = new Validator();
- $validator->add('title', 'minlength', [
- 'rule' => ['minlength', 10]
- ])
- ->add('body', 'maxlength', [
- 'rule' => ['maxlength', 1000]
- ])->allowEmpty('body');
- $articles->validator('create', $validator);
- $validator = new Validator();
- $validator->add('username', 'length', [
- 'rule' => ['minlength', 10]
- ]);
- $users->validator('custom', $validator);
- $validator = new Validator();
- $validator->add('comment', 'length', [
- 'rule' => ['minlength', 10]
- ]);
- $comments->validator('custom', $validator);
- }
- }
|