cacert-testmgr/external/ZendFramework-1.9.5/tests/Zend/Form/Element/MultiCheckboxTest.php

289 lines
9.6 KiB
PHP
Raw Permalink Normal View History

<?php
/**
* Zend Framework
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://framework.zend.com/license/new-bsd
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@zend.com so we can send you a copy immediately.
*
* @category Zend
* @package Zend_Form
* @subpackage UnitTests
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @version $Id: MultiCheckboxTest.php 18555 2009-10-15 20:10:50Z matthew $
*/
// Call Zend_Form_Element_MultiCheckboxTest::main() if this source file is executed directly.
if (!defined("PHPUnit_MAIN_METHOD")) {
define("PHPUnit_MAIN_METHOD", "Zend_Form_Element_MultiCheckboxTest::main");
}
require_once dirname(__FILE__) . '/../../../TestHelper.php';
require_once 'Zend/Form/Element/MultiCheckbox.php';
/**
* Test class for Zend_Form_Element_MultiCheckbox
*
* @category Zend
* @package Zend_Form
* @subpackage UnitTests
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @group Zend_Form
*/
class Zend_Form_Element_MultiCheckboxTest extends PHPUnit_Framework_TestCase
{
/**
* Runs the test methods of this class.
*
* @return void
*/
public static function main()
{
$suite = new PHPUnit_Framework_TestSuite("Zend_Form_Element_MultiCheckboxTest");
$result = PHPUnit_TextUI_TestRunner::run($suite);
}
/**
* Sets up the fixture, for example, open a network connection.
* This method is called before a test is executed.
*
* @return void
*/
public function setUp()
{
$this->element = new Zend_Form_Element_MultiCheckbox('foo');
}
/**
* Tears down the fixture, for example, close a network connection.
* This method is called after a test is executed.
*
* @return void
*/
public function tearDown()
{
}
public function getView()
{
require_once 'Zend/View.php';
$view = new Zend_View();
$view->addHelperPath(dirname(__FILE__) . '/../../../../library/Zend/View/Helper');
return $view;
}
public function testMultiCheckboxElementSubclassesMultiElement()
{
$this->assertTrue($this->element instanceof Zend_Form_Element_Multi);
}
public function testMultiCheckboxElementSubclassesXhtmlElement()
{
$this->assertTrue($this->element instanceof Zend_Form_Element_Xhtml);
}
public function testMultiCheckboxElementInstanceOfBaseElement()
{
$this->assertTrue($this->element instanceof Zend_Form_Element);
}
public function testMultiCheckboxElementIsAnArrayByDefault()
{
$this->assertTrue($this->element->isArray());
}
public function testHelperAttributeSetToFormMultiCheckboxByDefault()
{
$this->assertEquals('formMultiCheckbox', $this->element->getAttrib('helper'));
}
public function testMultiCheckboxElementUsesMultiCheckboxHelperInViewHelperDecoratorByDefault()
{
$this->_checkZf2794();
$decorator = $this->element->getDecorator('viewHelper');
$this->assertTrue($decorator instanceof Zend_Form_Decorator_ViewHelper);
$decorator->setElement($this->element);
$helper = $decorator->getHelper();
$this->assertEquals('formMultiCheckbox', $helper);
}
public function testCanDisableIndividualMultiCheckboxOptions()
{
$this->element->setMultiOptions(array(
'foo' => 'Foo',
'bar' => 'Bar',
'baz' => 'Baz',
'bat' => 'Bat',
'test' => 'Test',
))
->setAttrib('disable', array('baz', 'test'));
$html = $this->element->render($this->getView());
foreach (array('baz', 'test') as $test) {
if (!preg_match('/(<input[^>]*?(value="' . $test . '")[^>]*>)/', $html, $m)) {
$this->fail('Unable to find matching disabled option for ' . $test);
}
$this->assertRegexp('/<input[^>]*?(disabled="disabled")/', $m[1]);
}
foreach (array('foo', 'bar', 'bat') as $test) {
if (!preg_match('/(<input[^>]*?(value="' . $test . '")[^>]*>)/', $html, $m)) {
$this->fail('Unable to find matching option for ' . $test);
}
$this->assertNotRegexp('/<input[^>]*?(disabled="disabled")/', $m[1], var_export($m, 1));
}
}
public function testSpecifiedSeparatorIsUsedWhenRendering()
{
$this->element->setMultiOptions(array(
'foo' => 'Foo',
'bar' => 'Bar',
'baz' => 'Baz',
'bat' => 'Bat',
'test' => 'Test',
))
->setSeparator('--FooBarFunSep--');
$html = $this->element->render($this->getView());
$this->assertContains($this->element->getSeparator(), $html);
$count = substr_count($html, $this->element->getSeparator());
$this->assertEquals(4, $count);
}
/**
* @see ZF-2830
*/
public function testRenderingMulticheckboxCreatesCorrectArrayNotation()
{
$this->element->addMultiOption(1, 'A');
$this->element->addMultiOption(2, 'B');
$html = $this->element->render($this->getView());
$this->assertContains('name="foo[]"', $html, $html);
$count = substr_count($html, 'name="foo[]"');
$this->assertEquals(2, $count);
}
/**
* @see ZF-2828
*/
public function testCanPopulateCheckboxOptionsFromPostedData()
{
$form = new Zend_Form(array(
'elements' => array(
'100_1' => array('MultiCheckbox', array(
'multiOptions' => array(
'100_1_1' => 'Agriculture',
'100_1_2' => 'Automotive',
'100_1_12' => 'Chemical',
'100_1_13' => 'Communications',
),
'required' => true,
)),
),
));
$data = array(
'100_1' => array(
'100_1_1',
'100_1_2',
'100_1_12',
'100_1_13'
),
);
$form->populate($data);
$html = $form->render($this->getView());
foreach ($form->getElement('100_1')->getMultiOptions() as $key => $value) {
if (!preg_match('#(<input[^>]*' . $key . '[^>]*>)#', $html, $m)) {
$this->fail('Missing input for a given multi option: ' . $html);
}
$this->assertContains('checked="checked"', $m[1]);
}
}
/**
* Used by test methods susceptible to ZF-2794, marks a test as incomplete
*
* @link http://framework.zend.com/issues/browse/ZF-2794
* @return void
*/
protected function _checkZf2794()
{
if (strtolower(substr(PHP_OS, 0, 3)) == 'win' && version_compare(PHP_VERSION, '5.1.4', '=')) {
$this->markTestIncomplete('Error occurs for PHP 5.1.4 on Windows');
}
}
/**#+
* @see ZF-3286
*/
public function testShouldRegisterInArrayValidatorByDefault()
{
$this->assertTrue($this->element->registerInArrayValidator());
}
public function testShouldAllowSpecifyingWhetherOrNotToUseInArrayValidator()
{
$this->testShouldRegisterInArrayValidatorByDefault();
$this->element->setRegisterInArrayValidator(false);
$this->assertFalse($this->element->registerInArrayValidator());
$this->element->setRegisterInArrayValidator(true);
$this->assertTrue($this->element->registerInArrayValidator());
}
public function testInArrayValidatorShouldBeRegisteredAfterValidation()
{
$options = array(
'foo' => 'Foo Value',
'bar' => 'Bar Value',
'baz' => 'Baz Value',
);
$this->element->setMultiOptions($options);
$this->assertFalse($this->element->getValidator('InArray'));
$this->element->isValid('test');
$validator = $this->element->getValidator('InArray');
$this->assertTrue($validator instanceof Zend_Validate_InArray);
}
public function testShouldNotValidateIfValueIsNotInArray()
{
$options = array(
'foo' => 'Foo Value',
'bar' => 'Bar Value',
'baz' => 'Baz Value',
);
$this->element->setMultiOptions($options);
$this->assertFalse($this->element->getValidator('InArray'));
$this->assertFalse($this->element->isValid('test'));
}
/**#@-*/
/**
* No assertion; just making sure no error occurs
*
* @group ZF-4915
*/
public function testRetrievingErrorMessagesShouldNotResultInError()
{
$this->element->addMultiOptions(array(
'foo' => 'Foo',
'bar' => 'Bar',
'baz' => 'Baz',
))
->addErrorMessage('%value% is invalid');
$this->element->isValid(array('foo', 'bogus'));
$html = $this->element->render($this->getView());
}
}
// Call Zend_Form_Element_MultiCheckboxTest::main() if this source file is executed directly.
if (PHPUnit_MAIN_METHOD == "Zend_Form_Element_MultiCheckboxTest::main") {
Zend_Form_Element_MultiCheckboxTest::main();
}