2014-04-23 10:51:50 +08:00
< ? php
/**
* SetTest file
*
2018-03-18 09:24:15 +08:00
* CakePHP ( tm ) Tests < https :// book . cakephp . org / 2.0 / en / development / testing . html >
* Copyright ( c ) Cake Software Foundation , Inc . ( https :// cakefoundation . org )
2014-04-23 10:51:50 +08:00
*
* 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
*
2018-03-18 09:24:15 +08:00
* @ copyright Copyright ( c ) Cake Software Foundation , Inc . ( https :// cakefoundation . org )
* @ link https :// book . cakephp . org / 2.0 / en / development / testing . html CakePHP ( tm ) Tests
2014-04-23 10:51:50 +08:00
* @ package Cake . Test . Case . Utility
* @ since CakePHP ( tm ) v 1.2 . 0.4206
2018-03-18 09:24:15 +08:00
* @ license https :// opensource . org / licenses / mit - license . php MIT License
2014-04-23 10:51:50 +08:00
*/
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 32 bit 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 & amp ; #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 / 49 bc00f3bc651b4f </ link >
< description > i & #39;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 / 49 bc00f3bc651b4f </ 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 / 8 b350d898707dad8 </ link >
< description > Then perhaps you might do us all a favour and refrain from replying to & lt ; br & gt ; things you do not understand . That goes especially for asinine comments . & lt ; br & gt ; Indeed . & lt ; br & gt ; To sum up : & lt ; br & gt ; No comment . & lt ; br & gt ; In my day , a simple & amp ; quot ; RTFM & amp ; quot ; would suffice . I & #39;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 / 8 b350d898707dad8 </ 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 & amp ; #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 / 49 bc00f3bc651b4f </ link >
< description > i & #39;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 / 49 bc00f3bc651b4f </ 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 / 8 b350d898707dad8 </ link >
< description > Then perhaps you might do us all a favour and refrain from replying to & lt ; br & gt ; things you do not understand . That goes especially for asinine comments . & lt ; br & gt ; Indeed . & lt ; br & gt ; To sum up : & lt ; br & gt ; No comment . & lt ; br & gt ; In my day , a simple & amp ; quot ; RTFM & amp ; quot ; would suffice . I & #39;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 / 8 b350d898707dad8 </ 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 - 13 T07 : 34 : 58 Z </ 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 1 d 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 );
}
}