3566 lines
111 KiB
PHP
3566 lines
111 KiB
PHP
<?php
|
|
/**
|
|
* SetTest file
|
|
*
|
|
* CakePHP(tm) Tests <http://book.cakephp.org/2.0/en/development/testing.html>
|
|
* 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://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
|
|
* @package Cake.Test.Case.Utility
|
|
* @since CakePHP(tm) v 1.2.0.4206
|
|
* @license http://www.opensource.org/licenses/mit-license.php MIT License
|
|
*/
|
|
|
|
App::uses('Set', 'Utility');
|
|
App::uses('Model', 'Model');
|
|
|
|
/**
|
|
* SetTest class
|
|
*
|
|
* @package Cake.Test.Case.Utility
|
|
*/
|
|
class SetTest extends CakeTestCase {
|
|
|
|
/**
|
|
* testNumericKeyExtraction method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testNumericKeyExtraction() {
|
|
$data = array('plugin' => null, 'controller' => '', 'action' => '', 1, 'whatever');
|
|
$this->assertEquals(array(1, 'whatever'), Set::extract($data, '{n}'));
|
|
$this->assertEquals(array('plugin' => null, 'controller' => '', 'action' => ''), Set::diff($data, Set::extract($data, '{n}')));
|
|
}
|
|
|
|
/**
|
|
* testEnum method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testEnum() {
|
|
$result = Set::enum(1, 'one, two');
|
|
$this->assertEquals('two', $result);
|
|
$result = Set::enum(2, 'one, two');
|
|
$this->assertNull($result);
|
|
|
|
$set = array('one', 'two');
|
|
$result = Set::enum(0, $set);
|
|
$this->assertEquals('one', $result);
|
|
$result = Set::enum(1, $set);
|
|
$this->assertEquals('two', $result);
|
|
|
|
$result = Set::enum(1, array('one', 'two'));
|
|
$this->assertEquals('two', $result);
|
|
$result = Set::enum(2, array('one', 'two'));
|
|
$this->assertNull($result);
|
|
|
|
$result = Set::enum('first', array('first' => 'one', 'second' => 'two'));
|
|
$this->assertEquals('one', $result);
|
|
$result = Set::enum('third', array('first' => 'one', 'second' => 'two'));
|
|
$this->assertNull($result);
|
|
|
|
$result = Set::enum('no', array('no' => 0, 'yes' => 1));
|
|
$this->assertEquals(0, $result);
|
|
$result = Set::enum('not sure', array('no' => 0, 'yes' => 1));
|
|
$this->assertNull($result);
|
|
|
|
$result = Set::enum(0);
|
|
$this->assertEquals('no', $result);
|
|
$result = Set::enum(1);
|
|
$this->assertEquals('yes', $result);
|
|
$result = Set::enum(2);
|
|
$this->assertNull($result);
|
|
}
|
|
|
|
/**
|
|
* testFilter method
|
|
*
|
|
* @see Hash test cases, as Set::filter() is just a proxy.
|
|
* @return void
|
|
*/
|
|
public function testFilter() {
|
|
$result = Set::filter(array('0', false, true, 0, array('one thing', 'I can tell you', 'is you got to be', false)));
|
|
$expected = array('0', 2 => true, 3 => 0, 4 => array('one thing', 'I can tell you', 'is you got to be'));
|
|
$this->assertSame($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testNumericArrayCheck method
|
|
*
|
|
* @see Hash test cases, as Set::numeric() is just a proxy.
|
|
* @return void
|
|
*/
|
|
public function testNumericArrayCheck() {
|
|
$data = array('one');
|
|
$this->assertTrue(Set::numeric(array_keys($data)));
|
|
}
|
|
|
|
/**
|
|
* testKeyCheck method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testKeyCheck() {
|
|
$data = array('Multi' => array('dimensonal' => array('array')));
|
|
$this->assertTrue(Set::check($data, 'Multi.dimensonal'));
|
|
$this->assertFalse(Set::check($data, 'Multi.dimensonal.array'));
|
|
|
|
$data = array(
|
|
array(
|
|
'Article' => array('id' => '1', 'user_id' => '1', 'title' => 'First Article', 'body' => 'First Article Body', 'published' => 'Y', 'created' => '2007-03-18 10:39:23', 'updated' => '2007-03-18 10:41:31'),
|
|
'User' => array('id' => '1', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31'),
|
|
'Comment' => array(
|
|
array('id' => '1', 'article_id' => '1', 'user_id' => '2', 'comment' => 'First Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:45:23', 'updated' => '2007-03-18 10:47:31'),
|
|
array('id' => '2', 'article_id' => '1', 'user_id' => '4', 'comment' => 'Second Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:47:23', 'updated' => '2007-03-18 10:49:31'),
|
|
),
|
|
'Tag' => array(
|
|
array('id' => '1', 'tag' => 'tag1', 'created' => '2007-03-18 12:22:23', 'updated' => '2007-03-18 12:24:31'),
|
|
array('id' => '2', 'tag' => 'tag2', 'created' => '2007-03-18 12:24:23', 'updated' => '2007-03-18 12:26:31')
|
|
)
|
|
),
|
|
array(
|
|
'Article' => array('id' => '3', 'user_id' => '1', 'title' => 'Third Article', 'body' => 'Third Article Body', 'published' => 'Y', 'created' => '2007-03-18 10:43:23', 'updated' => '2007-03-18 10:45:31'),
|
|
'User' => array('id' => '1', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31'),
|
|
'Comment' => array(),
|
|
'Tag' => array()
|
|
)
|
|
);
|
|
$this->assertTrue(Set::check($data, '0.Article.user_id'));
|
|
$this->assertTrue(Set::check($data, '0.Comment.0.id'));
|
|
$this->assertFalse(Set::check($data, '0.Comment.0.id.0'));
|
|
$this->assertTrue(Set::check($data, '0.Article.user_id'));
|
|
$this->assertFalse(Set::check($data, '0.Article.user_id.a'));
|
|
}
|
|
|
|
/**
|
|
* testMerge method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testMerge() {
|
|
$r = Set::merge(array('foo'));
|
|
$this->assertEquals(array('foo'), $r);
|
|
|
|
$r = Set::merge('foo');
|
|
$this->assertEquals(array('foo'), $r);
|
|
|
|
$r = Set::merge('foo', 'bar');
|
|
$this->assertEquals(array('foo', 'bar'), $r);
|
|
|
|
$r = Set::merge(array('foo'), array(), array('bar'));
|
|
$this->assertEquals(array('foo', 'bar'), $r);
|
|
|
|
$r = Set::merge('foo', array('user' => 'bob', 'no-bar'), 'bar');
|
|
$this->assertEquals(array('foo', 'user' => 'bob', 'no-bar', 'bar'), $r);
|
|
|
|
$a = array('foo', 'foo2');
|
|
$b = array('bar', 'bar2');
|
|
$this->assertEquals(array('foo', 'foo2', 'bar', 'bar2'), Set::merge($a, $b));
|
|
|
|
$a = array('foo' => 'bar', 'bar' => 'foo');
|
|
$b = array('foo' => 'no-bar', 'bar' => 'no-foo');
|
|
$this->assertEquals(array('foo' => 'no-bar', 'bar' => 'no-foo'), Set::merge($a, $b));
|
|
|
|
$a = array('users' => array('bob', 'jim'));
|
|
$b = array('users' => array('lisa', 'tina'));
|
|
$this->assertEquals(array('users' => array('bob', 'jim', 'lisa', 'tina')), Set::merge($a, $b));
|
|
|
|
$a = array('users' => array('jim', 'bob'));
|
|
$b = array('users' => 'none');
|
|
$this->assertEquals(array('users' => 'none'), Set::merge($a, $b));
|
|
|
|
$a = array('users' => array('lisa' => array('id' => 5, 'pw' => 'secret')), 'cakephp');
|
|
$b = array('users' => array('lisa' => array('pw' => 'new-pass', 'age' => 23)), 'ice-cream');
|
|
$this->assertEquals(array('users' => array('lisa' => array('id' => 5, 'pw' => 'new-pass', 'age' => 23)), 'cakephp', 'ice-cream'), Set::merge($a, $b));
|
|
|
|
$c = array('users' => array('lisa' => array('pw' => 'you-will-never-guess', 'age' => 25, 'pet' => 'dog')), 'chocolate');
|
|
$expected = array('users' => array('lisa' => array('id' => 5, 'pw' => 'you-will-never-guess', 'age' => 25, 'pet' => 'dog')), 'cakephp', 'ice-cream', 'chocolate');
|
|
$this->assertEquals($expected, Set::merge($a, $b, $c));
|
|
|
|
$this->assertEquals($expected, Set::merge($a, $b, array(), $c));
|
|
|
|
$r = Set::merge($a, $b, $c);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$a = array('Tree', 'CounterCache',
|
|
'Upload' => array('folder' => 'products',
|
|
'fields' => array('image_1_id', 'image_2_id', 'image_3_id', 'image_4_id', 'image_5_id')));
|
|
$b = array('Cacheable' => array('enabled' => false),
|
|
'Limit',
|
|
'Bindable',
|
|
'Validator',
|
|
'Transactional');
|
|
|
|
$expected = array('Tree', 'CounterCache',
|
|
'Upload' => array('folder' => 'products',
|
|
'fields' => array('image_1_id', 'image_2_id', 'image_3_id', 'image_4_id', 'image_5_id')),
|
|
'Cacheable' => array('enabled' => false),
|
|
'Limit',
|
|
'Bindable',
|
|
'Validator',
|
|
'Transactional');
|
|
|
|
$this->assertEquals($expected, Set::merge($a, $b));
|
|
|
|
$expected = array('Tree' => null, 'CounterCache' => null,
|
|
'Upload' => array('folder' => 'products',
|
|
'fields' => array('image_1_id', 'image_2_id', 'image_3_id', 'image_4_id', 'image_5_id')),
|
|
'Cacheable' => array('enabled' => false),
|
|
'Limit' => null,
|
|
'Bindable' => null,
|
|
'Validator' => null,
|
|
'Transactional' => null);
|
|
|
|
$this->assertEquals($expected, Set::normalize(Set::merge($a, $b)));
|
|
}
|
|
|
|
/**
|
|
* testSort method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testSort() {
|
|
$result = Set::sort(array(), '{n}.name', 'asc');
|
|
$this->assertEquals(array(), $result);
|
|
|
|
$a = array(
|
|
0 => array('Person' => array('name' => 'Jeff'), 'Friend' => array(array('name' => 'Nate'))),
|
|
1 => array('Person' => array('name' => 'Tracy'), 'Friend' => array(array('name' => 'Lindsay')))
|
|
);
|
|
$b = array(
|
|
0 => array('Person' => array('name' => 'Tracy'), 'Friend' => array(array('name' => 'Lindsay'))),
|
|
1 => array('Person' => array('name' => 'Jeff'), 'Friend' => array(array('name' => 'Nate')))
|
|
|
|
);
|
|
$a = Set::sort($a, '{n}.Friend.{n}.name', 'asc');
|
|
$this->assertEquals($a, $b);
|
|
|
|
$b = array(
|
|
0 => array('Person' => array('name' => 'Jeff'), 'Friend' => array(array('name' => 'Nate'))),
|
|
1 => array('Person' => array('name' => 'Tracy'), 'Friend' => array(array('name' => 'Lindsay')))
|
|
);
|
|
$a = array(
|
|
0 => array('Person' => array('name' => 'Tracy'), 'Friend' => array(array('name' => 'Lindsay'))),
|
|
1 => array('Person' => array('name' => 'Jeff'), 'Friend' => array(array('name' => 'Nate')))
|
|
|
|
);
|
|
$a = Set::sort($a, '{n}.Friend.{n}.name', 'desc');
|
|
$this->assertEquals($a, $b);
|
|
|
|
$a = array(
|
|
0 => array('Person' => array('name' => 'Jeff'), 'Friend' => array(array('name' => 'Nate'))),
|
|
1 => array('Person' => array('name' => 'Tracy'), 'Friend' => array(array('name' => 'Lindsay'))),
|
|
2 => array('Person' => array('name' => 'Adam'), 'Friend' => array(array('name' => 'Bob')))
|
|
);
|
|
$b = array(
|
|
0 => array('Person' => array('name' => 'Adam'), 'Friend' => array(array('name' => 'Bob'))),
|
|
1 => array('Person' => array('name' => 'Jeff'), 'Friend' => array(array('name' => 'Nate'))),
|
|
2 => array('Person' => array('name' => 'Tracy'), 'Friend' => array(array('name' => 'Lindsay')))
|
|
);
|
|
$a = Set::sort($a, '{n}.Person.name', 'asc');
|
|
$this->assertEquals($a, $b);
|
|
|
|
$a = array(
|
|
array(7, 6, 4),
|
|
array(3, 4, 5),
|
|
array(3, 2, 1),
|
|
);
|
|
|
|
$b = array(
|
|
array(3, 2, 1),
|
|
array(3, 4, 5),
|
|
array(7, 6, 4),
|
|
);
|
|
|
|
$a = Set::sort($a, '{n}.{n}', 'asc');
|
|
$this->assertEquals($a, $b);
|
|
|
|
$a = array(
|
|
array(7, 6, 4),
|
|
array(3, 4, 5),
|
|
array(3, 2, array(1, 1, 1)),
|
|
);
|
|
|
|
$b = array(
|
|
array(3, 2, array(1, 1, 1)),
|
|
array(3, 4, 5),
|
|
array(7, 6, 4),
|
|
);
|
|
|
|
$a = Set::sort($a, '{n}', 'asc');
|
|
$this->assertEquals($a, $b);
|
|
|
|
$a = array(
|
|
0 => array('Person' => array('name' => 'Jeff')),
|
|
1 => array('Shirt' => array('color' => 'black'))
|
|
);
|
|
$b = array(
|
|
0 => array('Shirt' => array('color' => 'black')),
|
|
1 => array('Person' => array('name' => 'Jeff')),
|
|
);
|
|
$a = Set::sort($a, '{n}.Person.name', 'ASC');
|
|
$this->assertEquals($a, $b);
|
|
|
|
$names = array(
|
|
array('employees' => array(array('name' => array('first' => 'John', 'last' => 'Doe')))),
|
|
array('employees' => array(array('name' => array('first' => 'Jane', 'last' => 'Doe')))),
|
|
array('employees' => array(array('name' => array()))),
|
|
array('employees' => array(array('name' => array())))
|
|
);
|
|
$result = Set::sort($names, '{n}.employees.0.name', 'asc', 1);
|
|
$expected = array(
|
|
array('employees' => array(array('name' => array('first' => 'John', 'last' => 'Doe')))),
|
|
array('employees' => array(array('name' => array('first' => 'Jane', 'last' => 'Doe')))),
|
|
array('employees' => array(array('name' => array()))),
|
|
array('employees' => array(array('name' => array())))
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$menus = array(
|
|
'blogs' => array('title' => 'Blogs', 'weight' => 3),
|
|
'comments' => array('title' => 'Comments', 'weight' => 2),
|
|
'users' => array('title' => 'Users', 'weight' => 1),
|
|
);
|
|
$expected = array(
|
|
'users' => array('title' => 'Users', 'weight' => 1),
|
|
'comments' => array('title' => 'Comments', 'weight' => 2),
|
|
'blogs' => array('title' => 'Blogs', 'weight' => 3),
|
|
);
|
|
$result = Set::sort($menus, '{[a-z]+}.weight', 'ASC');
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* test sorting with string keys.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testSortString() {
|
|
$toSort = array(
|
|
'four' => array('number' => 4, 'some' => 'foursome'),
|
|
'six' => array('number' => 6, 'some' => 'sixsome'),
|
|
'five' => array('number' => 5, 'some' => 'fivesome'),
|
|
'two' => array('number' => 2, 'some' => 'twosome'),
|
|
'three' => array('number' => 3, 'some' => 'threesome')
|
|
);
|
|
$sorted = Set::sort($toSort, '{s}.number', 'asc');
|
|
$expected = array(
|
|
'two' => array('number' => 2, 'some' => 'twosome'),
|
|
'three' => array('number' => 3, 'some' => 'threesome'),
|
|
'four' => array('number' => 4, 'some' => 'foursome'),
|
|
'five' => array('number' => 5, 'some' => 'fivesome'),
|
|
'six' => array('number' => 6, 'some' => 'sixsome')
|
|
);
|
|
$this->assertEquals($expected, $sorted);
|
|
}
|
|
|
|
/**
|
|
* test sorting with out of order keys.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testSortWithOutOfOrderKeys() {
|
|
$data = array(
|
|
9 => array('class' => 510, 'test2' => 2),
|
|
1 => array('class' => 500, 'test2' => 1),
|
|
2 => array('class' => 600, 'test2' => 2),
|
|
5 => array('class' => 625, 'test2' => 4),
|
|
0 => array('class' => 605, 'test2' => 3),
|
|
);
|
|
$expected = array(
|
|
array('class' => 500, 'test2' => 1),
|
|
array('class' => 510, 'test2' => 2),
|
|
array('class' => 600, 'test2' => 2),
|
|
array('class' => 605, 'test2' => 3),
|
|
array('class' => 625, 'test2' => 4),
|
|
);
|
|
$result = Set::sort($data, '{n}.class', 'asc');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::sort($data, '{n}.test2', 'asc');
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testExtract method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testExtract() {
|
|
$a = array(
|
|
array(
|
|
'Article' => array('id' => '1', 'user_id' => '1', 'title' => 'First Article', 'body' => 'First Article Body', 'published' => 'Y', 'created' => '2007-03-18 10:39:23', 'updated' => '2007-03-18 10:41:31'),
|
|
'User' => array('id' => '1', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31'),
|
|
'Comment' => array(
|
|
array('id' => '1', 'article_id' => '1', 'user_id' => '2', 'comment' => 'First Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:45:23', 'updated' => '2007-03-18 10:47:31'),
|
|
array('id' => '2', 'article_id' => '1', 'user_id' => '4', 'comment' => 'Second Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:47:23', 'updated' => '2007-03-18 10:49:31'),
|
|
),
|
|
'Tag' => array(
|
|
array('id' => '1', 'tag' => 'tag1', 'created' => '2007-03-18 12:22:23', 'updated' => '2007-03-18 12:24:31'),
|
|
array('id' => '2', 'tag' => 'tag2', 'created' => '2007-03-18 12:24:23', 'updated' => '2007-03-18 12:26:31')
|
|
),
|
|
'Deep' => array(
|
|
'Nesting' => array(
|
|
'test' => array(
|
|
1 => 'foo',
|
|
2 => array(
|
|
'and' => array('more' => 'stuff')
|
|
)
|
|
)
|
|
)
|
|
)
|
|
),
|
|
array(
|
|
'Article' => array('id' => '3', 'user_id' => '1', 'title' => 'Third Article', 'body' => 'Third Article Body', 'published' => 'Y', 'created' => '2007-03-18 10:43:23', 'updated' => '2007-03-18 10:45:31'),
|
|
'User' => array('id' => '2', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31'),
|
|
'Comment' => array(),
|
|
'Tag' => array()
|
|
),
|
|
array(
|
|
'Article' => array('id' => '3', 'user_id' => '1', 'title' => 'Third Article', 'body' => 'Third Article Body', 'published' => 'Y', 'created' => '2007-03-18 10:43:23', 'updated' => '2007-03-18 10:45:31'),
|
|
'User' => array('id' => '3', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31'),
|
|
'Comment' => array(),
|
|
'Tag' => array()
|
|
),
|
|
array(
|
|
'Article' => array('id' => '3', 'user_id' => '1', 'title' => 'Third Article', 'body' => 'Third Article Body', 'published' => 'Y', 'created' => '2007-03-18 10:43:23', 'updated' => '2007-03-18 10:45:31'),
|
|
'User' => array('id' => '4', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31'),
|
|
'Comment' => array(),
|
|
'Tag' => array()
|
|
),
|
|
array(
|
|
'Article' => array('id' => '3', 'user_id' => '1', 'title' => 'Third Article', 'body' => 'Third Article Body', 'published' => 'Y', 'created' => '2007-03-18 10:43:23', 'updated' => '2007-03-18 10:45:31'),
|
|
'User' => array('id' => '5', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31'),
|
|
'Comment' => array(),
|
|
'Tag' => array()
|
|
)
|
|
);
|
|
$b = array('Deep' => $a[0]['Deep']);
|
|
$c = array(
|
|
array('a' => array('I' => array('a' => 1))),
|
|
array(
|
|
'a' => array(
|
|
2
|
|
)
|
|
),
|
|
array('a' => array('II' => array('a' => 3, 'III' => array('a' => array('foo' => 4))))),
|
|
);
|
|
|
|
$expected = array(array('a' => $c[2]['a']));
|
|
$r = Set::extract('/a/II[a=3]/..', $c);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(1, 2, 3, 4, 5);
|
|
$this->assertEquals($expected, Set::extract('/User/id', $a));
|
|
|
|
$expected = array(1, 2, 3, 4, 5);
|
|
$this->assertEquals($expected, Set::extract('/User/id', $a));
|
|
|
|
$expected = array(
|
|
array('id' => 1), array('id' => 2), array('id' => 3), array('id' => 4), array('id' => 5)
|
|
);
|
|
|
|
$r = Set::extract('/User/id', $a, array('flatten' => false));
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('test' => $a[0]['Deep']['Nesting']['test']));
|
|
$this->assertEquals($expected, Set::extract('/Deep/Nesting/test', $a));
|
|
$this->assertEquals($expected, Set::extract('/Deep/Nesting/test', $b));
|
|
|
|
$expected = array(array('test' => $a[0]['Deep']['Nesting']['test']));
|
|
$r = Set::extract('/Deep/Nesting/test/1/..', $a);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('test' => $a[0]['Deep']['Nesting']['test']));
|
|
$r = Set::extract('/Deep/Nesting/test/2/and/../..', $a);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('test' => $a[0]['Deep']['Nesting']['test']));
|
|
$r = Set::extract('/Deep/Nesting/test/2/../../../Nesting/test/2/..', $a);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(2);
|
|
$r = Set::extract('/User[2]/id', $a);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(4, 5);
|
|
$r = Set::extract('/User[id>3]/id', $a);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(2, 3);
|
|
$r = Set::extract('/User[id>1][id<=3]/id', $a);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('I'), array('II'));
|
|
$r = Set::extract('/a/@*', $c);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$single = array(
|
|
'User' => array(
|
|
'id' => 4,
|
|
'name' => 'Neo',
|
|
)
|
|
);
|
|
$tricky = array(
|
|
0 => array(
|
|
'User' => array(
|
|
'id' => 1,
|
|
'name' => 'John',
|
|
)
|
|
),
|
|
1 => array(
|
|
'User' => array(
|
|
'id' => 2,
|
|
'name' => 'Bob',
|
|
)
|
|
),
|
|
2 => array(
|
|
'User' => array(
|
|
'id' => 3,
|
|
'name' => 'Tony',
|
|
)
|
|
),
|
|
'User' => array(
|
|
'id' => 4,
|
|
'name' => 'Neo',
|
|
)
|
|
);
|
|
|
|
$expected = array(1, 2, 3, 4);
|
|
$r = Set::extract('/User/id', $tricky);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(4);
|
|
$r = Set::extract('/User/id', $single);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(1, 3);
|
|
$r = Set::extract('/User[name=/n/]/id', $tricky);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(4);
|
|
$r = Set::extract('/User[name=/N/]/id', $tricky);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(1, 3, 4);
|
|
$r = Set::extract('/User[name=/N/i]/id', $tricky);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('id', 'name'), array('id', 'name'), array('id', 'name'), array('id', 'name'));
|
|
$r = Set::extract('/User/@*', $tricky);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$common = array(
|
|
array(
|
|
'Article' => array(
|
|
'id' => 1,
|
|
'name' => 'Article 1',
|
|
),
|
|
'Comment' => array(
|
|
array(
|
|
'id' => 1,
|
|
'user_id' => 5,
|
|
'article_id' => 1,
|
|
'text' => 'Comment 1',
|
|
),
|
|
array(
|
|
'id' => 2,
|
|
'user_id' => 23,
|
|
'article_id' => 1,
|
|
'text' => 'Comment 2',
|
|
),
|
|
array(
|
|
'id' => 3,
|
|
'user_id' => 17,
|
|
'article_id' => 1,
|
|
'text' => 'Comment 3',
|
|
),
|
|
),
|
|
),
|
|
array(
|
|
'Article' => array(
|
|
'id' => 2,
|
|
'name' => 'Article 2',
|
|
),
|
|
'Comment' => array(
|
|
array(
|
|
'id' => 4,
|
|
'user_id' => 2,
|
|
'article_id' => 2,
|
|
'text' => 'Comment 4',
|
|
'addition' => '',
|
|
),
|
|
array(
|
|
'id' => 5,
|
|
'user_id' => 23,
|
|
'article_id' => 2,
|
|
'text' => 'Comment 5',
|
|
'addition' => 'foo',
|
|
),
|
|
),
|
|
),
|
|
array(
|
|
'Article' => array(
|
|
'id' => 3,
|
|
'name' => 'Article 3',
|
|
),
|
|
'Comment' => array(),
|
|
)
|
|
);
|
|
|
|
$r = Set::extract('/Comment/id', $common);
|
|
$expected = array(1, 2, 3, 4, 5);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(1, 2, 4, 5);
|
|
$r = Set::extract('/Comment[id!=3]/id', $common);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$r = Set::extract('/', $common);
|
|
$this->assertEquals($r, $common);
|
|
|
|
$expected = array(1, 2, 4, 5);
|
|
$r = Set::extract($common, '/Comment[id!=3]/id');
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array($common[0]['Comment'][2]);
|
|
$r = Set::extract($common, '/Comment/2');
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array($common[0]['Comment'][0]);
|
|
$r = Set::extract($common, '/Comment[1]/.[id=1]');
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array($common[1]['Comment'][1]);
|
|
$r = Set::extract($common, '/1/Comment/.[2]');
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array();
|
|
$r = Set::extract('/User/id', array());
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(5);
|
|
$r = Set::extract('/Comment/id[:last]', $common);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(1);
|
|
$r = Set::extract('/Comment/id[:first]', $common);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(3);
|
|
$r = Set::extract('/Article[:last]/id', $common);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('Comment' => $common[1]['Comment'][0]));
|
|
$r = Set::extract('/Comment[addition=]', $common);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$habtm = array(
|
|
array(
|
|
'Post' => array(
|
|
'id' => 1,
|
|
'title' => 'great post',
|
|
),
|
|
'Comment' => array(
|
|
array(
|
|
'id' => 1,
|
|
'text' => 'foo',
|
|
'User' => array(
|
|
'id' => 1,
|
|
'name' => 'bob'
|
|
),
|
|
),
|
|
array(
|
|
'id' => 2,
|
|
'text' => 'bar',
|
|
'User' => array(
|
|
'id' => 2,
|
|
'name' => 'tod'
|
|
),
|
|
),
|
|
),
|
|
),
|
|
array(
|
|
'Post' => array(
|
|
'id' => 2,
|
|
'title' => 'fun post',
|
|
),
|
|
'Comment' => array(
|
|
array(
|
|
'id' => 3,
|
|
'text' => '123',
|
|
'User' => array(
|
|
'id' => 3,
|
|
'name' => 'dan'
|
|
),
|
|
),
|
|
array(
|
|
'id' => 4,
|
|
'text' => '987',
|
|
'User' => array(
|
|
'id' => 4,
|
|
'name' => 'jim'
|
|
),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
|
|
$r = Set::extract('/Comment/User[name=/bob|dan/]/..', $habtm);
|
|
$this->assertEquals('bob', $r[0]['Comment']['User']['name']);
|
|
$this->assertEquals('dan', $r[1]['Comment']['User']['name']);
|
|
$this->assertEquals(2, count($r));
|
|
|
|
$r = Set::extract('/Comment/User[name=/bob|tod/]/..', $habtm);
|
|
$this->assertEquals('bob', $r[0]['Comment']['User']['name']);
|
|
|
|
$this->assertEquals('tod', $r[1]['Comment']['User']['name']);
|
|
$this->assertEquals(2, count($r));
|
|
|
|
$tree = array(
|
|
array(
|
|
'Category' => array('name' => 'Category 1'),
|
|
'children' => array(array('Category' => array('name' => 'Category 1.1')))
|
|
),
|
|
array(
|
|
'Category' => array('name' => 'Category 2'),
|
|
'children' => array(
|
|
array('Category' => array('name' => 'Category 2.1')),
|
|
array('Category' => array('name' => 'Category 2.2'))
|
|
)
|
|
),
|
|
array(
|
|
'Category' => array('name' => 'Category 3'),
|
|
'children' => array(array('Category' => array('name' => 'Category 3.1')))
|
|
)
|
|
);
|
|
|
|
$expected = array(array('Category' => $tree[1]['Category']));
|
|
$r = Set::extract('/Category[name=Category 2]', $tree);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(
|
|
array('Category' => $tree[1]['Category'], 'children' => $tree[1]['children'])
|
|
);
|
|
$r = Set::extract('/Category[name=Category 2]/..', $tree);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(
|
|
array('children' => $tree[1]['children'][0]),
|
|
array('children' => $tree[1]['children'][1])
|
|
);
|
|
$r = Set::extract('/Category[name=Category 2]/../children', $tree);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$habtm = array(
|
|
array(
|
|
'Post' => array(
|
|
'id' => 1,
|
|
'title' => 'great post',
|
|
),
|
|
'Comment' => array(
|
|
array(
|
|
'id' => 1,
|
|
'text' => 'foo',
|
|
'User' => array(
|
|
'id' => 1,
|
|
'name' => 'bob'
|
|
),
|
|
),
|
|
array(
|
|
'id' => 2,
|
|
'text' => 'bar',
|
|
'User' => array(
|
|
'id' => 2,
|
|
'name' => 'tod'
|
|
),
|
|
),
|
|
),
|
|
),
|
|
array(
|
|
'Post' => array(
|
|
'id' => 2,
|
|
'title' => 'fun post',
|
|
),
|
|
'Comment' => array(
|
|
array(
|
|
'id' => 3,
|
|
'text' => '123',
|
|
'User' => array(
|
|
'id' => 3,
|
|
'name' => 'dan'
|
|
),
|
|
),
|
|
array(
|
|
'id' => 4,
|
|
'text' => '987',
|
|
'User' => array(
|
|
'id' => 4,
|
|
'name' => 'jim'
|
|
),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
|
|
$r = Set::extract('/Comment/User[name=/\w+/]/..', $habtm);
|
|
$this->assertEquals('bob', $r[0]['Comment']['User']['name']);
|
|
$this->assertEquals('tod', $r[1]['Comment']['User']['name']);
|
|
$this->assertEquals('dan', $r[2]['Comment']['User']['name']);
|
|
$this->assertEquals('dan', $r[3]['Comment']['User']['name']);
|
|
$this->assertEquals(4, count($r));
|
|
|
|
$r = Set::extract('/Comment/User[name=/[a-z]+/]/..', $habtm);
|
|
$this->assertEquals('bob', $r[0]['Comment']['User']['name']);
|
|
$this->assertEquals('tod', $r[1]['Comment']['User']['name']);
|
|
$this->assertEquals('dan', $r[2]['Comment']['User']['name']);
|
|
$this->assertEquals('dan', $r[3]['Comment']['User']['name']);
|
|
$this->assertEquals(4, count($r));
|
|
|
|
$r = Set::extract('/Comment/User[name=/bob|dan/]/..', $habtm);
|
|
$this->assertEquals('bob', $r[0]['Comment']['User']['name']);
|
|
$this->assertEquals('dan', $r[1]['Comment']['User']['name']);
|
|
$this->assertEquals(2, count($r));
|
|
|
|
$r = Set::extract('/Comment/User[name=/bob|tod/]/..', $habtm);
|
|
$this->assertEquals('bob', $r[0]['Comment']['User']['name']);
|
|
$this->assertEquals('tod', $r[1]['Comment']['User']['name']);
|
|
$this->assertEquals(2, count($r));
|
|
|
|
$mixedKeys = array(
|
|
'User' => array(
|
|
0 => array(
|
|
'id' => 4,
|
|
'name' => 'Neo'
|
|
),
|
|
1 => array(
|
|
'id' => 5,
|
|
'name' => 'Morpheus'
|
|
),
|
|
'stringKey' => array()
|
|
)
|
|
);
|
|
$expected = array('Neo', 'Morpheus');
|
|
$r = Set::extract('/User/name', $mixedKeys);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$f = array(
|
|
array(
|
|
'file' => array(
|
|
'name' => 'zipfile.zip',
|
|
'type' => 'application/zip',
|
|
'tmp_name' => '/tmp/php178.tmp',
|
|
'error' => 0,
|
|
'size' => '564647'
|
|
)
|
|
),
|
|
array(
|
|
'file' => array(
|
|
'name' => 'zipfile2.zip',
|
|
'type' => 'application/x-zip-compressed',
|
|
'tmp_name' => '/tmp/php179.tmp',
|
|
'error' => 0,
|
|
'size' => '354784'
|
|
)
|
|
),
|
|
array(
|
|
'file' => array(
|
|
'name' => 'picture.jpg',
|
|
'type' => 'image/jpeg',
|
|
'tmp_name' => '/tmp/php180.tmp',
|
|
'error' => 0,
|
|
'size' => '21324'
|
|
)
|
|
)
|
|
);
|
|
$expected = array(array('name' => 'zipfile2.zip', 'type' => 'application/x-zip-compressed', 'tmp_name' => '/tmp/php179.tmp', 'error' => 0, 'size' => '354784'));
|
|
$r = Set::extract('/file/.[type=application/x-zip-compressed]', $f);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('name' => 'zipfile.zip', 'type' => 'application/zip', 'tmp_name' => '/tmp/php178.tmp', 'error' => 0, 'size' => '564647'));
|
|
$r = Set::extract('/file/.[type=application/zip]', $f);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$f = array(
|
|
array(
|
|
'file' => array(
|
|
'name' => 'zipfile.zip',
|
|
'type' => 'application/zip',
|
|
'tmp_name' => '/tmp/php178.tmp',
|
|
'error' => 0,
|
|
'size' => '564647'
|
|
)
|
|
),
|
|
array(
|
|
'file' => array(
|
|
'name' => 'zipfile2.zip',
|
|
'type' => 'application/x zip compressed',
|
|
'tmp_name' => '/tmp/php179.tmp',
|
|
'error' => 0,
|
|
'size' => '354784'
|
|
)
|
|
),
|
|
array(
|
|
'file' => array(
|
|
'name' => 'picture.jpg',
|
|
'type' => 'image/jpeg',
|
|
'tmp_name' => '/tmp/php180.tmp',
|
|
'error' => 0,
|
|
'size' => '21324'
|
|
)
|
|
)
|
|
);
|
|
$expected = array(array('name' => 'zipfile2.zip', 'type' => 'application/x zip compressed', 'tmp_name' => '/tmp/php179.tmp', 'error' => 0, 'size' => '354784'));
|
|
$r = Set::extract('/file/.[type=application/x zip compressed]', $f);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(
|
|
array('name' => 'zipfile.zip', 'type' => 'application/zip', 'tmp_name' => '/tmp/php178.tmp', 'error' => 0, 'size' => '564647'),
|
|
array('name' => 'zipfile2.zip', 'type' => 'application/x zip compressed', 'tmp_name' => '/tmp/php179.tmp', 'error' => 0, 'size' => '354784')
|
|
);
|
|
$r = Set::extract('/file/.[tmp_name=/tmp\/php17/]', $f);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$hasMany = array(
|
|
'Node' => array(
|
|
'id' => 1,
|
|
'name' => 'First',
|
|
'state' => 50
|
|
),
|
|
'ParentNode' => array(
|
|
0 => array(
|
|
'id' => 2,
|
|
'name' => 'Second',
|
|
'state' => 60,
|
|
)
|
|
)
|
|
);
|
|
$result = Set::extract('/ParentNode/name', $hasMany);
|
|
$expected = array('Second');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$data = array(
|
|
array(
|
|
'Category' => array(
|
|
'id' => 1,
|
|
'name' => 'First'
|
|
),
|
|
0 => array(
|
|
'value' => 50
|
|
)
|
|
),
|
|
array(
|
|
'Category' => array(
|
|
'id' => 2,
|
|
'name' => 'Second'
|
|
),
|
|
0 => array(
|
|
'value' => 60
|
|
)
|
|
)
|
|
);
|
|
$expected = array(
|
|
array(
|
|
'Category' => array(
|
|
'id' => 1,
|
|
'name' => 'First'
|
|
),
|
|
0 => array(
|
|
'value' => 50
|
|
)
|
|
)
|
|
);
|
|
$result = Set::extract('/Category[id=1]/..', $data);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$data = array(
|
|
array(
|
|
'ChildNode' => array('id' => 1),
|
|
array('name' => 'Item 1')
|
|
),
|
|
array(
|
|
'ChildNode' => array('id' => 2),
|
|
array('name' => 'Item 2')
|
|
),
|
|
);
|
|
|
|
$expected = array(
|
|
'Item 1',
|
|
'Item 2'
|
|
);
|
|
$result = Set::extract('/0/name', $data);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$data = array(
|
|
array('A1', 'B1'),
|
|
array('A2', 'B2')
|
|
);
|
|
$expected = array('A1', 'A2');
|
|
$result = Set::extract('/0', $data);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* test parent selectors with extract
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testExtractParentSelector() {
|
|
$tree = array(
|
|
array(
|
|
'Category' => array(
|
|
'name' => 'Category 1'
|
|
),
|
|
'children' => array(
|
|
array(
|
|
'Category' => array(
|
|
'name' => 'Category 1.1'
|
|
)
|
|
)
|
|
)
|
|
),
|
|
array(
|
|
'Category' => array(
|
|
'name' => 'Category 2'
|
|
),
|
|
'children' => array(
|
|
array(
|
|
'Category' => array(
|
|
'name' => 'Category 2.1'
|
|
)
|
|
),
|
|
array(
|
|
'Category' => array(
|
|
'name' => 'Category 2.2'
|
|
)
|
|
),
|
|
)
|
|
),
|
|
array(
|
|
'Category' => array(
|
|
'name' => 'Category 3'
|
|
),
|
|
'children' => array(
|
|
array(
|
|
'Category' => array(
|
|
'name' => 'Category 3.1'
|
|
)
|
|
)
|
|
)
|
|
)
|
|
);
|
|
$expected = array(array('Category' => $tree[1]['Category']));
|
|
$r = Set::extract('/Category[name=Category 2]', $tree);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('Category' => $tree[1]['Category'], 'children' => $tree[1]['children']));
|
|
$r = Set::extract('/Category[name=Category 2]/..', $tree);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(array('children' => $tree[1]['children'][0]), array('children' => $tree[1]['children'][1]));
|
|
$r = Set::extract('/Category[name=Category 2]/../children', $tree);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$single = array(
|
|
array(
|
|
'CallType' => array(
|
|
'name' => 'Internal Voice'
|
|
),
|
|
'x' => array(
|
|
'hour' => 7
|
|
)
|
|
)
|
|
);
|
|
|
|
$expected = array(7);
|
|
$r = Set::extract('/CallType[name=Internal Voice]/../x/hour', $single);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$multiple = array(
|
|
array(
|
|
'CallType' => array(
|
|
'name' => 'Internal Voice'
|
|
),
|
|
'x' => array(
|
|
'hour' => 7
|
|
)
|
|
),
|
|
array(
|
|
'CallType' => array(
|
|
'name' => 'Internal Voice'
|
|
),
|
|
'x' => array(
|
|
'hour' => 2
|
|
)
|
|
),
|
|
array(
|
|
'CallType' => array(
|
|
'name' => 'Internal Voice'
|
|
),
|
|
'x' => array(
|
|
'hour' => 1
|
|
)
|
|
)
|
|
);
|
|
|
|
$expected = array(7, 2, 1);
|
|
$r = Set::extract('/CallType[name=Internal Voice]/../x/hour', $multiple);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$a = array(
|
|
'Model' => array(
|
|
'0' => array(
|
|
'id' => 18,
|
|
'SubModelsModel' => array(
|
|
'id' => 1,
|
|
'submodel_id' => 66,
|
|
'model_id' => 18,
|
|
'type' => 1
|
|
),
|
|
),
|
|
'1' => array(
|
|
'id' => 0,
|
|
'SubModelsModel' => array(
|
|
'id' => 2,
|
|
'submodel_id' => 66,
|
|
'model_id' => 0,
|
|
'type' => 1
|
|
),
|
|
),
|
|
'2' => array(
|
|
'id' => 17,
|
|
'SubModelsModel' => array(
|
|
'id' => 3,
|
|
'submodel_id' => 66,
|
|
'model_id' => 17,
|
|
'type' => 2
|
|
),
|
|
),
|
|
'3' => array(
|
|
'id' => 0,
|
|
'SubModelsModel' => array(
|
|
'id' => 4,
|
|
'submodel_id' => 66,
|
|
'model_id' => 0,
|
|
'type' => 2
|
|
)
|
|
)
|
|
)
|
|
);
|
|
|
|
$expected = array(
|
|
array(
|
|
'Model' => array(
|
|
'id' => 17,
|
|
'SubModelsModel' => array(
|
|
'id' => 3,
|
|
'submodel_id' => 66,
|
|
'model_id' => 17,
|
|
'type' => 2
|
|
),
|
|
)
|
|
),
|
|
array(
|
|
'Model' => array(
|
|
'id' => 0,
|
|
'SubModelsModel' => array(
|
|
'id' => 4,
|
|
'submodel_id' => 66,
|
|
'model_id' => 0,
|
|
'type' => 2
|
|
)
|
|
)
|
|
)
|
|
);
|
|
$r = Set::extract('/Model/SubModelsModel[type=2]/..', $a);
|
|
$this->assertEquals($expected, $r);
|
|
}
|
|
|
|
/**
|
|
* test that extract() still works when arrays don't contain a 0 index.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testExtractWithNonZeroArrays() {
|
|
$nonZero = array(
|
|
1 => array(
|
|
'User' => array(
|
|
'id' => 1,
|
|
'name' => 'John',
|
|
)
|
|
),
|
|
2 => array(
|
|
'User' => array(
|
|
'id' => 2,
|
|
'name' => 'Bob',
|
|
)
|
|
),
|
|
3 => array(
|
|
'User' => array(
|
|
'id' => 3,
|
|
'name' => 'Tony',
|
|
)
|
|
)
|
|
);
|
|
$expected = array(1, 2, 3);
|
|
$r = Set::extract('/User/id', $nonZero);
|
|
$this->assertEquals($expected, $r);
|
|
|
|
$expected = array(
|
|
array('User' => array('id' => 1, 'name' => 'John')),
|
|
array('User' => array('id' => 2, 'name' => 'Bob')),
|
|
array('User' => array('id' => 3, 'name' => 'Tony')),
|
|
);
|
|
$result = Set::extract('/User', $nonZero);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$nonSequential = array(
|
|
'User' => array(
|
|
0 => array('id' => 1),
|
|
2 => array('id' => 2),
|
|
6 => array('id' => 3),
|
|
9 => array('id' => 4),
|
|
3 => array('id' => 5),
|
|
),
|
|
);
|
|
|
|
$nonZero = array(
|
|
'User' => array(
|
|
2 => array('id' => 1),
|
|
4 => array('id' => 2),
|
|
6 => array('id' => 3),
|
|
9 => array('id' => 4),
|
|
3 => array('id' => 5),
|
|
),
|
|
);
|
|
|
|
$expected = array(1, 2, 3, 4, 5);
|
|
$this->assertEquals($expected, Set::extract('/User/id', $nonSequential));
|
|
|
|
$result = Set::extract('/User/id', $nonZero);
|
|
$this->assertEquals($expected, $result, 'Failed non zero array key extract');
|
|
|
|
$expected = array(1, 2, 3, 4, 5);
|
|
$this->assertEquals($expected, Set::extract('/User/id', $nonSequential));
|
|
|
|
$result = Set::extract('/User/id', $nonZero);
|
|
$this->assertEquals($expected, $result, 'Failed non zero array key extract');
|
|
|
|
$startingAtOne = array(
|
|
'Article' => array(
|
|
1 => array(
|
|
'id' => 1,
|
|
'approved' => 1,
|
|
),
|
|
)
|
|
);
|
|
|
|
$expected = array(0 => array('Article' => array('id' => 1, 'approved' => 1)));
|
|
$result = Set::extract('/Article[approved=1]', $startingAtOne);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$items = array(
|
|
240 => array(
|
|
'A' => array(
|
|
'field1' => 'a240',
|
|
'field2' => 'a240',
|
|
),
|
|
'B' => array(
|
|
'field1' => 'b240',
|
|
'field2' => 'b240'
|
|
),
|
|
)
|
|
);
|
|
|
|
$expected = array(
|
|
0 => 'b240'
|
|
);
|
|
|
|
$result = Set::extract('/B/field1', $items);
|
|
$this->assertSame($expected, $result);
|
|
$this->assertSame($result, Set::extract('{n}.B.field1', $items));
|
|
}
|
|
|
|
/**
|
|
* testExtractWithArrays method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testExtractWithArrays() {
|
|
$data = array(
|
|
'Level1' => array(
|
|
'Level2' => array('test1', 'test2'),
|
|
'Level2bis' => array('test3', 'test4')
|
|
)
|
|
);
|
|
$this->assertEquals(array(array('Level2' => array('test1', 'test2'))), Set::extract('/Level1/Level2', $data));
|
|
$this->assertEquals(array(array('Level2bis' => array('test3', 'test4'))), Set::extract('/Level1/Level2bis', $data));
|
|
}
|
|
|
|
/**
|
|
* test extract() with elements that have non-array children.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testExtractWithNonArrayElements() {
|
|
$data = array(
|
|
'node' => array(
|
|
array('foo'),
|
|
'bar'
|
|
)
|
|
);
|
|
$result = Set::extract('/node', $data);
|
|
$expected = array(
|
|
array('node' => array('foo')),
|
|
'bar'
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$data = array(
|
|
'node' => array(
|
|
'foo' => array('bar'),
|
|
'bar' => array('foo')
|
|
)
|
|
);
|
|
$result = Set::extract('/node', $data);
|
|
$expected = array(
|
|
array('foo' => array('bar')),
|
|
array('bar' => array('foo')),
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$data = array(
|
|
'node' => array(
|
|
'foo' => array(
|
|
'bar'
|
|
),
|
|
'bar' => 'foo'
|
|
)
|
|
);
|
|
$result = Set::extract('/node', $data);
|
|
$expected = array(
|
|
array('foo' => array('bar')),
|
|
'foo'
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* Test that extract() + matching can hit null things.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testExtractMatchesNull() {
|
|
$data = array(
|
|
'Country' => array(
|
|
array('name' => 'Canada'),
|
|
array('name' => 'Australia'),
|
|
array('name' => null),
|
|
)
|
|
);
|
|
$result = Set::extract('/Country[name=/Canada|^$/]', $data);
|
|
$expected = array(
|
|
array(
|
|
'Country' => array(
|
|
'name' => 'Canada',
|
|
),
|
|
),
|
|
array(
|
|
'Country' => array(
|
|
'name' => null,
|
|
),
|
|
),
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testMatches method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testMatches() {
|
|
$a = array(
|
|
array('Article' => array('id' => 1, 'title' => 'Article 1')),
|
|
array('Article' => array('id' => 2, 'title' => 'Article 2')),
|
|
array('Article' => array('id' => 3, 'title' => 'Article 3'))
|
|
);
|
|
|
|
$this->assertTrue(Set::matches(array('id=2'), $a[1]['Article']));
|
|
$this->assertFalse(Set::matches(array('id>2'), $a[1]['Article']));
|
|
$this->assertTrue(Set::matches(array('id>=2'), $a[1]['Article']));
|
|
$this->assertFalse(Set::matches(array('id>=3'), $a[1]['Article']));
|
|
$this->assertTrue(Set::matches(array('id<=2'), $a[1]['Article']));
|
|
$this->assertFalse(Set::matches(array('id<2'), $a[1]['Article']));
|
|
$this->assertTrue(Set::matches(array('id>1'), $a[1]['Article']));
|
|
$this->assertTrue(Set::matches(array('id>1', 'id<3', 'id!=0'), $a[1]['Article']));
|
|
|
|
$this->assertTrue(Set::matches(array('3'), null, 3));
|
|
$this->assertTrue(Set::matches(array('5'), null, 5));
|
|
|
|
$this->assertTrue(Set::matches(array('id'), $a[1]['Article']));
|
|
$this->assertTrue(Set::matches(array('id', 'title'), $a[1]['Article']));
|
|
$this->assertFalse(Set::matches(array('non-existant'), $a[1]['Article']));
|
|
|
|
$this->assertTrue(Set::matches('/Article[id=2]', $a));
|
|
$this->assertFalse(Set::matches('/Article[id=4]', $a));
|
|
$this->assertTrue(Set::matches(array(), $a));
|
|
|
|
$r = array(
|
|
'Attachment' => array(
|
|
'keep' => array()
|
|
),
|
|
'Comment' => array(
|
|
'keep' => array(
|
|
'Attachment' => array(
|
|
'fields' => array(
|
|
0 => 'attachment',
|
|
),
|
|
),
|
|
)
|
|
),
|
|
'User' => array(
|
|
'keep' => array()
|
|
),
|
|
'Article' => array(
|
|
'keep' => array(
|
|
'Comment' => array(
|
|
'fields' => array(
|
|
0 => 'comment',
|
|
1 => 'published',
|
|
),
|
|
),
|
|
'User' => array(
|
|
'fields' => array(
|
|
0 => 'user',
|
|
),
|
|
),
|
|
)
|
|
)
|
|
);
|
|
|
|
$this->assertTrue(Set::matches('/Article/keep/Comment', $r));
|
|
$this->assertEquals(array('comment', 'published'), Set::extract('/Article/keep/Comment/fields', $r));
|
|
$this->assertEquals(array('user'), Set::extract('/Article/keep/User/fields', $r));
|
|
}
|
|
|
|
/**
|
|
* testSetExtractReturnsEmptyArray method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testSetExtractReturnsEmptyArray() {
|
|
$this->assertEquals(Set::extract(array(), '/Post/id'), array());
|
|
|
|
$this->assertEquals(Set::extract('/Post/id', array()), array());
|
|
|
|
$this->assertEquals(Set::extract('/Post/id', array(
|
|
array('Post' => array('name' => 'bob')),
|
|
array('Post' => array('name' => 'jim'))
|
|
)), array());
|
|
|
|
$this->assertEquals(Set::extract(array(), 'Message.flash'), null);
|
|
}
|
|
|
|
/**
|
|
* testClassicExtract method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testClassicExtract() {
|
|
$a = array(
|
|
array('Article' => array('id' => 1, 'title' => 'Article 1')),
|
|
array('Article' => array('id' => 2, 'title' => 'Article 2')),
|
|
array('Article' => array('id' => 3, 'title' => 'Article 3'))
|
|
);
|
|
|
|
$result = Set::extract($a, '{n}.Article.id');
|
|
$expected = array(1, 2, 3);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{n}.Article.title');
|
|
$expected = array('Article 1', 'Article 2', 'Article 3');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '1.Article.title');
|
|
$expected = 'Article 2';
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '3.Article.title');
|
|
$expected = null;
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array(
|
|
array(
|
|
'Article' => array('id' => 1, 'title' => 'Article 1',
|
|
'User' => array('id' => 1, 'username' => 'mariano.iglesias'))
|
|
),
|
|
array(
|
|
'Article' => array('id' => 2, 'title' => 'Article 2',
|
|
'User' => array('id' => 1, 'username' => 'mariano.iglesias'))
|
|
),
|
|
array(
|
|
'Article' => array('id' => 3, 'title' => 'Article 3',
|
|
'User' => array('id' => 2, 'username' => 'phpnut'))
|
|
)
|
|
);
|
|
|
|
$result = Set::extract($a, '{n}.Article.User.username');
|
|
$expected = array('mariano.iglesias', 'mariano.iglesias', 'phpnut');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array(
|
|
array(
|
|
'Article' => array(
|
|
'id' => 1, 'title' => 'Article 1',
|
|
'Comment' => array(
|
|
array('id' => 10, 'title' => 'Comment 10'),
|
|
array('id' => 11, 'title' => 'Comment 11'),
|
|
array('id' => 12, 'title' => 'Comment 12')
|
|
)
|
|
)
|
|
),
|
|
array(
|
|
'Article' => array(
|
|
'id' => 2, 'title' => 'Article 2',
|
|
'Comment' => array(
|
|
array('id' => 13, 'title' => 'Comment 13'),
|
|
array('id' => 14, 'title' => 'Comment 14')
|
|
)
|
|
)
|
|
),
|
|
array('Article' => array('id' => 3, 'title' => 'Article 3'))
|
|
);
|
|
|
|
$result = Set::extract($a, '{n}.Article.Comment.{n}.id');
|
|
$expected = array(array(10, 11, 12), array(13, 14), null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{n}.Article.Comment.{n}.title');
|
|
$expected = array(
|
|
array('Comment 10', 'Comment 11', 'Comment 12'),
|
|
array('Comment 13', 'Comment 14'),
|
|
null
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array(array('1day' => '20 sales'), array('1day' => '2 sales'));
|
|
$result = Set::extract($a, '{n}.1day');
|
|
$expected = array('20 sales', '2 sales');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array(
|
|
'pages' => array('name' => 'page'),
|
|
'fruites' => array('name' => 'fruit'),
|
|
0 => array('name' => 'zero')
|
|
);
|
|
$result = Set::extract($a, '{s}.name');
|
|
$expected = array('page', 'fruit');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array(
|
|
0 => array('pages' => array('name' => 'page')),
|
|
1 => array('fruites' => array('name' => 'fruit')),
|
|
'test' => array(array('name' => 'jippi')),
|
|
'dot.test' => array(array('name' => 'jippi'))
|
|
);
|
|
|
|
$result = Set::extract($a, '{n}.{s}.name');
|
|
$expected = array(0 => array('page'), 1 => array('fruit'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{s}.{n}.name');
|
|
$expected = array(array('jippi'), array('jippi'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{\w+}.{\w+}.name');
|
|
$expected = array(
|
|
array('pages' => 'page'),
|
|
array('fruites' => 'fruit'),
|
|
'test' => array('jippi'),
|
|
'dot.test' => array('jippi')
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{\d+}.{\w+}.name');
|
|
$expected = array(array('pages' => 'page'), array('fruites' => 'fruit'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{n}.{\w+}.name');
|
|
$expected = array(array('pages' => 'page'), array('fruites' => 'fruit'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{s}.{\d+}.name');
|
|
$expected = array(array('jippi'), array('jippi'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{s}');
|
|
$expected = array(array(array('name' => 'jippi')), array(array('name' => 'jippi')));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{[a-z]}');
|
|
$expected = array(
|
|
'test' => array(array('name' => 'jippi')),
|
|
'dot.test' => array(array('name' => 'jippi'))
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, '{dot\.test}.{n}');
|
|
$expected = array('dot.test' => array(array('name' => 'jippi')));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = new stdClass();
|
|
$a->articles = array(
|
|
array('Article' => array('id' => 1, 'title' => 'Article 1')),
|
|
array('Article' => array('id' => 2, 'title' => 'Article 2')),
|
|
array('Article' => array('id' => 3, 'title' => 'Article 3'))
|
|
);
|
|
|
|
$result = Set::extract($a, 'articles.{n}.Article.id');
|
|
$expected = array(1, 2, 3);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, 'articles.{n}.Article.title');
|
|
$expected = array('Article 1', 'Article 2', 'Article 3');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = new ArrayObject();
|
|
$a['articles'] = array(
|
|
array('Article' => array('id' => 1, 'title' => 'Article 1')),
|
|
array('Article' => array('id' => 2, 'title' => 'Article 2')),
|
|
array('Article' => array('id' => 3, 'title' => 'Article 3'))
|
|
);
|
|
|
|
$result = Set::extract($a, 'articles.{n}.Article.id');
|
|
$expected = array(1, 2, 3);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, 'articles.{n}.Article.title');
|
|
$expected = array('Article 1', 'Article 2', 'Article 3');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::extract($a, 'articles.0.Article.title');
|
|
$expected = 'Article 1';
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* test classicExtract with keys that exceed 32bit max int.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testClassicExtractMaxInt() {
|
|
$data = array(
|
|
'Data' => array(
|
|
'13376924712' => 'abc'
|
|
)
|
|
);
|
|
$this->assertEquals('abc', Set::classicExtract($data, 'Data.13376924712'));
|
|
}
|
|
|
|
/**
|
|
* testInsert method
|
|
*
|
|
* @see Hash tests, as Set::insert() is just a proxy.
|
|
* @return void
|
|
*/
|
|
public function testInsert() {
|
|
$a = array(
|
|
'pages' => array('name' => 'page')
|
|
);
|
|
|
|
$result = Set::insert($a, 'files', array('name' => 'files'));
|
|
$expected = array(
|
|
'pages' => array('name' => 'page'),
|
|
'files' => array('name' => 'files')
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testRemove method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testRemove() {
|
|
$a = array(
|
|
'pages' => array('name' => 'page'),
|
|
'files' => array('name' => 'files')
|
|
);
|
|
|
|
$result = Set::remove($a, 'files');
|
|
$expected = array(
|
|
'pages' => array('name' => 'page')
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testCheck method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testCheck() {
|
|
$set = array(
|
|
'My Index 1' => array('First' => 'The first item')
|
|
);
|
|
$this->assertTrue(Set::check($set, 'My Index 1.First'));
|
|
$this->assertTrue(Set::check($set, 'My Index 1'));
|
|
$this->assertEquals(Set::check($set, array()), $set);
|
|
|
|
$set = array(
|
|
'My Index 1' => array('First' => array('Second' => array('Third' => array('Fourth' => 'Heavy. Nesting.'))))
|
|
);
|
|
$this->assertTrue(Set::check($set, 'My Index 1.First.Second'));
|
|
$this->assertTrue(Set::check($set, 'My Index 1.First.Second.Third'));
|
|
$this->assertTrue(Set::check($set, 'My Index 1.First.Second.Third.Fourth'));
|
|
$this->assertFalse(Set::check($set, 'My Index 1.First.Seconds.Third.Fourth'));
|
|
}
|
|
|
|
/**
|
|
* testWritingWithFunkyKeys method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testWritingWithFunkyKeys() {
|
|
$set = Set::insert(array(), 'Session Test', "test");
|
|
$this->assertEquals('test', Set::extract($set, 'Session Test'));
|
|
|
|
$set = Set::remove($set, 'Session Test');
|
|
$this->assertFalse(Set::check($set, 'Session Test'));
|
|
|
|
$expected = array('Session Test' => array('Test Case' => 'test'));
|
|
$this->assertEquals($expected, Set::insert(array(), 'Session Test.Test Case', "test"));
|
|
$this->assertTrue(Set::check($expected, 'Session Test.Test Case'));
|
|
}
|
|
|
|
/**
|
|
* testDiff method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testDiff() {
|
|
$a = array(
|
|
0 => array('name' => 'main'),
|
|
1 => array('name' => 'about')
|
|
);
|
|
$b = array(
|
|
0 => array('name' => 'main'),
|
|
1 => array('name' => 'about'),
|
|
2 => array('name' => 'contact')
|
|
);
|
|
|
|
$result = Set::diff($a, $b);
|
|
$expected = array(
|
|
2 => array('name' => 'contact')
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::diff($a, array());
|
|
$expected = $a;
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::diff(array(), $b);
|
|
$expected = $b;
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$b = array(
|
|
0 => array('name' => 'me'),
|
|
1 => array('name' => 'about')
|
|
);
|
|
|
|
$result = Set::diff($a, $b);
|
|
$expected = array(
|
|
0 => array('name' => 'main')
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array();
|
|
$b = array('name' => 'bob', 'address' => 'home');
|
|
$result = Set::diff($a, $b);
|
|
$this->assertEquals($b, $result);
|
|
|
|
$a = array('name' => 'bob', 'address' => 'home');
|
|
$b = array();
|
|
$result = Set::diff($a, $b);
|
|
$this->assertEquals($a, $result);
|
|
|
|
$a = array('key' => true, 'another' => false, 'name' => 'me');
|
|
$b = array('key' => 1, 'another' => 0);
|
|
$expected = array('name' => 'me');
|
|
$result = Set::diff($a, $b);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array('key' => 'value', 'another' => null, 'name' => 'me');
|
|
$b = array('key' => 'differentValue', 'another' => null);
|
|
$expected = array('key' => 'value', 'name' => 'me');
|
|
$result = Set::diff($a, $b);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array('key' => 'value', 'another' => null, 'name' => 'me');
|
|
$b = array('key' => 'differentValue', 'another' => 'value');
|
|
$expected = array('key' => 'value', 'another' => null, 'name' => 'me');
|
|
$result = Set::diff($a, $b);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array('key' => 'value', 'another' => null, 'name' => 'me');
|
|
$b = array('key' => 'differentValue', 'another' => 'value');
|
|
$expected = array('key' => 'differentValue', 'another' => 'value', 'name' => 'me');
|
|
$result = Set::diff($b, $a);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$a = array('key' => 'value', 'another' => null, 'name' => 'me');
|
|
$b = array(0 => 'differentValue', 1 => 'value');
|
|
$expected = $a + $b;
|
|
$result = Set::diff($a, $b);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testContains method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testContains() {
|
|
$a = array(
|
|
0 => array('name' => 'main'),
|
|
1 => array('name' => 'about')
|
|
);
|
|
$b = array(
|
|
0 => array('name' => 'main'),
|
|
1 => array('name' => 'about'),
|
|
2 => array('name' => 'contact'),
|
|
'a' => 'b'
|
|
);
|
|
|
|
$this->assertTrue(Set::contains($a, $a));
|
|
$this->assertFalse(Set::contains($a, $b));
|
|
$this->assertTrue(Set::contains($b, $a));
|
|
}
|
|
|
|
/**
|
|
* testCombine method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testCombine() {
|
|
$result = Set::combine(array(), '{n}.User.id', '{n}.User.Data');
|
|
$this->assertTrue(empty($result));
|
|
$result = Set::combine('', '{n}.User.id', '{n}.User.Data');
|
|
$this->assertTrue(empty($result));
|
|
|
|
$a = array(
|
|
array('User' => array('id' => 2, 'group_id' => 1,
|
|
'Data' => array('user' => 'mariano.iglesias', 'name' => 'Mariano Iglesias'))),
|
|
array('User' => array('id' => 14, 'group_id' => 2,
|
|
'Data' => array('user' => 'phpnut', 'name' => 'Larry E. Masters'))),
|
|
array('User' => array('id' => 25, 'group_id' => 1,
|
|
'Data' => array('user' => 'gwoo', 'name' => 'The Gwoo'))));
|
|
$result = Set::combine($a, '{n}.User.id');
|
|
$expected = array(2 => null, 14 => null, 25 => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.non-existant');
|
|
$expected = array(2 => null, 14 => null, 25 => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.Data');
|
|
$expected = array(
|
|
2 => array('user' => 'mariano.iglesias', 'name' => 'Mariano Iglesias'),
|
|
14 => array('user' => 'phpnut', 'name' => 'Larry E. Masters'),
|
|
25 => array('user' => 'gwoo', 'name' => 'The Gwoo'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.Data.name');
|
|
$expected = array(
|
|
2 => 'Mariano Iglesias',
|
|
14 => 'Larry E. Masters',
|
|
25 => 'The Gwoo');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.Data', '{n}.User.group_id');
|
|
$expected = array(
|
|
1 => array(
|
|
2 => array('user' => 'mariano.iglesias', 'name' => 'Mariano Iglesias'),
|
|
25 => array('user' => 'gwoo', 'name' => 'The Gwoo')),
|
|
2 => array(
|
|
14 => array('user' => 'phpnut', 'name' => 'Larry E. Masters')));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.Data.name', '{n}.User.group_id');
|
|
$expected = array(
|
|
1 => array(
|
|
2 => 'Mariano Iglesias',
|
|
25 => 'The Gwoo'),
|
|
2 => array(
|
|
14 => 'Larry E. Masters'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id');
|
|
$expected = array(2 => null, 14 => null, 25 => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.Data');
|
|
$expected = array(
|
|
2 => array('user' => 'mariano.iglesias', 'name' => 'Mariano Iglesias'),
|
|
14 => array('user' => 'phpnut', 'name' => 'Larry E. Masters'),
|
|
25 => array('user' => 'gwoo', 'name' => 'The Gwoo'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.Data.name');
|
|
$expected = array(2 => 'Mariano Iglesias', 14 => 'Larry E. Masters', 25 => 'The Gwoo');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.Data', '{n}.User.group_id');
|
|
$expected = array(
|
|
1 => array(
|
|
2 => array('user' => 'mariano.iglesias', 'name' => 'Mariano Iglesias'),
|
|
25 => array('user' => 'gwoo', 'name' => 'The Gwoo')),
|
|
2 => array(
|
|
14 => array('user' => 'phpnut', 'name' => 'Larry E. Masters')));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', '{n}.User.Data.name', '{n}.User.group_id');
|
|
$expected = array(
|
|
1 => array(
|
|
2 => 'Mariano Iglesias',
|
|
25 => 'The Gwoo'),
|
|
2 => array(
|
|
14 => 'Larry E. Masters'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, '{n}.User.id', array('{0}: {1}', '{n}.User.Data.user', '{n}.User.Data.name'), '{n}.User.group_id');
|
|
$expected = array(
|
|
1 => array(
|
|
2 => 'mariano.iglesias: Mariano Iglesias',
|
|
25 => 'gwoo: The Gwoo'),
|
|
2 => array(14 => 'phpnut: Larry E. Masters'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, array('{0}: {1}', '{n}.User.Data.user', '{n}.User.Data.name'), '{n}.User.id');
|
|
$expected = array('mariano.iglesias: Mariano Iglesias' => 2, 'phpnut: Larry E. Masters' => 14, 'gwoo: The Gwoo' => 25);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, array('{1}: {0}', '{n}.User.Data.user', '{n}.User.Data.name'), '{n}.User.id');
|
|
$expected = array('Mariano Iglesias: mariano.iglesias' => 2, 'Larry E. Masters: phpnut' => 14, 'The Gwoo: gwoo' => 25);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, array('%1$s: %2$d', '{n}.User.Data.user', '{n}.User.id'), '{n}.User.Data.name');
|
|
$expected = array('mariano.iglesias: 2' => 'Mariano Iglesias', 'phpnut: 14' => 'Larry E. Masters', 'gwoo: 25' => 'The Gwoo');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, array('%2$d: %1$s', '{n}.User.Data.user', '{n}.User.id'), '{n}.User.Data.name');
|
|
$expected = array('2: mariano.iglesias' => 'Mariano Iglesias', '14: phpnut' => 'Larry E. Masters', '25: gwoo' => 'The Gwoo');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$b = new stdClass();
|
|
$b->users = array(
|
|
array('User' => array('id' => 2, 'group_id' => 1,
|
|
'Data' => array('user' => 'mariano.iglesias', 'name' => 'Mariano Iglesias'))),
|
|
array('User' => array('id' => 14, 'group_id' => 2,
|
|
'Data' => array('user' => 'phpnut', 'name' => 'Larry E. Masters'))),
|
|
array('User' => array('id' => 25, 'group_id' => 1,
|
|
'Data' => array('user' => 'gwoo', 'name' => 'The Gwoo'))));
|
|
$result = Set::combine($b, 'users.{n}.User.id');
|
|
$expected = array(2 => null, 14 => null, 25 => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($b, 'users.{n}.User.id', 'users.{n}.User.non-existant');
|
|
$expected = array(2 => null, 14 => null, 25 => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::combine($a, 'fail', 'fail');
|
|
$this->assertSame(array(), $result);
|
|
}
|
|
|
|
/**
|
|
* testMapReverse method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testMapReverse() {
|
|
$result = Set::reverse(null);
|
|
$this->assertEquals(null, $result);
|
|
|
|
$result = Set::reverse(false);
|
|
$this->assertEquals(false, $result);
|
|
|
|
$expected = array(
|
|
'Array1' => array(
|
|
'Array1Data1' => 'Array1Data1 value 1', 'Array1Data2' => 'Array1Data2 value 2'),
|
|
'Array2' => array(
|
|
0 => array('Array2Data1' => 1, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
1 => array('Array2Data1' => 2, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
2 => array('Array2Data1' => 3, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
3 => array('Array2Data1' => 4, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
4 => array('Array2Data1' => 5, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4')),
|
|
'Array3' => array(
|
|
0 => array('Array3Data1' => 1, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
1 => array('Array3Data1' => 2, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
2 => array('Array3Data1' => 3, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
3 => array('Array3Data1' => 4, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
4 => array('Array3Data1' => 5, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4')));
|
|
$map = Set::map($expected, true);
|
|
$this->assertEquals($expected['Array1']['Array1Data1'], $map->Array1->Array1Data1);
|
|
$this->assertEquals($expected['Array2'][0]['Array2Data1'], $map->Array2[0]->Array2Data1);
|
|
|
|
$result = Set::reverse($map);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$expected = array(
|
|
'Post' => array('id' => 1, 'title' => 'First Post'),
|
|
'Comment' => array(
|
|
array('id' => 1, 'title' => 'First Comment'),
|
|
array('id' => 2, 'title' => 'Second Comment')
|
|
),
|
|
'Tag' => array(
|
|
array('id' => 1, 'title' => 'First Tag'),
|
|
array('id' => 2, 'title' => 'Second Tag')
|
|
),
|
|
);
|
|
$map = Set::map($expected);
|
|
$this->assertEquals($expected['Post']['title'], $map->title);
|
|
foreach ($map->Comment as $comment) {
|
|
$ids[] = $comment->id;
|
|
}
|
|
$this->assertEquals(array(1, 2), $ids);
|
|
|
|
$expected = array(
|
|
'Array1' => array(
|
|
'Array1Data1' => 'Array1Data1 value 1', 'Array1Data2' => 'Array1Data2 value 2', 'Array1Data3' => 'Array1Data3 value 3', 'Array1Data4' => 'Array1Data4 value 4',
|
|
'Array1Data5' => 'Array1Data5 value 5', 'Array1Data6' => 'Array1Data6 value 6', 'Array1Data7' => 'Array1Data7 value 7', 'Array1Data8' => 'Array1Data8 value 8'),
|
|
'string' => 1,
|
|
'another' => 'string',
|
|
'some' => 'thing else',
|
|
'Array2' => array(
|
|
0 => array('Array2Data1' => 1, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
1 => array('Array2Data1' => 2, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
2 => array('Array2Data1' => 3, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
3 => array('Array2Data1' => 4, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
4 => array('Array2Data1' => 5, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4')),
|
|
'Array3' => array(
|
|
0 => array('Array3Data1' => 1, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
1 => array('Array3Data1' => 2, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
2 => array('Array3Data1' => 3, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
3 => array('Array3Data1' => 4, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
4 => array('Array3Data1' => 5, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4')));
|
|
$map = Set::map($expected, true);
|
|
$result = Set::reverse($map);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$expected = array(
|
|
'Array1' => array(
|
|
'Array1Data1' => 'Array1Data1 value 1', 'Array1Data2' => 'Array1Data2 value 2', 'Array1Data3' => 'Array1Data3 value 3', 'Array1Data4' => 'Array1Data4 value 4',
|
|
'Array1Data5' => 'Array1Data5 value 5', 'Array1Data6' => 'Array1Data6 value 6', 'Array1Data7' => 'Array1Data7 value 7', 'Array1Data8' => 'Array1Data8 value 8'),
|
|
'string' => 1,
|
|
'another' => 'string',
|
|
'some' => 'thing else',
|
|
'Array2' => array(
|
|
0 => array('Array2Data1' => 1, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
1 => array('Array2Data1' => 2, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
2 => array('Array2Data1' => 3, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
3 => array('Array2Data1' => 4, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4'),
|
|
4 => array('Array2Data1' => 5, 'Array2Data2' => 'Array2Data2 value 2', 'Array2Data3' => 'Array2Data3 value 2', 'Array2Data4' => 'Array2Data4 value 4')),
|
|
'string2' => 1,
|
|
'another2' => 'string',
|
|
'some2' => 'thing else',
|
|
'Array3' => array(
|
|
0 => array('Array3Data1' => 1, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
1 => array('Array3Data1' => 2, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
2 => array('Array3Data1' => 3, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
3 => array('Array3Data1' => 4, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4'),
|
|
4 => array('Array3Data1' => 5, 'Array3Data2' => 'Array3Data2 value 2', 'Array3Data3' => 'Array3Data3 value 2', 'Array3Data4' => 'Array3Data4 value 4')),
|
|
'string3' => 1,
|
|
'another3' => 'string',
|
|
'some3' => 'thing else');
|
|
$map = Set::map($expected, true);
|
|
$result = Set::reverse($map);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$expected = array('User' => array('psword' => 'whatever', 'Icon' => array('id' => 851)));
|
|
$map = Set::map($expected);
|
|
$result = Set::reverse($map);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$expected = array('User' => array('psword' => 'whatever', 'Icon' => array('id' => 851)));
|
|
$class = new stdClass;
|
|
$class->User = new stdClass;
|
|
$class->User->psword = 'whatever';
|
|
$class->User->Icon = new stdClass;
|
|
$class->User->Icon->id = 851;
|
|
$result = Set::reverse($class);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$expected = array('User' => array('psword' => 'whatever', 'Icon' => array('id' => 851), 'Profile' => array('name' => 'Some Name', 'address' => 'Some Address')));
|
|
$class = new stdClass;
|
|
$class->User = new stdClass;
|
|
$class->User->psword = 'whatever';
|
|
$class->User->Icon = new stdClass;
|
|
$class->User->Icon->id = 851;
|
|
$class->User->Profile = new stdClass;
|
|
$class->User->Profile->name = 'Some Name';
|
|
$class->User->Profile->address = 'Some Address';
|
|
|
|
$result = Set::reverse($class);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$expected = array('User' => array('psword' => 'whatever',
|
|
'Icon' => array('id' => 851),
|
|
'Profile' => array('name' => 'Some Name', 'address' => 'Some Address'),
|
|
'Comment' => array(
|
|
array('id' => 1, 'article_id' => 1, 'user_id' => 1, 'comment' => 'First Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:47:23', 'updated' => '2007-03-18 10:49:31'),
|
|
array('id' => 2, 'article_id' => 1, 'user_id' => 2, 'comment' => 'Second Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:47:23', 'updated' => '2007-03-18 10:49:31'))));
|
|
|
|
$class = new stdClass;
|
|
$class->User = new stdClass;
|
|
$class->User->psword = 'whatever';
|
|
$class->User->Icon = new stdClass;
|
|
$class->User->Icon->id = 851;
|
|
$class->User->Profile = new stdClass;
|
|
$class->User->Profile->name = 'Some Name';
|
|
$class->User->Profile->address = 'Some Address';
|
|
$class->User->Comment = new stdClass;
|
|
$class->User->Comment->{'0'} = new stdClass;
|
|
$class->User->Comment->{'0'}->id = 1;
|
|
$class->User->Comment->{'0'}->article_id = 1;
|
|
$class->User->Comment->{'0'}->user_id = 1;
|
|
$class->User->Comment->{'0'}->comment = 'First Comment for First Article';
|
|
$class->User->Comment->{'0'}->published = 'Y';
|
|
$class->User->Comment->{'0'}->created = '2007-03-18 10:47:23';
|
|
$class->User->Comment->{'0'}->updated = '2007-03-18 10:49:31';
|
|
$class->User->Comment->{'1'} = new stdClass;
|
|
$class->User->Comment->{'1'}->id = 2;
|
|
$class->User->Comment->{'1'}->article_id = 1;
|
|
$class->User->Comment->{'1'}->user_id = 2;
|
|
$class->User->Comment->{'1'}->comment = 'Second Comment for First Article';
|
|
$class->User->Comment->{'1'}->published = 'Y';
|
|
$class->User->Comment->{'1'}->created = '2007-03-18 10:47:23';
|
|
$class->User->Comment->{'1'}->updated = '2007-03-18 10:49:31';
|
|
|
|
$result = Set::reverse($class);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$expected = array('User' => array('psword' => 'whatever',
|
|
'Icon' => array('id' => 851),
|
|
'Profile' => array('name' => 'Some Name', 'address' => 'Some Address'),
|
|
'Comment' => array(
|
|
array('id' => 1, 'article_id' => 1, 'user_id' => 1, 'comment' => 'First Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:47:23', 'updated' => '2007-03-18 10:49:31'),
|
|
array('id' => 2, 'article_id' => 1, 'user_id' => 2, 'comment' => 'Second Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:47:23', 'updated' => '2007-03-18 10:49:31'))));
|
|
|
|
// @codingStandardsIgnoreStart
|
|
$class = new stdClass;
|
|
$class->User = new stdClass;
|
|
$class->User->psword = 'whatever';
|
|
$class->User->Icon = new stdClass;
|
|
$class->User->Icon->id = 851;
|
|
$class->User->Profile = new stdClass;
|
|
$class->User->Profile->name = 'Some Name';
|
|
$class->User->Profile->address = 'Some Address';
|
|
$class->User->Comment = array();
|
|
$comment = new stdClass;
|
|
$comment->id = 1;
|
|
$comment->article_id = 1;
|
|
$comment->user_id = 1;
|
|
$comment->comment = 'First Comment for First Article';
|
|
$comment->published = 'Y';
|
|
$comment->created = '2007-03-18 10:47:23';
|
|
$comment->updated = '2007-03-18 10:49:31';
|
|
$comment2 = new stdClass;
|
|
$comment2->id = 2;
|
|
$comment2->article_id = 1;
|
|
$comment2->user_id = 2;
|
|
$comment2->comment = 'Second Comment for First Article';
|
|
$comment2->published = 'Y';
|
|
$comment2->created = '2007-03-18 10:47:23';
|
|
$comment2->updated = '2007-03-18 10:49:31';
|
|
// @codingStandardsIgnoreEnd
|
|
$class->User->Comment = array($comment, $comment2);
|
|
$result = Set::reverse($class);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$class = new stdClass;
|
|
$class->User = new stdClass;
|
|
$class->User->id = 100;
|
|
$class->someString = 'this is some string';
|
|
$class->Profile = new stdClass;
|
|
$class->Profile->name = 'Joe Mamma';
|
|
|
|
$result = Set::reverse($class);
|
|
$expected = array(
|
|
'User' => array('id' => '100'),
|
|
'someString' => 'this is some string',
|
|
'Profile' => array('name' => 'Joe Mamma')
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
// @codingStandardsIgnoreStart
|
|
$class = new stdClass;
|
|
$class->User = new stdClass;
|
|
$class->User->id = 100;
|
|
$class->User->_name_ = 'User';
|
|
$class->Profile = new stdClass;
|
|
$class->Profile->name = 'Joe Mamma';
|
|
$class->Profile->_name_ = 'Profile';
|
|
// @codingStandardsIgnoreEnd
|
|
|
|
$result = Set::reverse($class);
|
|
$expected = array('User' => array('id' => '100'), 'Profile' => array('name' => 'Joe Mamma'));
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testFormatting method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testFormatting() {
|
|
$data = array(
|
|
array('Person' => array('first_name' => 'Nate', 'last_name' => 'Abele', 'city' => 'Boston', 'state' => 'MA', 'something' => '42')),
|
|
array('Person' => array('first_name' => 'Larry', 'last_name' => 'Masters', 'city' => 'Boondock', 'state' => 'TN', 'something' => '{0}')),
|
|
array('Person' => array('first_name' => 'Garrett', 'last_name' => 'Woodworth', 'city' => 'Venice Beach', 'state' => 'CA', 'something' => '{1}')));
|
|
|
|
$result = Set::format($data, '{1}, {0}', array('{n}.Person.first_name', '{n}.Person.last_name'));
|
|
$expected = array('Abele, Nate', 'Masters, Larry', 'Woodworth, Garrett');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '{0}, {1}', array('{n}.Person.last_name', '{n}.Person.first_name'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '{0}, {1}', array('{n}.Person.city', '{n}.Person.state'));
|
|
$expected = array('Boston, MA', 'Boondock, TN', 'Venice Beach, CA');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '{{0}, {1}}', array('{n}.Person.city', '{n}.Person.state'));
|
|
$expected = array('{Boston, MA}', '{Boondock, TN}', '{Venice Beach, CA}');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '{{0}, {1}}', array('{n}.Person.something', '{n}.Person.something'));
|
|
$expected = array('{42, 42}', '{{0}, {0}}', '{{1}, {1}}');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '{%2$d, %1$s}', array('{n}.Person.something', '{n}.Person.something'));
|
|
$expected = array('{42, 42}', '{0, {0}}', '{0, {1}}');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '{%1$s, %1$s}', array('{n}.Person.something', '{n}.Person.something'));
|
|
$expected = array('{42, 42}', '{{0}, {0}}', '{{1}, {1}}');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '%2$d, %1$s', array('{n}.Person.first_name', '{n}.Person.something'));
|
|
$expected = array('42, Nate', '0, Larry', '0, Garrett');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '%1$s, %2$d', array('{n}.Person.first_name', '{n}.Person.something'));
|
|
$expected = array('Nate, 42', 'Larry, 0', 'Garrett, 0');
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testFormattingNullValues method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testFormattingNullValues() {
|
|
$data = array(
|
|
array('Person' => array('first_name' => 'Nate', 'last_name' => 'Abele', 'city' => 'Boston', 'state' => 'MA', 'something' => '42')),
|
|
array('Person' => array('first_name' => 'Larry', 'last_name' => 'Masters', 'city' => 'Boondock', 'state' => 'TN', 'something' => null)),
|
|
array('Person' => array('first_name' => 'Garrett', 'last_name' => 'Woodworth', 'city' => 'Venice Beach', 'state' => 'CA', 'something' => null)));
|
|
|
|
$result = Set::format($data, '%s', array('{n}.Person.something'));
|
|
$expected = array('42', '', '');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::format($data, '{0}, {1}', array('{n}.Person.city', '{n}.Person.something'));
|
|
$expected = array('Boston, 42', 'Boondock, ', 'Venice Beach, ');
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testCountDim method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testCountDim() {
|
|
$data = array('one', '2', 'three');
|
|
$result = Set::countDim($data);
|
|
$this->assertEquals(1, $result);
|
|
|
|
$data = array('1' => '1.1', '2', '3');
|
|
$result = Set::countDim($data);
|
|
$this->assertEquals(1, $result);
|
|
|
|
$data = array('1' => array('1.1' => '1.1.1'), '2', '3' => array('3.1' => '3.1.1'));
|
|
$result = Set::countDim($data);
|
|
$this->assertEquals(2, $result);
|
|
|
|
$data = array('1' => '1.1', '2', '3' => array('3.1' => '3.1.1'));
|
|
$result = Set::countDim($data);
|
|
$this->assertEquals(1, $result);
|
|
|
|
$data = array('1' => '1.1', '2', '3' => array('3.1' => '3.1.1'));
|
|
$result = Set::countDim($data, true);
|
|
$this->assertEquals(2, $result);
|
|
|
|
$data = array('1' => array('1.1' => '1.1.1'), '2', '3' => array('3.1' => array('3.1.1' => '3.1.1.1')));
|
|
$result = Set::countDim($data);
|
|
$this->assertEquals(2, $result);
|
|
|
|
$data = array('1' => array('1.1' => '1.1.1'), '2', '3' => array('3.1' => array('3.1.1' => '3.1.1.1')));
|
|
$result = Set::countDim($data, true);
|
|
$this->assertEquals(3, $result);
|
|
|
|
$data = array('1' => array('1.1' => '1.1.1'), array('2' => array('2.1' => array('2.1.1' => '2.1.1.1'))), '3' => array('3.1' => array('3.1.1' => '3.1.1.1')));
|
|
$result = Set::countDim($data, true);
|
|
$this->assertEquals(4, $result);
|
|
|
|
$data = array('1' => array('1.1' => '1.1.1'), array('2' => array('2.1' => array('2.1.1' => array('2.1.1.1')))), '3' => array('3.1' => array('3.1.1' => '3.1.1.1')));
|
|
$result = Set::countDim($data, true);
|
|
$this->assertEquals(5, $result);
|
|
|
|
$data = array('1' => array('1.1' => '1.1.1'), array('2' => array('2.1' => array('2.1.1' => array('2.1.1.1' => '2.1.1.1.1')))), '3' => array('3.1' => array('3.1.1' => '3.1.1.1')));
|
|
$result = Set::countDim($data, true);
|
|
$this->assertEquals(5, $result);
|
|
|
|
$set = array('1' => array('1.1' => '1.1.1'), array('2' => array('2.1' => array('2.1.1' => array('2.1.1.1' => '2.1.1.1.1')))), '3' => array('3.1' => array('3.1.1' => '3.1.1.1')));
|
|
$result = Set::countDim($set, false, 0);
|
|
$this->assertEquals(2, $result);
|
|
|
|
$result = Set::countDim($set, true);
|
|
$this->assertEquals(5, $result);
|
|
}
|
|
|
|
/**
|
|
* testMapNesting method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testMapNesting() {
|
|
$expected = array(
|
|
array(
|
|
"IndexedPage" => array(
|
|
"id" => 1,
|
|
"url" => 'http://blah.com/',
|
|
'hash' => '68a9f053b19526d08e36c6a9ad150737933816a5',
|
|
'headers' => array(
|
|
'Date' => "Wed, 14 Nov 2007 15:51:42 GMT",
|
|
'Server' => "Apache",
|
|
'Expires' => "Thu, 19 Nov 1981 08:52:00 GMT",
|
|
'Cache-Control' => "private",
|
|
'Pragma' => "no-cache",
|
|
'Content-Type' => "text/html; charset=UTF-8",
|
|
'X-Original-Transfer-Encoding' => "chunked",
|
|
'Content-Length' => "50210",
|
|
),
|
|
'meta' => array(
|
|
'keywords' => array('testing', 'tests'),
|
|
'description' => 'describe me',
|
|
),
|
|
'get_vars' => '',
|
|
'post_vars' => array(),
|
|
'cookies' => array('PHPSESSID' => "dde9896ad24595998161ffaf9e0dbe2d"),
|
|
'redirect' => '',
|
|
'created' => "1195055503",
|
|
'updated' => "1195055503",
|
|
)
|
|
),
|
|
array(
|
|
"IndexedPage" => array(
|
|
"id" => 2,
|
|
"url" => 'http://blah.com/',
|
|
'hash' => '68a9f053b19526d08e36c6a9ad150737933816a5',
|
|
'headers' => array(
|
|
'Date' => "Wed, 14 Nov 2007 15:51:42 GMT",
|
|
'Server' => "Apache",
|
|
'Expires' => "Thu, 19 Nov 1981 08:52:00 GMT",
|
|
'Cache-Control' => "private",
|
|
'Pragma' => "no-cache",
|
|
'Content-Type' => "text/html; charset=UTF-8",
|
|
'X-Original-Transfer-Encoding' => "chunked",
|
|
'Content-Length' => "50210",
|
|
),
|
|
'meta' => array(
|
|
'keywords' => array('testing', 'tests'),
|
|
'description' => 'describe me',
|
|
),
|
|
'get_vars' => '',
|
|
'post_vars' => array(),
|
|
'cookies' => array('PHPSESSID' => "dde9896ad24595998161ffaf9e0dbe2d"),
|
|
'redirect' => '',
|
|
'created' => "1195055503",
|
|
'updated' => "1195055503",
|
|
),
|
|
)
|
|
);
|
|
|
|
$mapped = Set::map($expected);
|
|
$ids = array();
|
|
|
|
foreach ($mapped as $object) {
|
|
$ids[] = $object->id;
|
|
}
|
|
$this->assertEquals(array(1, 2), $ids);
|
|
$this->assertEquals($expected[0]['IndexedPage']['headers'], get_object_vars($mapped[0]->headers));
|
|
|
|
$result = Set::reverse($mapped);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$data = array(
|
|
array(
|
|
"IndexedPage" => array(
|
|
"id" => 1,
|
|
"url" => 'http://blah.com/',
|
|
'hash' => '68a9f053b19526d08e36c6a9ad150737933816a5',
|
|
'get_vars' => '',
|
|
'redirect' => '',
|
|
'created' => "1195055503",
|
|
'updated' => "1195055503",
|
|
)
|
|
),
|
|
array(
|
|
"IndexedPage" => array(
|
|
"id" => 2,
|
|
"url" => 'http://blah.com/',
|
|
'hash' => '68a9f053b19526d08e36c6a9ad150737933816a5',
|
|
'get_vars' => '',
|
|
'redirect' => '',
|
|
'created' => "1195055503",
|
|
'updated' => "1195055503",
|
|
),
|
|
)
|
|
);
|
|
$mapped = Set::map($data);
|
|
|
|
// @codingStandardsIgnoreStart
|
|
$expected = new stdClass();
|
|
$expected->_name_ = 'IndexedPage';
|
|
$expected->id = 2;
|
|
$expected->url = 'http://blah.com/';
|
|
$expected->hash = '68a9f053b19526d08e36c6a9ad150737933816a5';
|
|
$expected->get_vars = '';
|
|
$expected->redirect = '';
|
|
$expected->created = '1195055503';
|
|
$expected->updated = '1195055503';
|
|
// @codingStandardsIgnoreEnd
|
|
$this->assertEquals($expected, $mapped[1]);
|
|
|
|
$ids = array();
|
|
|
|
foreach ($mapped as $object) {
|
|
$ids[] = $object->id;
|
|
}
|
|
$this->assertEquals(array(1, 2), $ids);
|
|
|
|
$result = Set::map(null);
|
|
$expected = null;
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testNestedMappedData method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testNestedMappedData() {
|
|
$result = Set::map(array(
|
|
array(
|
|
'Post' => array('id' => '1', 'author_id' => '1', 'title' => 'First Post', 'body' => 'First Post Body', 'published' => 'Y', 'created' => '2007-03-18 10:39:23', 'updated' => '2007-03-18 10:41:31'),
|
|
'Author' => array('id' => '1', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31', 'test' => 'working'),
|
|
),
|
|
array(
|
|
'Post' => array('id' => '2', 'author_id' => '3', 'title' => 'Second Post', 'body' => 'Second Post Body', 'published' => 'Y', 'created' => '2007-03-18 10:41:23', 'updated' => '2007-03-18 10:43:31'),
|
|
'Author' => array('id' => '3', 'user' => 'larry', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:20:23', 'updated' => '2007-03-17 01:22:31', 'test' => 'working'),
|
|
)
|
|
));
|
|
|
|
// @codingStandardsIgnoreStart
|
|
$expected = new stdClass;
|
|
$expected->_name_ = 'Post';
|
|
$expected->id = '1';
|
|
$expected->author_id = '1';
|
|
$expected->title = 'First Post';
|
|
$expected->body = 'First Post Body';
|
|
$expected->published = 'Y';
|
|
$expected->created = "2007-03-18 10:39:23";
|
|
$expected->updated = "2007-03-18 10:41:31";
|
|
|
|
$expected->Author = new stdClass;
|
|
$expected->Author->id = '1';
|
|
$expected->Author->user = 'mariano';
|
|
$expected->Author->password = '5f4dcc3b5aa765d61d8327deb882cf99';
|
|
$expected->Author->created = '2007-03-17 01:16:23';
|
|
$expected->Author->updated = '2007-03-17 01:18:31';
|
|
$expected->Author->test = 'working';
|
|
$expected->Author->_name_ = 'Author';
|
|
|
|
$expected2 = new stdClass;
|
|
$expected2->_name_ = 'Post';
|
|
$expected2->id = '2';
|
|
$expected2->author_id = '3';
|
|
$expected2->title = 'Second Post';
|
|
$expected2->body = 'Second Post Body';
|
|
$expected2->published = 'Y';
|
|
$expected2->created = "2007-03-18 10:41:23";
|
|
$expected2->updated = "2007-03-18 10:43:31";
|
|
|
|
$expected2->Author = new stdClass;
|
|
$expected2->Author->id = '3';
|
|
$expected2->Author->user = 'larry';
|
|
$expected2->Author->password = '5f4dcc3b5aa765d61d8327deb882cf99';
|
|
$expected2->Author->created = '2007-03-17 01:20:23';
|
|
$expected2->Author->updated = '2007-03-17 01:22:31';
|
|
$expected2->Author->test = 'working';
|
|
$expected2->Author->_name_ = 'Author';
|
|
// @codingStandardsIgnoreEnd
|
|
|
|
$test = array();
|
|
$test[0] = $expected;
|
|
$test[1] = $expected2;
|
|
|
|
$this->assertEquals($test, $result);
|
|
|
|
$result = Set::map(
|
|
array(
|
|
'Post' => array('id' => '1', 'author_id' => '1', 'title' => 'First Post', 'body' => 'First Post Body', 'published' => 'Y', 'created' => '2007-03-18 10:39:23', 'updated' => '2007-03-18 10:41:31'),
|
|
'Author' => array('id' => '1', 'user' => 'mariano', 'password' => '5f4dcc3b5aa765d61d8327deb882cf99', 'created' => '2007-03-17 01:16:23', 'updated' => '2007-03-17 01:18:31', 'test' => 'working'),
|
|
)
|
|
);
|
|
// @codingStandardsIgnoreStart
|
|
$expected = new stdClass;
|
|
$expected->_name_ = 'Post';
|
|
$expected->id = '1';
|
|
$expected->author_id = '1';
|
|
$expected->title = 'First Post';
|
|
$expected->body = 'First Post Body';
|
|
$expected->published = 'Y';
|
|
$expected->created = "2007-03-18 10:39:23";
|
|
$expected->updated = "2007-03-18 10:41:31";
|
|
|
|
$expected->Author = new stdClass;
|
|
$expected->Author->id = '1';
|
|
$expected->Author->user = 'mariano';
|
|
$expected->Author->password = '5f4dcc3b5aa765d61d8327deb882cf99';
|
|
$expected->Author->created = "2007-03-17 01:16:23";
|
|
$expected->Author->updated = "2007-03-17 01:18:31";
|
|
$expected->Author->test = 'working';
|
|
$expected->Author->_name_ = 'Author';
|
|
// @codingStandardsIgnoreEnd
|
|
$this->assertEquals($expected, $result);
|
|
|
|
//Case where extra HABTM fields come back in a result
|
|
$data = array(
|
|
'User' => array(
|
|
'id' => 1,
|
|
'email' => 'user@example.com',
|
|
'first_name' => 'John',
|
|
'last_name' => 'Smith',
|
|
),
|
|
'Piece' => array(
|
|
array(
|
|
'id' => 1,
|
|
'title' => 'Moonlight Sonata',
|
|
'composer' => 'Ludwig van Beethoven',
|
|
'PiecesUser' => array(
|
|
'id' => 1,
|
|
'created' => '2008-01-01 00:00:00',
|
|
'modified' => '2008-01-01 00:00:00',
|
|
'piece_id' => 1,
|
|
'user_id' => 2,
|
|
)
|
|
),
|
|
array(
|
|
'id' => 2,
|
|
'title' => 'Moonlight Sonata 2',
|
|
'composer' => 'Ludwig van Beethoven',
|
|
'PiecesUser' => array(
|
|
'id' => 2,
|
|
'created' => '2008-01-01 00:00:00',
|
|
'modified' => '2008-01-01 00:00:00',
|
|
'piece_id' => 2,
|
|
'user_id' => 2,
|
|
)
|
|
)
|
|
)
|
|
);
|
|
|
|
$result = Set::map($data);
|
|
|
|
// @codingStandardsIgnoreStart
|
|
$expected = new stdClass();
|
|
$expected->_name_ = 'User';
|
|
$expected->id = 1;
|
|
$expected->email = 'user@example.com';
|
|
$expected->first_name = 'John';
|
|
$expected->last_name = 'Smith';
|
|
|
|
$piece = new stdClass();
|
|
$piece->id = 1;
|
|
$piece->title = 'Moonlight Sonata';
|
|
$piece->composer = 'Ludwig van Beethoven';
|
|
|
|
$piece->PiecesUser = new stdClass();
|
|
$piece->PiecesUser->id = 1;
|
|
$piece->PiecesUser->created = '2008-01-01 00:00:00';
|
|
$piece->PiecesUser->modified = '2008-01-01 00:00:00';
|
|
$piece->PiecesUser->piece_id = 1;
|
|
$piece->PiecesUser->user_id = 2;
|
|
$piece->PiecesUser->_name_ = 'PiecesUser';
|
|
|
|
$piece->_name_ = 'Piece';
|
|
|
|
$piece2 = new stdClass();
|
|
$piece2->id = 2;
|
|
$piece2->title = 'Moonlight Sonata 2';
|
|
$piece2->composer = 'Ludwig van Beethoven';
|
|
|
|
$piece2->PiecesUser = new stdClass();
|
|
$piece2->PiecesUser->id = 2;
|
|
$piece2->PiecesUser->created = '2008-01-01 00:00:00';
|
|
$piece2->PiecesUser->modified = '2008-01-01 00:00:00';
|
|
$piece2->PiecesUser->piece_id = 2;
|
|
$piece2->PiecesUser->user_id = 2;
|
|
$piece2->PiecesUser->_name_ = 'PiecesUser';
|
|
|
|
$piece2->_name_ = 'Piece';
|
|
// @codingStandardsIgnoreEnd
|
|
|
|
$expected->Piece = array($piece, $piece2);
|
|
|
|
$this->assertEquals($expected, $result);
|
|
|
|
//Same data, but should work if _name_ has been manually defined:
|
|
$data = array(
|
|
'User' => array(
|
|
'id' => 1,
|
|
'email' => 'user@example.com',
|
|
'first_name' => 'John',
|
|
'last_name' => 'Smith',
|
|
'_name_' => 'FooUser',
|
|
),
|
|
'Piece' => array(
|
|
array(
|
|
'id' => 1,
|
|
'title' => 'Moonlight Sonata',
|
|
'composer' => 'Ludwig van Beethoven',
|
|
'_name_' => 'FooPiece',
|
|
'PiecesUser' => array(
|
|
'id' => 1,
|
|
'created' => '2008-01-01 00:00:00',
|
|
'modified' => '2008-01-01 00:00:00',
|
|
'piece_id' => 1,
|
|
'user_id' => 2,
|
|
'_name_' => 'FooPiecesUser',
|
|
)
|
|
),
|
|
array(
|
|
'id' => 2,
|
|
'title' => 'Moonlight Sonata 2',
|
|
'composer' => 'Ludwig van Beethoven',
|
|
'_name_' => 'FooPiece',
|
|
'PiecesUser' => array(
|
|
'id' => 2,
|
|
'created' => '2008-01-01 00:00:00',
|
|
'modified' => '2008-01-01 00:00:00',
|
|
'piece_id' => 2,
|
|
'user_id' => 2,
|
|
'_name_' => 'FooPiecesUser',
|
|
)
|
|
)
|
|
)
|
|
);
|
|
|
|
$result = Set::map($data);
|
|
|
|
// @codingStandardsIgnoreStart
|
|
$expected = new stdClass();
|
|
$expected->_name_ = 'FooUser';
|
|
$expected->id = 1;
|
|
$expected->email = 'user@example.com';
|
|
$expected->first_name = 'John';
|
|
$expected->last_name = 'Smith';
|
|
|
|
$piece = new stdClass();
|
|
$piece->id = 1;
|
|
$piece->title = 'Moonlight Sonata';
|
|
$piece->composer = 'Ludwig van Beethoven';
|
|
$piece->_name_ = 'FooPiece';
|
|
$piece->PiecesUser = new stdClass();
|
|
$piece->PiecesUser->id = 1;
|
|
$piece->PiecesUser->created = '2008-01-01 00:00:00';
|
|
$piece->PiecesUser->modified = '2008-01-01 00:00:00';
|
|
$piece->PiecesUser->piece_id = 1;
|
|
$piece->PiecesUser->user_id = 2;
|
|
$piece->PiecesUser->_name_ = 'FooPiecesUser';
|
|
|
|
$piece2 = new stdClass();
|
|
$piece2->id = 2;
|
|
$piece2->title = 'Moonlight Sonata 2';
|
|
$piece2->composer = 'Ludwig van Beethoven';
|
|
$piece2->_name_ = 'FooPiece';
|
|
$piece2->PiecesUser = new stdClass();
|
|
$piece2->PiecesUser->id = 2;
|
|
$piece2->PiecesUser->created = '2008-01-01 00:00:00';
|
|
$piece2->PiecesUser->modified = '2008-01-01 00:00:00';
|
|
$piece2->PiecesUser->piece_id = 2;
|
|
$piece2->PiecesUser->user_id = 2;
|
|
$piece2->PiecesUser->_name_ = 'FooPiecesUser';
|
|
// @codingStandardsIgnoreEnd
|
|
|
|
$expected->Piece = array($piece, $piece2);
|
|
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testPushDiff method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPushDiff() {
|
|
$array1 = array('ModelOne' => array('id' => 1001, 'field_one' => 'a1.m1.f1', 'field_two' => 'a1.m1.f2'));
|
|
$array2 = array('ModelTwo' => array('id' => 1002, 'field_one' => 'a2.m2.f1', 'field_two' => 'a2.m2.f2'));
|
|
|
|
$result = Set::pushDiff($array1, $array2);
|
|
|
|
$this->assertEquals($array1 + $array2, $result);
|
|
|
|
$array3 = array('ModelOne' => array('id' => 1003, 'field_one' => 'a3.m1.f1', 'field_two' => 'a3.m1.f2', 'field_three' => 'a3.m1.f3'));
|
|
$result = Set::pushDiff($array1, $array3);
|
|
|
|
$expected = array('ModelOne' => array('id' => 1001, 'field_one' => 'a1.m1.f1', 'field_two' => 'a1.m1.f2', 'field_three' => 'a3.m1.f3'));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$array1 = array(
|
|
0 => array('ModelOne' => array('id' => 1001, 'field_one' => 's1.0.m1.f1', 'field_two' => 's1.0.m1.f2')),
|
|
1 => array('ModelTwo' => array('id' => 1002, 'field_one' => 's1.1.m2.f2', 'field_two' => 's1.1.m2.f2')));
|
|
$array2 = array(
|
|
0 => array('ModelOne' => array('id' => 1001, 'field_one' => 's2.0.m1.f1', 'field_two' => 's2.0.m1.f2')),
|
|
1 => array('ModelTwo' => array('id' => 1002, 'field_one' => 's2.1.m2.f2', 'field_two' => 's2.1.m2.f2')));
|
|
|
|
$result = Set::pushDiff($array1, $array2);
|
|
$this->assertEquals($array1, $result);
|
|
|
|
$array3 = array(0 => array('ModelThree' => array('id' => 1003, 'field_one' => 's3.0.m3.f1', 'field_two' => 's3.0.m3.f2')));
|
|
|
|
$result = Set::pushDiff($array1, $array3);
|
|
$expected = array(
|
|
0 => array('ModelOne' => array('id' => 1001, 'field_one' => 's1.0.m1.f1', 'field_two' => 's1.0.m1.f2'),
|
|
'ModelThree' => array('id' => 1003, 'field_one' => 's3.0.m3.f1', 'field_two' => 's3.0.m3.f2')),
|
|
1 => array('ModelTwo' => array('id' => 1002, 'field_one' => 's1.1.m2.f2', 'field_two' => 's1.1.m2.f2')));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::pushDiff($array1, null);
|
|
$this->assertEquals($array1, $result);
|
|
|
|
$result = Set::pushDiff($array1, $array2);
|
|
$this->assertEquals($array1 + $array2, $result);
|
|
}
|
|
|
|
/**
|
|
* testSetApply method
|
|
* @return void
|
|
*/
|
|
public function testApply() {
|
|
$data = array(
|
|
array('Movie' => array('id' => 1, 'title' => 'movie 3', 'rating' => 5)),
|
|
array('Movie' => array('id' => 1, 'title' => 'movie 1', 'rating' => 1)),
|
|
array('Movie' => array('id' => 1, 'title' => 'movie 2', 'rating' => 3))
|
|
);
|
|
|
|
$result = Set::apply('/Movie/rating', $data, 'array_sum');
|
|
$expected = 9;
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::apply('/Movie/rating', $data, 'array_product');
|
|
$expected = 15;
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::apply('/Movie/title', $data, 'ucfirst', array('type' => 'map'));
|
|
$expected = array('Movie 3', 'Movie 1', 'Movie 2');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::apply('/Movie/title', $data, 'strtoupper', array('type' => 'map'));
|
|
$expected = array('MOVIE 3', 'MOVIE 1', 'MOVIE 2');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::apply('/Movie/rating', $data, array('SetTest', 'method'), array('type' => 'reduce'));
|
|
$expected = 9;
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::apply('/Movie/rating', $data, 'strtoupper', array('type' => 'non existing type'));
|
|
$expected = null;
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* Helper method to test Set::apply()
|
|
*
|
|
* @return void
|
|
*/
|
|
public static function method($val1, $val2) {
|
|
$val1 += $val2;
|
|
return $val1;
|
|
}
|
|
|
|
/**
|
|
* testXmlSetReverse method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testXmlSetReverse() {
|
|
App::uses('Xml', 'Utility');
|
|
|
|
$string = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
|
<rss version="2.0">
|
|
<channel>
|
|
<title>Cake PHP Google Group</title>
|
|
<link>http://groups.google.com/group/cake-php</link>
|
|
<description>Search this group before posting anything. There are over 20,000 posts and it&#39;s very likely your question was answered before. Visit the IRC channel #cakephp at irc.freenode.net for live chat with users and developers of Cake. If you post, tell us the version of Cake, PHP, and database.</description>
|
|
<language>en</language>
|
|
<item>
|
|
<title>constructng result array when using findall</title>
|
|
<link>http://groups.google.com/group/cake-php/msg/49bc00f3bc651b4f</link>
|
|
<description>i'm using cakephp to construct a logical data model array that will be <br> passed to a flex app. I have the following model association: <br> ServiceDay-&gt;(hasMany)ServiceTi me-&gt;(hasMany)ServiceTimePrice. So what <br> the current output from my findall is something like this example: <br> <p>Array( <br> [0] =&gt; Array(</description>
|
|
<guid isPermaLink="true">http://groups.google.com/group/cake-php/msg/49bc00f3bc651b4f</guid>
|
|
<author>bmil...@gmail.com(bpscrugs)</author>
|
|
<pubDate>Fri, 28 Dec 2007 00:44:14 UT</pubDate>
|
|
</item>
|
|
<item>
|
|
<title>Re: share views between actions?</title>
|
|
<link>http://groups.google.com/group/cake-php/msg/8b350d898707dad8</link>
|
|
<description>Then perhaps you might do us all a favour and refrain from replying to <br> things you do not understand. That goes especially for asinine comments. <br> Indeed. <br> To sum up: <br> No comment. <br> In my day, a simple &quot;RTFM&quot; would suffice. I'll keep in mind to ignore any <br> further responses from you. <br> You (and I) were referring to the *online documentation*, not other</description>
|
|
<guid isPermaLink="true">http://groups.google.com/group/cake-php/msg/8b350d898707dad8</guid>
|
|
<author>subtropolis.z...@gmail.com(subtropolis zijn)</author>
|
|
<pubDate>Fri, 28 Dec 2007 00:45:01 UT</pubDate>
|
|
</item>
|
|
</channel>
|
|
</rss>';
|
|
$xml = Xml::build($string);
|
|
$result = Set::reverse($xml);
|
|
$expected = array('rss' => array(
|
|
'@version' => '2.0',
|
|
'channel' => array(
|
|
'title' => 'Cake PHP Google Group',
|
|
'link' => 'http://groups.google.com/group/cake-php',
|
|
'description' => 'Search this group before posting anything. There are over 20,000 posts and it's very likely your question was answered before. Visit the IRC channel #cakephp at irc.freenode.net for live chat with users and developers of Cake. If you post, tell us the version of Cake, PHP, and database.',
|
|
'language' => 'en',
|
|
'item' => array(
|
|
array(
|
|
'title' => 'constructng result array when using findall',
|
|
'link' => 'http://groups.google.com/group/cake-php/msg/49bc00f3bc651b4f',
|
|
'description' => "i'm using cakephp to construct a logical data model array that will be <br> passed to a flex app. I have the following model association: <br> ServiceDay->(hasMany)ServiceTi me->(hasMany)ServiceTimePrice. So what <br> the current output from my findall is something like this example: <br> <p>Array( <br> [0] => Array(",
|
|
'guid' => array('@isPermaLink' => 'true', '@' => 'http://groups.google.com/group/cake-php/msg/49bc00f3bc651b4f'),
|
|
'author' => 'bmil...@gmail.com(bpscrugs)',
|
|
'pubDate' => 'Fri, 28 Dec 2007 00:44:14 UT',
|
|
),
|
|
array(
|
|
'title' => 'Re: share views between actions?',
|
|
'link' => 'http://groups.google.com/group/cake-php/msg/8b350d898707dad8',
|
|
'description' => 'Then perhaps you might do us all a favour and refrain from replying to <br> things you do not understand. That goes especially for asinine comments. <br> Indeed. <br> To sum up: <br> No comment. <br> In my day, a simple "RTFM" would suffice. I\'ll keep in mind to ignore any <br> further responses from you. <br> You (and I) were referring to the *online documentation*, not other',
|
|
'guid' => array('@isPermaLink' => 'true', '@' => 'http://groups.google.com/group/cake-php/msg/8b350d898707dad8'),
|
|
'author' => 'subtropolis.z...@gmail.com(subtropolis zijn)',
|
|
'pubDate' => 'Fri, 28 Dec 2007 00:45:01 UT'
|
|
)
|
|
)
|
|
)
|
|
));
|
|
$this->assertEquals($expected, $result);
|
|
$string = '<data><post title="Title of this post" description="cool"/></data>';
|
|
|
|
$xml = Xml::build($string);
|
|
$result = Set::reverse($xml);
|
|
$expected = array('data' => array('post' => array('@title' => 'Title of this post', '@description' => 'cool')));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$xml = Xml::build('<example><item><title>An example of a correctly reversed SimpleXMLElement</title><desc/></item></example>');
|
|
$result = Set::reverse($xml);
|
|
$expected = array('example' =>
|
|
array(
|
|
'item' => array(
|
|
'title' => 'An example of a correctly reversed SimpleXMLElement',
|
|
'desc' => '',
|
|
)
|
|
)
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$xml = Xml::build('<example><item attr="123"><titles><title>title1</title><title>title2</title></titles></item></example>');
|
|
$result = Set::reverse($xml);
|
|
$expected =
|
|
array('example' => array(
|
|
'item' => array(
|
|
'@attr' => '123',
|
|
'titles' => array(
|
|
'title' => array('title1', 'title2')
|
|
)
|
|
)
|
|
)
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$xml = Xml::build('<example attr="ex_attr"><item attr="123"><titles>list</titles>textforitems</item></example>');
|
|
$result = Set::reverse($xml);
|
|
$expected =
|
|
array('example' => array(
|
|
'@attr' => 'ex_attr',
|
|
'item' => array(
|
|
'@attr' => '123',
|
|
'titles' => 'list',
|
|
'@' => 'textforitems'
|
|
)
|
|
)
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$string = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
|
<rss version="2.0" xmlns:dc="http://www.cakephp.org/">
|
|
<channel>
|
|
<title>Cake PHP Google Group</title>
|
|
<link>http://groups.google.com/group/cake-php</link>
|
|
<description>Search this group before posting anything. There are over 20,000 posts and it&#39;s very likely your question was answered before. Visit the IRC channel #cakephp at irc.freenode.net for live chat with users and developers of Cake. If you post, tell us the version of Cake, PHP, and database.</description>
|
|
<language>en</language>
|
|
<item>
|
|
<title>constructng result array when using findall</title>
|
|
<link>http://groups.google.com/group/cake-php/msg/49bc00f3bc651b4f</link>
|
|
<description>i'm using cakephp to construct a logical data model array that will be <br> passed to a flex app. I have the following model association: <br> ServiceDay-&gt;(hasMany)ServiceTi me-&gt;(hasMany)ServiceTimePrice. So what <br> the current output from my findall is something like this example: <br> <p>Array( <br> [0] =&gt; Array(</description>
|
|
<dc:creator>cakephp</dc:creator>
|
|
<category><![CDATA[cakephp]]></category>
|
|
<category><![CDATA[model]]></category>
|
|
<guid isPermaLink="true">http://groups.google.com/group/cake-php/msg/49bc00f3bc651b4f</guid>
|
|
<author>bmil...@gmail.com(bpscrugs)</author>
|
|
<pubDate>Fri, 28 Dec 2007 00:44:14 UT</pubDate>
|
|
</item>
|
|
<item>
|
|
<title>Re: share views between actions?</title>
|
|
<link>http://groups.google.com/group/cake-php/msg/8b350d898707dad8</link>
|
|
<description>Then perhaps you might do us all a favour and refrain from replying to <br> things you do not understand. That goes especially for asinine comments. <br> Indeed. <br> To sum up: <br> No comment. <br> In my day, a simple &quot;RTFM&quot; would suffice. I'll keep in mind to ignore any <br> further responses from you. <br> You (and I) were referring to the *online documentation*, not other</description>
|
|
<dc:creator>cakephp</dc:creator>
|
|
<category><![CDATA[cakephp]]></category>
|
|
<category><![CDATA[model]]></category>
|
|
<guid isPermaLink="true">http://groups.google.com/group/cake-php/msg/8b350d898707dad8</guid>
|
|
<author>subtropolis.z...@gmail.com(subtropolis zijn)</author>
|
|
<pubDate>Fri, 28 Dec 2007 00:45:01 UT</pubDate>
|
|
</item>
|
|
</channel>
|
|
</rss>';
|
|
|
|
$xml = Xml::build($string);
|
|
$result = Set::reverse($xml);
|
|
|
|
$expected = array('rss' => array(
|
|
'@version' => '2.0',
|
|
'channel' => array(
|
|
'title' => 'Cake PHP Google Group',
|
|
'link' => 'http://groups.google.com/group/cake-php',
|
|
'description' => 'Search this group before posting anything. There are over 20,000 posts and it's very likely your question was answered before. Visit the IRC channel #cakephp at irc.freenode.net for live chat with users and developers of Cake. If you post, tell us the version of Cake, PHP, and database.',
|
|
'language' => 'en',
|
|
'item' => array(
|
|
array(
|
|
'title' => 'constructng result array when using findall',
|
|
'link' => 'http://groups.google.com/group/cake-php/msg/49bc00f3bc651b4f',
|
|
'description' => "i'm using cakephp to construct a logical data model array that will be <br> passed to a flex app. I have the following model association: <br> ServiceDay->(hasMany)ServiceTi me->(hasMany)ServiceTimePrice. So what <br> the current output from my findall is something like this example: <br> <p>Array( <br> [0] => Array(",
|
|
'dc:creator' => 'cakephp',
|
|
'category' => array('cakephp', 'model'),
|
|
'guid' => array('@isPermaLink' => 'true', '@' => 'http://groups.google.com/group/cake-php/msg/49bc00f3bc651b4f'),
|
|
'author' => 'bmil...@gmail.com(bpscrugs)',
|
|
'pubDate' => 'Fri, 28 Dec 2007 00:44:14 UT',
|
|
),
|
|
array(
|
|
'title' => 'Re: share views between actions?',
|
|
'link' => 'http://groups.google.com/group/cake-php/msg/8b350d898707dad8',
|
|
'description' => 'Then perhaps you might do us all a favour and refrain from replying to <br> things you do not understand. That goes especially for asinine comments. <br> Indeed. <br> To sum up: <br> No comment. <br> In my day, a simple "RTFM" would suffice. I\'ll keep in mind to ignore any <br> further responses from you. <br> You (and I) were referring to the *online documentation*, not other',
|
|
'dc:creator' => 'cakephp',
|
|
'category' => array('cakephp', 'model'),
|
|
'guid' => array('@isPermaLink' => 'true', '@' => 'http://groups.google.com/group/cake-php/msg/8b350d898707dad8'),
|
|
'author' => 'subtropolis.z...@gmail.com(subtropolis zijn)',
|
|
'pubDate' => 'Fri, 28 Dec 2007 00:45:01 UT'
|
|
)
|
|
)
|
|
)
|
|
));
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$text = '<?xml version="1.0" encoding="UTF-8"?>
|
|
<XRDS xmlns="xri://$xrds">
|
|
<XRD xml:id="oauth" xmlns="xri://$XRD*($v*2.0)" version="2.0">
|
|
<Type>xri://$xrds*simple</Type>
|
|
<Expires>2008-04-13T07:34:58Z</Expires>
|
|
<Service>
|
|
<Type>http://oauth.net/core/1.0/endpoint/authorize</Type>
|
|
<Type>http://oauth.net/core/1.0/parameters/auth-header</Type>
|
|
<Type>http://oauth.net/core/1.0/parameters/uri-query</Type>
|
|
<URI priority="10">https://ma.gnolia.com/oauth/authorize</URI>
|
|
<URI priority="20">http://ma.gnolia.com/oauth/authorize</URI>
|
|
</Service>
|
|
</XRD>
|
|
<XRD xmlns="xri://$XRD*($v*2.0)" version="2.0">
|
|
<Type>xri://$xrds*simple</Type>
|
|
<Service priority="10">
|
|
<Type>http://oauth.net/discovery/1.0</Type>
|
|
<URI>#oauth</URI>
|
|
</Service>
|
|
</XRD>
|
|
</XRDS>';
|
|
|
|
$xml = Xml::build($text);
|
|
$result = Set::reverse($xml);
|
|
|
|
$expected = array('XRDS' => array(
|
|
'XRD' => array(
|
|
array(
|
|
'@xml:id' => 'oauth',
|
|
'@version' => '2.0',
|
|
'Type' => 'xri://$xrds*simple',
|
|
'Expires' => '2008-04-13T07:34:58Z',
|
|
'Service' => array(
|
|
'Type' => array(
|
|
'http://oauth.net/core/1.0/endpoint/authorize',
|
|
'http://oauth.net/core/1.0/parameters/auth-header',
|
|
'http://oauth.net/core/1.0/parameters/uri-query'
|
|
),
|
|
'URI' => array(
|
|
array(
|
|
'@' => 'https://ma.gnolia.com/oauth/authorize',
|
|
'@priority' => '10',
|
|
),
|
|
array(
|
|
'@' => 'http://ma.gnolia.com/oauth/authorize',
|
|
'@priority' => '20'
|
|
)
|
|
)
|
|
)
|
|
),
|
|
array(
|
|
'@version' => '2.0',
|
|
'Type' => 'xri://$xrds*simple',
|
|
'Service' => array(
|
|
'@priority' => '10',
|
|
'Type' => 'http://oauth.net/discovery/1.0',
|
|
'URI' => '#oauth'
|
|
)
|
|
)
|
|
)
|
|
));
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* testStrictKeyCheck method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testStrictKeyCheck() {
|
|
$set = array('a' => 'hi');
|
|
$this->assertFalse(Set::check($set, 'a.b'));
|
|
}
|
|
|
|
/**
|
|
* Tests Set::flatten
|
|
*
|
|
* @see Hash test cases, as Set::flatten() is just a proxy.
|
|
* @return void
|
|
*/
|
|
public function testFlatten() {
|
|
$data = array('Larry', 'Curly', 'Moe');
|
|
$result = Set::flatten($data);
|
|
$this->assertEquals($data, $result);
|
|
|
|
$data[9] = 'Shemp';
|
|
$result = Set::flatten($data);
|
|
$this->assertEquals($data, $result);
|
|
|
|
$data = array(
|
|
array(
|
|
'Post' => array('id' => '1', 'author_id' => null, 'title' => 'First Post'),
|
|
'Author' => array(),
|
|
)
|
|
);
|
|
$result = Set::flatten($data);
|
|
$expected = array(
|
|
'0.Post.id' => '1',
|
|
'0.Post.author_id' => null,
|
|
'0.Post.title' => 'First Post',
|
|
'0.Author' => array()
|
|
);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* Tests Set::expand
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testExpand() {
|
|
$data = array('My', 'Array', 'To', 'Flatten');
|
|
$flat = Set::flatten($data);
|
|
$result = Set::expand($flat);
|
|
$this->assertEquals($data, $result);
|
|
}
|
|
|
|
/**
|
|
* test normalization
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testNormalizeStrings() {
|
|
$result = Set::normalize('one,two,three');
|
|
$expected = array('one' => null, 'two' => null, 'three' => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::normalize('one two three', true, ' ');
|
|
$expected = array('one' => null, 'two' => null, 'three' => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::normalize('one , two , three ', true, ',', true);
|
|
$expected = array('one' => null, 'two' => null, 'three' => null);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* test normalizing arrays
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testNormalizeArrays() {
|
|
$result = Set::normalize(array('one', 'two', 'three'));
|
|
$expected = array('one' => null, 'two' => null, 'three' => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::normalize(array('one', 'two', 'three'), false);
|
|
$expected = array('one', 'two', 'three');
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::normalize(array('one' => 1, 'two' => 2, 'three' => 3, 'four'), false);
|
|
$expected = array('one' => 1, 'two' => 2, 'three' => 3, 'four' => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::normalize(array('one' => 1, 'two' => 2, 'three' => 3, 'four'));
|
|
$expected = array('one' => 1, 'two' => 2, 'three' => 3, 'four' => null);
|
|
$this->assertEquals($expected, $result);
|
|
|
|
$result = Set::normalize(array('one' => array('a', 'b', 'c' => 'cee'), 'two' => 2, 'three'));
|
|
$expected = array('one' => array('a', 'b', 'c' => 'cee'), 'two' => 2, 'three' => null);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* test Set nest with a normal model result set. For kicks rely on Set nest detecting the key names
|
|
* automatically
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testNestModel() {
|
|
$input = array(
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 1,
|
|
'parent_id' => null
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 2,
|
|
'parent_id' => 1
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 3,
|
|
'parent_id' => 1
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 4,
|
|
'parent_id' => 1
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 5,
|
|
'parent_id' => 1
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 6,
|
|
'parent_id' => null
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 7,
|
|
'parent_id' => 6
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 8,
|
|
'parent_id' => 6
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 9,
|
|
'parent_id' => 6
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 10,
|
|
'parent_id' => 6
|
|
)
|
|
)
|
|
);
|
|
$expected = array(
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 1,
|
|
'parent_id' => null
|
|
),
|
|
'children' => array(
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 2,
|
|
'parent_id' => 1
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 3,
|
|
'parent_id' => 1
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 4,
|
|
'parent_id' => 1
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 5,
|
|
'parent_id' => 1
|
|
),
|
|
'children' => array()
|
|
),
|
|
|
|
)
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 6,
|
|
'parent_id' => null
|
|
),
|
|
'children' => array(
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 7,
|
|
'parent_id' => 6
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 8,
|
|
'parent_id' => 6
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 9,
|
|
'parent_id' => 6
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 10,
|
|
'parent_id' => 6
|
|
),
|
|
'children' => array()
|
|
)
|
|
)
|
|
)
|
|
);
|
|
$result = Set::nest($input);
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* test Set nest with a normal model result set, and a nominated root id
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testNestModelExplicitRoot() {
|
|
$input = array(
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 1,
|
|
'parent_id' => null
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 2,
|
|
'parent_id' => 1
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 3,
|
|
'parent_id' => 1
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 4,
|
|
'parent_id' => 1
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 5,
|
|
'parent_id' => 1
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 6,
|
|
'parent_id' => null
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 7,
|
|
'parent_id' => 6
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 8,
|
|
'parent_id' => 6
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 9,
|
|
'parent_id' => 6
|
|
),
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 10,
|
|
'parent_id' => 6
|
|
)
|
|
)
|
|
);
|
|
$expected = array(
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 6,
|
|
'parent_id' => null
|
|
),
|
|
'children' => array(
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 7,
|
|
'parent_id' => 6
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 8,
|
|
'parent_id' => 6
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 9,
|
|
'parent_id' => 6
|
|
),
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'ModelName' => array(
|
|
'id' => 10,
|
|
'parent_id' => 6
|
|
),
|
|
'children' => array()
|
|
)
|
|
)
|
|
)
|
|
);
|
|
$result = Set::nest($input, array('root' => 6));
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* test Set nest with a 1d array - this method should be able to handle any type of array input
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testNest1Dimensional() {
|
|
$input = array(
|
|
array(
|
|
'id' => 1,
|
|
'parent_id' => null
|
|
),
|
|
array(
|
|
'id' => 2,
|
|
'parent_id' => 1
|
|
),
|
|
array(
|
|
'id' => 3,
|
|
'parent_id' => 1
|
|
),
|
|
array(
|
|
'id' => 4,
|
|
'parent_id' => 1
|
|
),
|
|
array(
|
|
'id' => 5,
|
|
'parent_id' => 1
|
|
),
|
|
array(
|
|
'id' => 6,
|
|
'parent_id' => null
|
|
),
|
|
array(
|
|
'id' => 7,
|
|
'parent_id' => 6
|
|
),
|
|
array(
|
|
'id' => 8,
|
|
'parent_id' => 6
|
|
),
|
|
array(
|
|
'id' => 9,
|
|
'parent_id' => 6
|
|
),
|
|
array(
|
|
'id' => 10,
|
|
'parent_id' => 6
|
|
)
|
|
);
|
|
$expected = array(
|
|
array(
|
|
'id' => 1,
|
|
'parent_id' => null,
|
|
'children' => array(
|
|
array(
|
|
'id' => 2,
|
|
'parent_id' => 1,
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'id' => 3,
|
|
'parent_id' => 1,
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'id' => 4,
|
|
'parent_id' => 1,
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'id' => 5,
|
|
'parent_id' => 1,
|
|
'children' => array()
|
|
),
|
|
|
|
)
|
|
),
|
|
array(
|
|
'id' => 6,
|
|
'parent_id' => null,
|
|
'children' => array(
|
|
array(
|
|
'id' => 7,
|
|
'parent_id' => 6,
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'id' => 8,
|
|
'parent_id' => 6,
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'id' => 9,
|
|
'parent_id' => 6,
|
|
'children' => array()
|
|
),
|
|
array(
|
|
'id' => 10,
|
|
'parent_id' => 6,
|
|
'children' => array()
|
|
)
|
|
)
|
|
)
|
|
);
|
|
$result = Set::nest($input, array('idPath' => '/id', 'parentPath' => '/parent_id'));
|
|
$this->assertEquals($expected, $result);
|
|
}
|
|
|
|
/**
|
|
* test Set nest with no specified parent data.
|
|
*
|
|
* The result should be the same as the input.
|
|
* For an easier comparison, unset all the empty children arrays from the result
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testMissingParent() {
|
|
$input = array(
|
|
array(
|
|
'id' => 1,
|
|
),
|
|
array(
|
|
'id' => 2,
|
|
),
|
|
array(
|
|
'id' => 3,
|
|
),
|
|
array(
|
|
'id' => 4,
|
|
),
|
|
array(
|
|
'id' => 5,
|
|
),
|
|
array(
|
|
'id' => 6,
|
|
),
|
|
array(
|
|
'id' => 7,
|
|
),
|
|
array(
|
|
'id' => 8,
|
|
),
|
|
array(
|
|
'id' => 9,
|
|
),
|
|
array(
|
|
'id' => 10,
|
|
)
|
|
);
|
|
|
|
$result = Set::nest($input, array('idPath' => '/id', 'parentPath' => '/parent_id'));
|
|
foreach ($result as &$row) {
|
|
if (empty($row['children'])) {
|
|
unset($row['children']);
|
|
}
|
|
}
|
|
$this->assertEquals($input, $result);
|
|
}
|
|
}
|