mediawiki-extensions-Confir.../tests/phpunit/HTMLFancyCaptchaFieldTest.php
Reedy 6a8c53f6d1 Remove 'UnitTestList' hook
No longer needed now that extension unittests are autodiscovered.

Bug: T142120
Bug: T142121
Change-Id: I7105170e56c8c3ec3837dd15be869e503bccecde
2016-08-05 18:46:15 +01:00

43 lines
1.6 KiB
PHP

<?php
require_once __DIR__ . '/../../FancyCaptcha/HTMLFancyCaptchaField.php';
class HTMLFancyCaptchaFieldTest extends PHPUnit_Framework_TestCase {
public function testGetHTML() {
$html = $this->getForm( [ 'imageUrl' => 'https://example.com/' ] )->getHTML( false );
$this->assertRegExp( '/"fancycaptcha-image"/', $html );
$this->assertRegExp( '#src="https://example.com/"#', $html );
$this->assertNotRegExp( '/"mw-createacct-captcha-assisted"/', $html );
$html = $this->getForm( [ 'imageUrl' => '', 'showCreateHelp' => true ] )->getHTML( false );
$this->assertRegExp( '/"mw-createacct-captcha-assisted"/', $html );
$html = $this->getForm( [ 'imageUrl' => '', 'label' => 'FooBarBaz' ] )->getHTML( false );
$this->assertRegExp( '/FooBarBaz/', $html );
}
public function testValue() {
$mockClosure = $this->getMockBuilder( 'object' )->setMethods( [ '__invoke' ] )->getMock();
$request = new FauxRequest( [ 'wpcaptchaWord' => 'abc' ], true );
$form = $this->getForm( [ 'imageUrl' => 'https://example.com/' ], $request );
$form->setSubmitCallback( $mockClosure );
$mockClosure->expects( $this->once() )->method( '__invoke' )
->with( [ 'captchaWord' => 'abc' ] )->willReturn( true );
$form->trySubmit();
}
protected function getForm( $params = [], WebRequest $request = null ) {
$params['class'] = HTMLFancyCaptchaField::class;
$form = new HTMLForm( [ 'captchaWord' => $params ] );
if ( $request ) {
$context = new DerivativeContext( RequestContext::getMain() );
$context->setRequest( $request );
$form->setContext( $context );
}
$form->setTitle( Title::newFromText( 'Foo' ) );
$form->prepareForm();
return $form;
}
}