Current File : /home/jvzmxxx/wiki1/extensions/Validator/tests/phpunit/Definitions/TitleParamTest.php
<?php

namespace ParamProcessor\Tests\Definitions;

/**
 * @group Validator
 *
 * @licence GNU GPL v2+
 * @author Jeroen De Dauw < jeroendedauw@gmail.com >
 */
class TitleParamTest extends ParamDefinitionTest {

	/**
	 * @see ParamDefinitionTest::getDefinitions
	 */
	public function getDefinitions() {
		$params = parent::getDefinitions();

		$params['empty-empty'] = $params['empty'];
		$params['empty-empty']['hastoexist'] = false;

		$params['values-empty'] = $params['values'];
		$params['values-empty']['hastoexist'] = false;
		$params['values-empty']['values'][] = \Title::newFromText( 'foo' );

		return $params;
	}

	/**
	 * @see ParamDefinitionTest::valueProvider
	 *
	 * @param boolean $stringlyTyped
	 *
	 * @return array
	 */
	public function valueProvider( $stringlyTyped = true ) {
		$values = array(
			'empty-empty' => array(
				array( 'foo bar page', true, \Title::newFromText( 'foo bar page' ) ),
				array( '|', false ),
				array( '', false ),
			),
			'empty' => array(
				array( 'foo bar page', false ),
				array( '|', false ),
				array( '', false ),
			),
			'values-empty' => array(
				array( 'foo', true, \Title::newFromText( 'foo' ) ),
				array( 'foo bar page', false ),
			),
			'values' => array(
				array( 'foo', false ),
				array( 'foo bar page', false ),
			),
		);

		if ( !$stringlyTyped ) {
			foreach ( $values as &$set ) {
				foreach ( $set as &$value ) {
					$value[0] = \Title::newFromText( $value[0] );
				}
			}
		}

		return $values;
	}

	/**
	 * @see ParamDefinitionTest::getType
	 * @return string
	 */
	public function getType() {
		return 'title';
	}

}