diff options
Diffstat (limited to 'tests/template/template_test.php')
| -rw-r--r-- | tests/template/template_test.php | 168 | 
1 files changed, 166 insertions, 2 deletions
| diff --git a/tests/template/template_test.php b/tests/template/template_test.php index 0bbfe3848d..69546cc227 100644 --- a/tests/template/template_test.php +++ b/tests/template/template_test.php @@ -528,22 +528,139 @@ EOT  			),  			array(  				'outer', +				array('VARIABLE' => 'changed'), +				0, +				'change', +				<<<EOT +outer - 0 - changed +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 +outer - 2 +middle - 0 +middle - 1 +EOT +, +				'Test changing at 0 on top level block', +			), +			array( +				'outer', +				array('VARIABLE' => 'changed'), +				array('S_ROW_NUM' => 2), +				'change', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 +outer - 2 - changed +middle - 0 +middle - 1 +EOT +, +				'Test changing at KEY on top level block', +			), +			array( +				'outer.middle', +				array('VARIABLE' => 'before'), +				false, +				'insert', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 +outer - 2 +middle - 0 - before +middle - 1 +middle - 2 +EOT +, +				'Test inserting before on middle level block', +			), +			array( +				'outer.middle', +				array('VARIABLE' => 'after'), +				true, +				'insert', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 +outer - 2 +middle - 0 +middle - 1 +middle - 2 - after +EOT +, +				'Test inserting after on middle level block', +			), +			array( +				'outer[1].middle',  				array('VARIABLE' => 'pos #1'), +				1, +				'insert', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 - pos #1 +middle - 2 +outer - 2 +middle - 0 +middle - 1 +EOT +, +				'Test inserting at 1 on middle level block', +			), +			array( +				'outer[].middle', +				array('VARIABLE' => 'changed'),  				0,  				'change',  				<<<EOT -outer - 0 - pos #1 +outer - 0  middle - 0  middle - 1  outer - 1  middle - 0  middle - 1  outer - 2 +middle - 0 - changed +middle - 1 +EOT +, +				'Test changing at beginning of last top level block', +			), +			array( +				'outer.middle', +				array('VARIABLE' => 'changed'), +				array('S_ROW_NUM' => 1), +				'change', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1  middle - 0  middle - 1 +outer - 2 +middle - 0 +middle - 1 - changed  EOT  , -				'Test inserting at 1 on top level block', +				'Test changing at beginning of last top level block',  			),  		);  	} @@ -601,8 +718,55 @@ EOT  		$expect = 'outer - 0[outer|4]outer - 1[outer|4]middle - 0[middle|1]outer - 2 - test[outer|4]middle - 0[middle|2]middle - 1[middle|2]outer - 3[outer|4]middle - 0[middle|3]middle - 1[middle|3]middle - 2[middle|3]';  		$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring S_NUM_ROWS is correct after modification'); + +		$this->template->alter_block_array('outer.middle', array()); + +		$expect = 'outer - 0[outer|4]outer - 1[outer|4]middle - 0[middle|1]outer - 2 - test[outer|4]middle - 0[middle|2]middle - 1[middle|2]outer - 3[outer|4]middle - 0[middle|4]middle - 1[middle|4]middle - 2[middle|4]middle - 3[middle|4]'; +		$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring S_NUM_ROWS is correct after insertion at middle level'); + +		$this->template->alter_block_array('outer.middle', array('VARIABLE' => 'test'), 2, 'change'); + +		$expect = 'outer - 0[outer|4]outer - 1[outer|4]middle - 0[middle|1]outer - 2 - test[outer|4]middle - 0[middle|2]middle - 1[middle|2]outer - 3[outer|4]middle - 0[middle|4]middle - 1[middle|4]middle - 2 - test[middle|4]middle - 3[middle|4]'; +		$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring S_NUM_ROWS is correct after modification at middle level');  	} +	public function test_find_key_index() +	{ +		$this->template->set_filenames(array('test' => 'loop_nested.html')); + +		$this->template->assign_var('TEST_MORE', true); + +		// @todo Change this +		$this->template->assign_block_vars('outer', array('VARIABLE' => 'zero')); +		$this->template->assign_block_vars('outer', array('VARIABLE' => 'one')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '1A')); +		$this->template->assign_block_vars('outer', array('VARIABLE' => 'two')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '2A')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '2B')); +		$this->template->assign_block_vars('outer', array('VARIABLE' => 'three')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '3A')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '3B')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '3C')); + +		$expect = 'outer - 0 - zero[outer|4]outer - 1 - one[outer|4]middle - 0 - 1A[middle|1]outer - 2 - two[outer|4]middle - 0 - 2A[middle|2]middle - 1 - 2B[middle|2]outer - 3 - three[outer|4]middle - 0 - 3A[middle|3]middle - 1 - 3B[middle|3]middle - 2 - 3C[middle|3]'; +		$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring template is built correctly before modification'); + +		$this->template->find_key_index('outer', false); + +		$this->assertEquals(0, $this->template->find_key_index('outer', false), 'Find index at the beginning of outer loop'); +		$this->assertEquals(1, $this->template->find_key_index('outer', 1), 'Find index by index in outer loop'); +		$this->assertEquals(2, $this->template->find_key_index('outer', array('VARIABLE' => 'two')), 'Find index by key in outer loop'); +		$this->assertEquals(3, $this->template->find_key_index('outer', true), 'Find index at the end of outer loop'); +		$this->assertEquals(false, $this->template->find_key_index('outer', 7), 'Find index out of bounds of outer loop'); + +		$this->assertEquals(false, $this->template->find_key_index('outer[0].middle', false), 'Find index at the beginning of middle loop, no middle block'); +		$this->assertEquals(false, $this->template->find_key_index('outer[1].middle', 1), 'Find index by index in inner loop, out of bounds'); +		$this->assertEquals(1, $this->template->find_key_index('outer[2].middle', array('VARIABLE' => '2B')), 'Find index by key in middle loop'); +		$this->assertEquals(2, $this->template->find_key_index('outer.middle', true), 'Find index at the end of middle loop'); + +		$this->assertEquals(false, $this->template->find_key_index('outer.wrong', true), 'Wrong middle block name'); +		$this->assertEquals(false, $this->template->find_key_index('wrong.middle', false), 'Wrong outer block name'); +	}  	public function assign_block_vars_array_data()  	{  		return array( | 
