cakephp2-php8/lib/Cake/Test/Case/Utility/HashTest.php

2166 lines
51 KiB
PHP
Raw Normal View History

2012-01-12 02:33:14 +00:00
<?php
2012-02-28 21:52:54 +00:00
/**
* CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
* Copyright 2005-2011, Cake Software Foundation, Inc. (http://cakefoundation.org)
*
* Licensed under The MIT License
* Redistributions of files must retain the above copyright notice.
*
* @copyright Copyright 2005-2011, Cake Software Foundation, Inc. (http://cakefoundation.org)
* @link http://cakephp.org CakePHP(tm) Project
* @package Cake.Utility
* @since CakePHP(tm) v 2.2.0
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
*/
App::uses('Hash', 'Utility');
2012-01-12 02:33:14 +00:00
2012-02-28 21:52:54 +00:00
class HashTest extends CakeTestCase {
2012-01-12 02:33:14 +00:00
public static function articleData() {
2012-03-27 02:57:50 +00:00
return array(
2012-01-12 02:33:14 +00:00
array(
'Article' => array(
'id' => '1',
'user_id' => '1',
'title' => 'First Article',
'body' => 'First Article Body'
),
'User' => array(
'id' => '1',
'user' => 'mariano',
'password' => '5f4dcc3b5aa765d61d8327deb882cf99',
),
'Comment' => array(
array(
'id' => '1',
'article_id' => '1',
'user_id' => '2',
'comment' => 'First Comment for First Article',
),
array(
'id' => '2',
'article_id' => '1',
'user_id' => '4',
'comment' => 'Second Comment for First Article',
),
),
'Tag' => array(
array(
'id' => '1',
'tag' => 'tag1',
),
array(
'id' => '2',
'tag' => 'tag2',
)
),
'Deep' => array(
'Nesting' => array(
'test' => array(
1 => 'foo',
2 => array(
'and' => array('more' => 'stuff')
)
)
)
)
),
array(
'Article' => array(
'id' => '2',
2012-01-12 02:33:14 +00:00
'user_id' => '1',
'title' => 'Second Article',
'body' => 'Second Article Body',
'published' => 'Y',
),
'User' => array(
'id' => '2',
'user' => 'mariano',
'password' => '5f4dcc3b5aa765d61d8327deb882cf99',
),
'Comment' => array(),
'Tag' => array()
),
array(
'Article' => array(
'id' => '3',
'user_id' => '1',
'title' => 'Third Article',
'body' => 'Third Article Body',
),
'User' => array(
'id' => '3',
'user' => 'mariano',
'password' => '5f4dcc3b5aa765d61d8327deb882cf99',
),
'Comment' => array(),
'Tag' => array()
),
array(
'Article' => array(
'id' => '4',
'user_id' => '1',
'title' => 'Fourth Article',
'body' => 'Fourth Article Body',
),
'User' => array(
'id' => '4',
'user' => 'mariano',
'password' => '5f4dcc3b5aa765d61d8327deb882cf99',
),
'Comment' => array(),
'Tag' => array()
),
array(
'Article' => array(
'id' => '5',
'user_id' => '1',
'title' => 'Fifth Article',
'body' => 'Fifth Article Body',
),
'User' => array(
'id' => '5',
'user' => 'mariano',
'password' => '5f4dcc3b5aa765d61d8327deb882cf99',
),
'Comment' => array(),
'Tag' => array()
)
);
}
2012-02-20 04:34:51 +00:00
public static function userData() {
return 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'
)
)
)
);
}
2012-01-12 02:33:14 +00:00
/**
* Test get()
*
* return void
*/
public function testGet() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::get(array(), '1.Article.title');
2012-01-12 02:33:14 +00:00
$this->assertNull($result);
2012-02-28 21:52:54 +00:00
$result = Hash::get($data, '');
2012-01-12 02:33:14 +00:00
$this->assertNull($result);
2012-02-28 21:52:54 +00:00
$result = Hash::get($data, '0.Article.title');
$this->assertEquals('First Article', $result);
2012-02-28 21:52:54 +00:00
$result = Hash::get($data, '1.Article.title');
2012-01-12 02:33:14 +00:00
$this->assertEquals('Second Article', $result);
2012-02-28 21:52:54 +00:00
$result = Hash::get($data, '5.Article.title');
2012-01-12 02:33:14 +00:00
$this->assertNull($result);
2012-02-28 21:52:54 +00:00
$result = Hash::get($data, '1.Article.title.not_there');
2012-01-12 02:33:14 +00:00
$this->assertNull($result);
2012-02-28 21:52:54 +00:00
$result = Hash::get($data, '1.Article');
2012-01-12 02:33:14 +00:00
$this->assertEquals($data[1]['Article'], $result);
2012-02-28 21:52:54 +00:00
$result = Hash::get($data, array('1', 'Article'));
$this->assertEquals($data[1]['Article'], $result);
2012-01-12 02:33:14 +00:00
}
/**
* Test dimensions.
*
* @return void
*/
public function testDimensions() {
2012-02-28 21:52:54 +00:00
$result = Hash::dimensions(array());
$this->assertEquals($result, 0);
$data = array('one', '2', 'three');
2012-02-28 21:52:54 +00:00
$result = Hash::dimensions($data);
$this->assertEquals($result, 1);
$data = array('1' => '1.1', '2', '3');
2012-02-28 21:52:54 +00:00
$result = Hash::dimensions($data);
$this->assertEquals($result, 1);
$data = array('1' => array('1.1' => '1.1.1'), '2', '3' => array('3.1' => '3.1.1'));
2012-02-28 21:52:54 +00:00
$result = Hash::dimensions($data);
$this->assertEquals($result, 2);
$data = array('1' => '1.1', '2', '3' => array('3.1' => '3.1.1'));
2012-02-28 21:52:54 +00:00
$result = Hash::dimensions($data);
$this->assertEquals($result, 1);
$data = array('1' => array('1.1' => '1.1.1'), '2', '3' => array('3.1' => array('3.1.1' => '3.1.1.1')));
2012-02-28 21:52:54 +00:00
$result = Hash::dimensions($data);
$this->assertEquals($result, 2);
}
/**
* Test maxDimensions
*
* @return void
*/
public function testMaxDimensions() {
$data = array('1' => '1.1', '2', '3' => array('3.1' => '3.1.1'));
2012-02-28 21:52:54 +00:00
$result = Hash::maxDimensions($data);
$this->assertEquals($result, 2);
$data = array('1' => array('1.1' => '1.1.1'), '2', '3' => array('3.1' => array('3.1.1' => '3.1.1.1')));
2012-02-28 21:52:54 +00:00
$result = Hash::maxDimensions($data);
$this->assertEquals($result, 3);
$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'))
);
2012-02-28 21:52:54 +00:00
$result = Hash::maxDimensions($data);
$this->assertEquals($result, 4);
$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'))
);
2012-02-28 21:52:54 +00:00
$result = Hash::maxDimensions($data);
$this->assertEquals($result, 5);
$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'))
);
2012-02-28 21:52:54 +00:00
$result = Hash::maxDimensions($data);
$this->assertEquals($result, 5);
$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'))
);
2012-02-28 21:52:54 +00:00
$result = Hash::maxDimensions($data);
$this->assertEquals($result, 5);
}
/**
2012-03-01 18:44:33 +00:00
* Tests Hash::flatten
*
* @return void
*/
public function testFlatten() {
$data = array('Larry', 'Curly', 'Moe');
2012-02-28 21:52:54 +00:00
$result = Hash::flatten($data);
$this->assertEquals($result, $data);
$data[9] = 'Shemp';
2012-02-28 21:52:54 +00:00
$result = Hash::flatten($data);
$this->assertEquals($result, $data);
$data = array(
array(
'Post' => array('id' => '1', 'author_id' => '1', 'title' => 'First Post'),
'Author' => array('id' => '1', 'user' => 'nate', 'password' => 'foo'),
),
array(
'Post' => array('id' => '2', 'author_id' => '3', 'title' => 'Second Post', 'body' => 'Second Post Body'),
'Author' => array('id' => '3', 'user' => 'larry', 'password' => null),
)
);
2012-02-28 21:52:54 +00:00
$result = Hash::flatten($data);
$expected = array(
'0.Post.id' => '1',
'0.Post.author_id' => '1',
'0.Post.title' => 'First Post',
'0.Author.id' => '1',
'0.Author.user' => 'nate',
'0.Author.password' => 'foo',
'1.Post.id' => '2',
'1.Post.author_id' => '3',
'1.Post.title' => 'Second Post',
'1.Post.body' => 'Second Post Body',
'1.Author.id' => '3',
'1.Author.user' => 'larry',
'1.Author.password' => null
);
$this->assertEquals($expected, $result);
$data = array(
array(
'Post' => array('id' => '1', 'author_id' => null, 'title' => 'First Post'),
'Author' => array(),
)
);
$result = Hash::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);
$data = array(
array('Post' => array('id' => 1)),
array('Post' => array('id' => 2)),
);
2012-02-28 21:52:54 +00:00
$result = Hash::flatten($data, '/');
$expected = array(
'0/Post/id' => '1',
'1/Post/id' => '2',
);
$this->assertEquals($expected, $result);
}
2012-01-16 02:38:13 +00:00
/**
* Test diff();
*
* @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')
);
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, array());
2012-01-16 02:38:13 +00:00
$expected = $a;
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::diff(array(), $b);
2012-01-16 02:38:13 +00:00
$expected = $b;
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, $b);
2012-01-16 02:38:13 +00:00
$expected = array(
2 => array('name' => 'contact')
);
$this->assertEquals($expected, $result);
$b = array(
0 => array('name' => 'me'),
1 => array('name' => 'about')
);
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, $b);
2012-01-16 02:38:13 +00:00
$expected = array(
0 => array('name' => 'main')
);
$this->assertEquals($expected, $result);
$a = array();
$b = array('name' => 'bob', 'address' => 'home');
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, $b);
2012-01-16 02:38:13 +00:00
$this->assertEquals($result, $b);
$a = array('name' => 'bob', 'address' => 'home');
$b = array();
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, $b);
2012-01-16 02:38:13 +00:00
$this->assertEquals($result, $a);
$a = array('key' => true, 'another' => false, 'name' => 'me');
$b = array('key' => 1, 'another' => 0);
$expected = array('name' => 'me');
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, $b);
2012-01-16 02:38:13 +00:00
$this->assertEquals($expected, $result);
$a = array('key' => 'value', 'another' => null, 'name' => 'me');
$b = array('key' => 'differentValue', 'another' => null);
$expected = array('key' => 'value', 'name' => 'me');
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, $b);
2012-01-16 02:38:13 +00:00
$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');
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, $b);
2012-01-16 02:38:13 +00:00
$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');
2012-02-28 21:52:54 +00:00
$result = Hash::diff($b, $a);
2012-01-16 02:38:13 +00:00
$this->assertEquals($expected, $result);
$a = array('key' => 'value', 'another' => null, 'name' => 'me');
$b = array(0 => 'differentValue', 1 => 'value');
$expected = $a + $b;
2012-02-28 21:52:54 +00:00
$result = Hash::diff($a, $b);
2012-01-16 02:38:13 +00:00
$this->assertEquals($expected, $result);
}
/**
* Test merge()
*
* @return void
*/
public function testMerge() {
2012-02-28 21:52:54 +00:00
$result = Hash::merge(array('foo'), array('bar'));
2012-01-16 02:38:13 +00:00
$this->assertEquals($result, array('foo', 'bar'));
2012-02-28 21:52:54 +00:00
$result = Hash::merge(array('foo'), array('user' => 'bob', 'no-bar'), 'bar');
2012-01-16 02:38:13 +00:00
$this->assertEquals($result, array('foo', 'user' => 'bob', 'no-bar', 'bar'));
$a = array('foo', 'foo2');
$b = array('bar', 'bar2');
$expected = array('foo', 'foo2', 'bar', 'bar2');
2012-02-28 21:52:54 +00:00
$this->assertEquals($expected, Hash::merge($a, $b));
2012-01-16 02:38:13 +00:00
$a = array('foo' => 'bar', 'bar' => 'foo');
$b = array('foo' => 'no-bar', 'bar' => 'no-foo');
$expected = array('foo' => 'no-bar', 'bar' => 'no-foo');
2012-02-28 21:52:54 +00:00
$this->assertEquals($expected, Hash::merge($a, $b));
2012-01-16 02:38:13 +00:00
$a = array('users' => array('bob', 'jim'));
$b = array('users' => array('lisa', 'tina'));
$expected = array('users' => array('bob', 'jim', 'lisa', 'tina'));
2012-02-28 21:52:54 +00:00
$this->assertEquals($expected, Hash::merge($a, $b));
2012-01-16 02:38:13 +00:00
$a = array('users' => array('jim', 'bob'));
$b = array('users' => 'none');
$expected = array('users' => 'none');
2012-02-28 21:52:54 +00:00
$this->assertEquals($expected, Hash::merge($a, $b));
2012-01-16 02:38:13 +00:00
$a = array('users' => array('lisa' => array('id' => 5, 'pw' => 'secret')), 'cakephp');
$b = array('users' => array('lisa' => array('pw' => 'new-pass', 'age' => 23)), 'ice-cream');
$expected = array(
'users' => array('lisa' => array('id' => 5, 'pw' => 'new-pass', 'age' => 23)),
'cakephp',
'ice-cream'
);
2012-03-27 02:57:50 +00:00
$result = Hash::merge($a, $b);
2012-01-16 02:38:13 +00:00
$this->assertEquals($expected, $result);
$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'
);
2012-02-28 21:52:54 +00:00
$this->assertEquals($expected, Hash::merge($a, $b, $c));
2012-01-16 02:38:13 +00:00
2012-02-28 21:52:54 +00:00
$this->assertEquals($expected, Hash::merge($a, $b, array(), $c));
2012-01-16 02:38:13 +00:00
$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')
)
);
2012-03-27 02:57:50 +00:00
$b = array(
2012-01-16 02:38:13 +00:00
'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'
);
2012-02-28 21:52:54 +00:00
$this->assertEquals(Hash::merge($a, $b), $expected);
2012-01-16 02:38:13 +00:00
}
/**
* test normalizing arrays
*
* @return void
*/
public function testNormalize() {
2012-02-28 21:52:54 +00:00
$result = Hash::normalize(array('one', 'two', 'three'));
$expected = array('one' => null, 'two' => null, 'three' => null);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::normalize(array('one', 'two', 'three'), false);
$expected = array('one', 'two', 'three');
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::normalize(array('one' => 1, 'two' => 2, 'three' => 3, 'four'), false);
$expected = array('one' => 1, 'two' => 2, 'three' => 3, 'four' => null);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::normalize(array('one' => 1, 'two' => 2, 'three' => 3, 'four'));
$expected = array('one' => 1, 'two' => 2, 'three' => 3, 'four' => null);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::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);
}
/**
* testContains method
*
* @return void
*/
public function testContains() {
$data = array('apple', 'bee', 'cyclops');
2012-02-28 21:52:54 +00:00
$this->assertTrue(Hash::contains($data, array('apple')));
$this->assertFalse(Hash::contains($data, array('data')));
$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'
);
2012-02-28 21:52:54 +00:00
$this->assertTrue(Hash::contains($a, $a));
$this->assertFalse(Hash::contains($a, $b));
$this->assertTrue(Hash::contains($b, $a));
$a = array(
array('User' => array('id' => 1)),
array('User' => array('id' => 2)),
);
$b = array(
array('User' => array('id' => 1)),
array('User' => array('id' => 2)),
array('User' => array('id' => 3))
);
2012-02-28 21:52:54 +00:00
$this->assertTrue(Hash::contains($b, $a));
$this->assertFalse(Hash::contains($a, $b));
}
2012-01-22 03:03:25 +00:00
/**
* testFilter method
*
* @return void
*/
public function testFilter() {
2012-02-28 21:52:54 +00:00
$result = Hash::filter(array('0', false, true, 0, array('one thing', 'I can tell you', 'is you got to be', false)));
2012-01-22 03:03:25 +00:00
$expected = array('0', 2 => true, 3 => 0, 4 => array('one thing', 'I can tell you', 'is you got to be'));
$this->assertSame($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::filter(array(1, array(false)));
2012-01-22 03:03:25 +00:00
$expected = array(1);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::filter(array(1, array(false, false)));
2012-01-22 03:03:25 +00:00
$expected = array(1);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::filter(array(1, array('empty', false)));
2012-01-22 03:03:25 +00:00
$expected = array(1, array('empty'));
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::filter(array(1, array('2', false, array(3, null))));
2012-01-22 03:03:25 +00:00
$expected = array(1, array('2', 2 => array(3)));
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$this->assertSame(array(), Hash::filter(array()));
2012-01-22 03:03:25 +00:00
}
2012-01-22 03:11:22 +00:00
/**
* testNumericArrayCheck method
*
* @return void
*/
public function testNumeric() {
$data = array('one');
2012-03-01 18:44:33 +00:00
$this->assertTrue(Hash::numeric(array_keys($data)));
2012-01-22 03:11:22 +00:00
$data = array(1 => 'one');
2012-03-01 18:44:33 +00:00
$this->assertFalse(Hash::numeric($data));
2012-01-22 03:11:22 +00:00
$data = array('one');
2012-03-01 18:44:33 +00:00
$this->assertFalse(Hash::numeric($data));
2012-01-22 03:11:22 +00:00
$data = array('one' => 'two');
2012-03-01 18:44:33 +00:00
$this->assertFalse(Hash::numeric($data));
2012-01-22 03:11:22 +00:00
$data = array('one' => 1);
2012-03-01 18:44:33 +00:00
$this->assertTrue(Hash::numeric($data));
2012-01-22 03:11:22 +00:00
$data = array(0);
2012-03-01 18:44:33 +00:00
$this->assertTrue(Hash::numeric($data));
2012-01-22 03:11:22 +00:00
$data = array('one', 'two', 'three', 'four', 'five');
2012-03-01 18:44:33 +00:00
$this->assertTrue(Hash::numeric(array_keys($data)));
2012-01-22 03:11:22 +00:00
$data = array(1 => 'one', 2 => 'two', 3 => 'three', 4 => 'four', 5 => 'five');
2012-03-01 18:44:33 +00:00
$this->assertTrue(Hash::numeric(array_keys($data)));
2012-01-22 03:11:22 +00:00
$data = array('1' => 'one', 2 => 'two', 3 => 'three', 4 => 'four', 5 => 'five');
2012-03-01 18:44:33 +00:00
$this->assertTrue(Hash::numeric(array_keys($data)));
2012-01-22 03:11:22 +00:00
$data = array('one', 2 => 'two', 3 => 'three', 4 => 'four', 'a' => 'five');
2012-03-01 18:44:33 +00:00
$this->assertFalse(Hash::numeric(array_keys($data)));
2012-01-22 03:11:22 +00:00
}
/**
* Test simple paths.
*
* @return void
*/
public function testExtractBasic() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '');
$this->assertEquals($data, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '0.Article.title');
$this->assertEquals(array('First Article'), $result);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '1.Article.title');
$this->assertEquals(array('Second Article'), $result);
}
2012-01-22 17:42:50 +00:00
/**
* Test the {n} selector
*
* @return void
*/
public function testExtractNumericKey() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Article.title');
$expected = array(
2012-03-27 02:57:50 +00:00
'First Article', 'Second Article',
'Third Article', 'Fourth Article',
'Fifth Article'
);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '0.Comment.{n}.user_id');
$expected = array(
'2', '4'
);
$this->assertEquals($expected, $result);
}
2012-01-22 17:42:50 +00:00
/**
* Test the {n} selector with inconsistent arrays
*
* @return void
*/
2012-01-26 01:34:43 +00:00
public function testExtractNumericMixedKeys() {
2012-01-22 17:42:50 +00:00
$data = array(
'User' => array(
0 => array(
'id' => 4,
'name' => 'Neo'
),
1 => array(
'id' => 5,
'name' => 'Morpheus'
),
'stringKey' => array(
'name' => 'Fail'
)
)
);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, 'User.{n}.name');
2012-01-22 17:42:50 +00:00
$expected = array('Neo', 'Morpheus');
$this->assertEquals($expected, $result);
}
/**
* Test the {n} selector with non-zero based arrays
*
* @return void
*/
public function testExtractNumericNonZero() {
$data = 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',
)
)
);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.User.name');
2012-01-22 17:42:50 +00:00
$expected = array('John', 'Bob', 'Tony');
$this->assertEquals($expected, $result);
}
2012-03-27 02:57:50 +00:00
2012-01-22 17:42:50 +00:00
/**
* Test the {s} selector.
*
* @return void
*/
public function testExtractStringKey() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.{s}.user');
$expected = array(
2012-01-26 03:41:20 +00:00
'mariano',
'mariano',
'mariano',
'mariano',
'mariano'
);
$this->assertEquals($expected, $result);
2012-01-22 17:42:50 +00:00
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.{s}.Nesting.test.1');
2012-01-22 17:42:50 +00:00
$this->assertEquals(array('foo'), $result);
}
/**
* Test the attribute presense selector.
*
* @return void
*/
public function testExtractAttributePresence() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Article[published]');
2012-01-24 12:27:21 +00:00
$expected = array($data[1]['Article']);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Article[id][published]');
2012-01-24 12:27:21 +00:00
$expected = array($data[1]['Article']);
$this->assertEquals($expected, $result);
}
/**
* Test = and != operators.
*
* @return void
*/
public function testExtractAttributeEquality() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Article[id=3]');
$expected = array($data[2]['Article']);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Article[id = 3]');
$expected = array($data[2]['Article']);
$this->assertEquals($expected, $result, 'Whitespace should not matter.');
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Article[id!=3]');
$this->assertEquals(1, $result[0]['id']);
$this->assertEquals(2, $result[1]['id']);
$this->assertEquals(4, $result[2]['id']);
$this->assertEquals(5, $result[3]['id']);
}
/**
* Test comparison operators.
*
* @return void
*/
public function testExtractAttributeComparison() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Comment.{n}[user_id > 2]');
$expected = array($data[0]['Comment'][1]);
$this->assertEquals($expected, $result);
$this->assertEquals(4, $expected[0]['user_id']);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Comment.{n}[user_id >= 4]');
$expected = array($data[0]['Comment'][1]);
$this->assertEquals($expected, $result);
$this->assertEquals(4, $expected[0]['user_id']);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Comment.{n}[user_id < 3]');
$expected = array($data[0]['Comment'][0]);
$this->assertEquals($expected, $result);
$this->assertEquals(2, $expected[0]['user_id']);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Comment.{n}[user_id <= 2]');
$expected = array($data[0]['Comment'][0]);
$this->assertEquals($expected, $result);
$this->assertEquals(2, $expected[0]['user_id']);
}
2012-01-24 12:27:21 +00:00
/**
* Test multiple attributes with conditions.
*
* @return void
*/
public function testExtractAttributeMultiple() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Comment.{n}[user_id > 2][id=1]');
2012-01-24 12:27:21 +00:00
$this->assertEmpty($result);
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Comment.{n}[user_id > 2][id=2]');
2012-01-24 12:27:21 +00:00
$expected = array($data[0]['Comment'][1]);
$this->assertEquals($expected, $result);
$this->assertEquals(4, $expected[0]['user_id']);
}
2012-01-25 03:27:01 +00:00
/**
* Test attribute pattern matching.
*
* @return void
*/
public function testExtractAttributePattern() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::extract($data, '{n}.Article[title=/^First/]');
2012-01-25 03:27:01 +00:00
$expected = array($data[0]['Article']);
$this->assertEquals($expected, $result);
}
/**
* Test that extract() + matching can hit null things.
*/
public function testExtractMatchesNull() {
$data = array(
'Country' => array(
array('name' => 'Canada'),
array('name' => 'Australia'),
array('name' => null),
)
);
$result = Hash::extract($data, 'Country.{n}[name=/Canada|^$/]');
$expected = array(
array(
'name' => 'Canada',
),
array(
'name' => null,
),
);
$this->assertEquals($expected, $result);
}
2012-02-22 03:21:24 +00:00
/**
* Test that uneven keys are handled correctly.
*
* @return void
*/
public function testExtractUnevenKeys() {
$data = array(
'Level1' => array(
'Level2' => array('test1', 'test2'),
'Level2bis' => array('test3', 'test4')
)
);
$this->assertEquals(
array('test1', 'test2'),
2012-02-28 21:52:54 +00:00
Hash::extract($data, 'Level1.Level2')
2012-02-22 03:21:24 +00:00
);
$this->assertEquals(
array('test3', 'test4'),
2012-02-28 21:52:54 +00:00
Hash::extract($data, 'Level1.Level2bis')
2012-02-22 03:21:24 +00:00
);
$data = array(
'Level1' => array(
'Level2bis' => array(
array('test3', 'test4'),
array('test5', 'test6')
)
)
);
$expected = array(
array('test3', 'test4'),
array('test5', 'test6')
);
2012-02-28 21:52:54 +00:00
$this->assertEquals($expected, Hash::extract($data, 'Level1.Level2bis'));
2012-03-27 02:57:50 +00:00
2012-02-22 03:21:24 +00:00
$data['Level1']['Level2'] = array('test1', 'test2');
2012-02-28 21:52:54 +00:00
$this->assertEquals($expected, Hash::extract($data, 'Level1.Level2bis'));
2012-02-22 03:21:24 +00:00
}
2012-01-26 01:34:43 +00:00
/**
* testSort method
*
* @return void
*/
public function testSort() {
$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'))
)
);
2012-02-28 21:52:54 +00:00
$a = Hash::sort($a, '{n}.Friend.{n}.name', 'asc');
2012-01-26 01:34:43 +00:00
$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'))
)
);
2012-02-28 21:52:54 +00:00
$a = Hash::sort($a, '{n}.Friend.{n}.name', 'desc');
2012-01-26 01:34:43 +00:00
$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'))
)
);
2012-02-28 21:52:54 +00:00
$a = Hash::sort($a, '{n}.Person.name', 'asc');
2012-01-26 01:34:43 +00:00
$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 = Hash::sort($a, '{n}.Person.name', 'ASC', 'STRING');
2012-01-26 01:34:43 +00:00
$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 = Hash::sort($names, '{n}.employees.0.name', 'asc');
2012-01-26 01:34:43 +00:00
$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);
}
/**
* Test sort() with numeric option.
*
* @return void
*/
public function testSortNumeric() {
$items = array(
array('Item' => array('price' => '155,000')),
array('Item' => array('price' => '139,000')),
array('Item' => array('price' => '275,622')),
array('Item' => array('price' => '230,888')),
array('Item' => array('price' => '66,000')),
);
$result = Hash::sort($items, '{n}.Item.price', 'asc', 'numeric');
$expected = array(
array('Item' => array('price' => '66,000')),
array('Item' => array('price' => '139,000')),
array('Item' => array('price' => '155,000')),
array('Item' => array('price' => '230,888')),
array('Item' => array('price' => '275,622')),
);
$this->assertEquals($expected, $result);
$result = Hash::sort($items, '{n}.Item.price', 'desc', 'numeric');
$expected = array(
array('Item' => array('price' => '275,622')),
array('Item' => array('price' => '230,888')),
array('Item' => array('price' => '155,000')),
array('Item' => array('price' => '139,000')),
array('Item' => array('price' => '66,000')),
);
$this->assertEquals($expected, $result);
}
/**
* Test natural sorting.
*
* @return void
*/
public function testSortNatural() {
if (version_compare(PHP_VERSION, '5.4.0', '<')) {
$this->markTestSkipped('SORT_NATURAL is available since PHP 5.4.');
}
$items = array(
array('Item' => array('image' => 'img1.jpg')),
array('Item' => array('image' => 'img99.jpg')),
array('Item' => array('image' => 'img12.jpg')),
array('Item' => array('image' => 'img10.jpg')),
array('Item' => array('image' => 'img2.jpg')),
);
$result = Hash::sort($items, '{n}.Item.image', 'desc', 'natural');
$expected = array(
array('Item' => array('image' => 'img99.jpg')),
array('Item' => array('image' => 'img12.jpg')),
array('Item' => array('image' => 'img10.jpg')),
array('Item' => array('image' => 'img2.jpg')),
array('Item' => array('image' => 'img1.jpg')),
);
$this->assertEquals($expected, $result);
$result = Hash::sort($items, '{n}.Item.image', 'asc', 'natural');
$expected = array(
array('Item' => array('image' => 'img1.jpg')),
array('Item' => array('image' => 'img2.jpg')),
array('Item' => array('image' => 'img10.jpg')),
array('Item' => array('image' => 'img12.jpg')),
array('Item' => array('image' => 'img99.jpg')),
);
$this->assertEquals($expected, $result);
}
2012-01-26 01:34:43 +00:00
/**
* 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),
);
2012-02-28 21:52:54 +00:00
$result = Hash::sort($data, '{n}.class', 'asc');
2012-01-26 01:34:43 +00:00
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::sort($data, '{n}.test2', 'asc');
2012-01-26 01:34:43 +00:00
$this->assertEquals($expected, $result);
}
/**
* test sorting with string keys.
*
* @return void
*/
public function testSortString() {
2012-03-27 02:57:50 +00:00
$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')
);
2012-03-27 02:57:50 +00:00
$sorted = Hash::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);
$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 = Hash::sort($menus, '{s}.weight', 'ASC');
$this->assertEquals($expected, $result);
}
/**
* Test insert()
*
* @return void
*/
public function testInsertSimple() {
$a = array(
'pages' => array('name' => 'page')
);
2012-02-28 21:52:54 +00:00
$result = Hash::insert($a, 'files', array('name' => 'files'));
$expected = array(
'pages' => array('name' => 'page'),
'files' => array('name' => 'files')
);
$this->assertEquals($expected, $result);
$a = array(
'pages' => array('name' => 'page')
);
2012-02-28 21:52:54 +00:00
$result = Hash::insert($a, 'pages.name', array());
$expected = array(
'pages' => array('name' => array()),
);
$this->assertEquals($expected, $result);
}
2012-01-26 01:34:43 +00:00
/**
* Test inserting with multiple values.
*
* @return void
*/
public function testInsertMulti() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::insert($data, '{n}.Article.insert', 'value');
$this->assertEquals('value', $result[0]['Article']['insert']);
$this->assertEquals('value', $result[1]['Article']['insert']);
2012-02-28 21:52:54 +00:00
$result = Hash::insert($data, '{n}.Comment.{n}.insert', 'value');
$this->assertEquals('value', $result[0]['Comment'][0]['insert']);
$this->assertEquals('value', $result[0]['Comment'][1]['insert']);
}
/**
* Test that insert() can insert data over a string value.
*
* @return void
*/
public function testInsertOverwriteStringValue() {
$data = array(
'Some' => array(
'string' => 'value'
)
);
2012-03-31 12:49:04 +00:00
$result = Hash::insert($data, 'Some.string.value', array('values'));
$expected = array(
'Some' => array(
'string' => array(
2012-05-19 14:48:15 +00:00
'value' => array('values')
)
)
);
$this->assertEquals($expected, $result);
}
/**
* Test remove() method.
2012-01-26 01:34:43 +00:00
*
* @return void
*/
public function testRemove() {
$a = array(
'pages' => array('name' => 'page'),
'files' => array('name' => 'files')
);
2012-02-28 21:52:54 +00:00
$result = Hash::remove($a, 'files');
$expected = array(
'pages' => array('name' => 'page')
);
$this->assertEquals($expected, $result);
$a = array(
'pages' => array(
0 => array('name' => 'main'),
1 => array(
'name' => 'about',
'vars' => array('title' => 'page title')
)
)
);
2012-02-28 21:52:54 +00:00
$result = Hash::remove($a, 'pages.1.vars');
$expected = array(
'pages' => array(
0 => array('name' => 'main'),
1 => array('name' => 'about')
)
);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::remove($a, 'pages.2.vars');
$expected = $a;
$this->assertEquals($expected, $result);
}
/**
* Test removing multiple values.
*
* @return void
*/
public function testRemoveMulti() {
2012-01-26 01:34:43 +00:00
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::remove($data, '{n}.Article.title');
$this->assertFalse(isset($result[0]['Article']['title']));
$this->assertFalse(isset($result[1]['Article']['title']));
2012-01-26 01:34:43 +00:00
2012-02-28 21:52:54 +00:00
$result = Hash::remove($data, '{n}.Article.{s}');
$this->assertFalse(isset($result[0]['Article']['id']));
$this->assertFalse(isset($result[0]['Article']['user_id']));
$this->assertFalse(isset($result[0]['Article']['title']));
$this->assertFalse(isset($result[0]['Article']['body']));
2012-01-26 01:34:43 +00:00
}
2012-02-20 04:11:43 +00:00
/**
* testCheck method
*
* @return void
*/
public function testCheck() {
$set = array(
'My Index 1' => array('First' => 'The first item')
);
2012-02-28 21:52:54 +00:00
$this->assertTrue(Hash::check($set, 'My Index 1.First'));
$this->assertTrue(Hash::check($set, 'My Index 1'));
2012-02-20 04:11:43 +00:00
$set = array(
'My Index 1' => array(
'First' => array(
'Second' => array(
'Third' => array(
'Fourth' => 'Heavy. Nesting.'
)
)
)
)
);
2012-02-28 21:52:54 +00:00
$this->assertTrue(Hash::check($set, 'My Index 1.First.Second'));
$this->assertTrue(Hash::check($set, 'My Index 1.First.Second.Third'));
$this->assertTrue(Hash::check($set, 'My Index 1.First.Second.Third.Fourth'));
$this->assertFalse(Hash::check($set, 'My Index 1.First.Seconds.Third.Fourth'));
2012-02-20 04:11:43 +00:00
}
2012-02-20 04:34:51 +00:00
/**
* testCombine method
*
* @return void
*/
public function testCombine() {
2012-02-28 21:52:54 +00:00
$result = Hash::combine(array(), '{n}.User.id', '{n}.User.Data');
2012-02-20 04:34:51 +00:00
$this->assertTrue(empty($result));
$a = self::userData();
2012-02-28 21:52:54 +00:00
$result = Hash::combine($a, '{n}.User.id');
2012-02-20 04:34:51 +00:00
$expected = array(2 => null, 14 => null, 25 => null);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::combine($a, '{n}.User.id', '{n}.User.non-existant');
2012-02-20 04:34:51 +00:00
$expected = array(2 => null, 14 => null, 25 => null);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::combine($a, '{n}.User.id', '{n}.User.Data');
2012-02-20 04:34:51 +00:00
$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);
2012-02-28 21:52:54 +00:00
$result = Hash::combine($a, '{n}.User.id', '{n}.User.Data.name');
2012-02-20 04:34:51 +00:00
$expected = array(
2 => 'Mariano Iglesias',
14 => 'Larry E. Masters',
25 => 'The Gwoo');
$this->assertEquals($expected, $result);
}
/**
* test combine() with a group path.
*
* @return void
*/
public function testCombineWithGroupPath() {
$a = self::userData();
2012-02-28 21:52:54 +00:00
$result = Hash::combine($a, '{n}.User.id', '{n}.User.Data', '{n}.User.group_id');
2012-02-20 04:34:51 +00:00
$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);
2012-02-28 21:52:54 +00:00
$result = Hash::combine($a, '{n}.User.id', '{n}.User.Data.name', '{n}.User.group_id');
2012-02-20 04:34:51 +00:00
$expected = array(
1 => array(
2 => 'Mariano Iglesias',
25 => 'The Gwoo'
),
2 => array(
14 => 'Larry E. Masters'
)
);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::combine($a, '{n}.User.id', '{n}.User.Data', '{n}.User.group_id');
2012-02-20 04:34:51 +00:00
$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);
2012-02-28 21:52:54 +00:00
$result = Hash::combine($a, '{n}.User.id', '{n}.User.Data.name', '{n}.User.group_id');
2012-02-20 04:34:51 +00:00
$expected = array(
1 => array(
2 => 'Mariano Iglesias',
25 => 'The Gwoo'
),
2 => array(
14 => 'Larry E. Masters'
)
);
$this->assertEquals($expected, $result);
}
/**
* Test combine with formatting rules.
*
* @return void
*/
public function testCombineWithFormatting() {
$a = self::userData();
2012-02-28 21:52:54 +00:00
$result = Hash::combine(
2012-02-20 04:34:51 +00:00
$a,
'{n}.User.id',
array('%1$s: %2$s', '{n}.User.Data.user', '{n}.User.Data.name'),
2012-02-20 04:34:51 +00:00
'{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);
2012-02-28 21:52:54 +00:00
$result = Hash::combine(
2012-02-20 04:34:51 +00:00
$a,
array(
'%s: %s',
'{n}.User.Data.user',
'{n}.User.Data.name'
),
2012-02-20 04:34:51 +00:00
'{n}.User.id'
);
$expected = array(
'mariano.iglesias: Mariano Iglesias' => 2,
'phpnut: Larry E. Masters' => 14,
'gwoo: The Gwoo' => 25
);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::combine(
2012-02-20 04:34:51 +00:00
$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);
2012-02-28 21:52:54 +00:00
$result = Hash::combine(
2012-02-20 04:34:51 +00:00
$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);
}
/**
* testFormat method
*
* @return void
*/
public function testFormat() {
$data = self::userData();
2012-02-28 21:52:54 +00:00
$result = Hash::format(
$data,
array('{n}.User.Data.user', '{n}.User.id'),
'%s, %s'
);
$expected = array(
'mariano.iglesias, 2',
'phpnut, 14',
'gwoo, 25'
);
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::format(
$data,
array('{n}.User.Data.user', '{n}.User.id'),
'%2$s, %1$s'
);
$expected = array(
'2, mariano.iglesias',
'14, phpnut',
'25, gwoo'
);
$this->assertEquals($expected, $result);
}
/**
* testFormattingNullValues method
*
* @return void
*/
public function testFormatNullValues() {
$data = array(
2012-02-22 04:27:26 +00:00
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
))
);
2012-02-28 21:52:54 +00:00
$result = Hash::format($data, array('{n}.Person.something'), '%s');
$expected = array('42', '', '');
$this->assertEquals($expected, $result);
2012-02-28 21:52:54 +00:00
$result = Hash::format($data, array('{n}.Person.city', '{n}.Person.something'), '%s, %s');
$expected = array('Boston, 42', 'Boondock, ', 'Venice Beach, ');
$this->assertEquals($expected, $result);
}
/**
* Test map()
*
* @return void
*/
public function testMap() {
$data = self::articleData();
2012-03-27 02:57:50 +00:00
$result = Hash::map($data, '{n}.Article.id', array($this, 'mapCallback'));
$expected = array(2, 4, 6, 8, 10);
$this->assertEquals($expected, $result);
}
public function testApply() {
$data = self::articleData();
2012-02-28 21:52:54 +00:00
$result = Hash::apply($data, '{n}.Article.id', 'array_sum');
$this->assertEquals(15, $result);
}
/**
* Test reduce()
*
* @return void
*/
public function testReduce() {
$data = self::articleData();
2012-03-27 02:57:50 +00:00
$result = Hash::reduce($data, '{n}.Article.id', array($this, 'reduceCallback'));
$this->assertEquals(15, $result);
}
/**
* testing method for map callbacks.
*
* @param mixed $value
* @return mixed.
*/
2012-03-27 02:57:50 +00:00
public function mapCallback($value) {
return $value * 2;
}
/**
* testing method for reduce callbacks.
*
* @param mixed $one
* @param mixed $two
* @return mixed.
*/
2012-03-27 02:57:50 +00:00
public function reduceCallback($one, $two) {
return $one + $two;
}
/**
2012-03-31 12:49:04 +00:00
* test Hash nest with a normal model result set. For kicks rely on Hash 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()
)
)
)
);
2012-02-28 21:52:54 +00:00
$result = Hash::nest($input);
$this->assertEquals($expected, $result);
}
/**
2012-03-31 12:49:04 +00:00
* test Hash 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()
)
)
)
);
2012-02-28 21:52:54 +00:00
$result = Hash::nest($input, array('root' => 6));
$this->assertEquals($expected, $result);
}
/**
2012-03-31 12:49:04 +00:00
* test Hash nest with a 1d array - this method should be able to handle any type of array input
*
* @return void
*/
public function testNest1Dimensional() {
$input = array(
array(
'id' => 1,
'parent_id' => null
),
array(
'id' => 2,
'parent_id' => 1
),
array(
'id' => 3,
'parent_id' => 1
),
array(
'id' => 4,
'parent_id' => 1
),
array(
'id' => 5,
'parent_id' => 1
),
array(
'id' => 6,
'parent_id' => null
),
array(
'id' => 7,
'parent_id' => 6
),
array(
'id' => 8,
'parent_id' => 6
),
array(
'id' => 9,
'parent_id' => 6
),
array(
'id' => 10,
'parent_id' => 6
)
);
$expected = array(
array(
'id' => 1,
'parent_id' => null,
'children' => array(
array(
'id' => 2,
'parent_id' => 1,
'children' => array()
),
array(
'id' => 3,
'parent_id' => 1,
'children' => array()
),
array(
'id' => 4,
'parent_id' => 1,
'children' => array()
),
array(
'id' => 5,
'parent_id' => 1,
'children' => array()
),
)
),
array(
'id' => 6,
'parent_id' => null,
'children' => array(
array(
'id' => 7,
'parent_id' => 6,
'children' => array()
),
array(
'id' => 8,
'parent_id' => 6,
'children' => array()
),
array(
'id' => 9,
'parent_id' => 6,
'children' => array()
),
array(
'id' => 10,
'parent_id' => 6,
'children' => array()
)
)
)
);
2012-02-28 21:52:54 +00:00
$result = Hash::nest($input, array('idPath' => '{n}.id', 'parentPath' => '{n}.parent_id'));
$this->assertEquals($expected, $result);
}
/**
2012-03-31 12:49:04 +00:00
* test Hash 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,
)
);
2012-02-28 21:52:54 +00:00
$result = Hash::nest($input, array('idPath' => '{n}.id', 'parentPath' => '{n}.parent_id'));
2012-03-27 02:57:50 +00:00
foreach ($result as &$row) {
if (empty($row['children'])) {
unset($row['children']);
}
}
$this->assertEquals($input, $result);
}
/**
* testMergeDiff method
*
* @return void
*/
public function testMergeDiff() {
2012-04-11 02:16:14 +00:00
$first = array(
'ModelOne' => array(
'id' => 1001,
'field_one' => 'a1.m1.f1',
'field_two' => 'a1.m1.f2'
)
);
2012-04-11 02:16:14 +00:00
$second = array(
'ModelTwo' => array(
'id' => 1002,
'field_one' => 'a2.m2.f1',
'field_two' => 'a2.m2.f2'
)
);
2012-04-11 02:16:14 +00:00
$result = Hash::mergeDiff($first, $second);
$this->assertEquals($result, $first + $second);
2012-04-11 02:16:14 +00:00
$result = Hash::mergeDiff($first, array());
$this->assertEquals($result, $first);
2012-03-27 02:57:50 +00:00
2012-04-11 02:16:14 +00:00
$result = Hash::mergeDiff(array(), $first);
$this->assertEquals($result, $first);
2012-03-27 02:57:50 +00:00
2012-04-11 02:16:14 +00:00
$third = array(
'ModelOne' => array(
'id' => 1003,
'field_one' => 'a3.m1.f1',
'field_two' => 'a3.m1.f2',
'field_three' => 'a3.m1.f3'
)
);
2012-04-11 02:16:14 +00:00
$result = Hash::mergeDiff($first, $third);
$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);
2012-04-11 02:16:14 +00:00
$first = 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'))
);
2012-04-11 02:16:14 +00:00
$second = 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'))
);
2012-04-11 02:16:14 +00:00
$result = Hash::mergeDiff($first, $second);
$this->assertEquals($result, $first);
2012-04-11 02:16:14 +00:00
$third = array(
0 => array(
'ModelThree' => array(
'id' => 1003,
'field_one' => 's3.0.m3.f1',
'field_two' => 's3.0.m3.f2'
)
)
);
2012-04-11 02:16:14 +00:00
$result = Hash::mergeDiff($first, $third);
$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);
2012-04-11 02:16:14 +00:00
$result = Hash::mergeDiff($first, null);
$this->assertEquals($result, $first);
2012-04-11 02:16:14 +00:00
$result = Hash::mergeDiff($first, $second);
$this->assertEquals($result, $first + $second);
}
2012-03-18 23:00:25 +00:00
/**
* Tests Hash::expand
*
* @return void
*/
public function testExpand() {
$data = array('My', 'Array', 'To', 'Flatten');
$flat = Hash::flatten($data);
$result = Hash::expand($flat);
$this->assertEquals($data, $result);
2012-03-18 23:00:25 +00:00
$data = array(
'0.Post.id' => '1', '0.Post.author_id' => '1', '0.Post.title' => 'First Post', '0.Author.id' => '1',
'0.Author.user' => 'nate', '0.Author.password' => 'foo', '1.Post.id' => '2', '1.Post.author_id' => '3',
'1.Post.title' => 'Second Post', '1.Post.body' => 'Second Post Body', '1.Author.id' => '3',
'1.Author.user' => 'larry', '1.Author.password' => null
);
$result = Hash::expand($data);
$expected = array(
array(
'Post' => array('id' => '1', 'author_id' => '1', 'title' => 'First Post'),
'Author' => array('id' => '1', 'user' => 'nate', 'password' => 'foo'),
),
array(
'Post' => array('id' => '2', 'author_id' => '3', 'title' => 'Second Post', 'body' => 'Second Post Body'),
'Author' => array('id' => '3', 'user' => 'larry', 'password' => null),
)
);
$this->assertEquals($expected, $result);
2012-03-18 23:00:25 +00:00
$data = array(
'0/Post/id' => 1,
'0/Post/name' => 'test post'
);
$result = Hash::expand($data, '/');
$expected = array(
array(
'Post' => array(
'id' => 1,
'name' => 'test post'
)
)
);
$this->assertEquals($result, $expected);
2012-03-18 23:00:25 +00:00
}
2012-01-12 02:33:14 +00:00
}