summaryrefslogtreecommitdiff
path: root/www/wiki/extensions/ConfirmEdit/tests/QuestyCaptchaTest.php
diff options
context:
space:
mode:
authorYaco <franco@reevo.org>2020-06-04 11:01:00 -0300
committerYaco <franco@reevo.org>2020-06-04 11:01:00 -0300
commitfc7369835258467bf97eb64f184b93691f9a9fd5 (patch)
treedaabd60089d2dd76d9f5fb416b005fbe159c799d /www/wiki/extensions/ConfirmEdit/tests/QuestyCaptchaTest.php
first commit
Diffstat (limited to 'www/wiki/extensions/ConfirmEdit/tests/QuestyCaptchaTest.php')
-rw-r--r--www/wiki/extensions/ConfirmEdit/tests/QuestyCaptchaTest.php49
1 files changed, 49 insertions, 0 deletions
diff --git a/www/wiki/extensions/ConfirmEdit/tests/QuestyCaptchaTest.php b/www/wiki/extensions/ConfirmEdit/tests/QuestyCaptchaTest.php
new file mode 100644
index 00000000..b5567bda
--- /dev/null
+++ b/www/wiki/extensions/ConfirmEdit/tests/QuestyCaptchaTest.php
@@ -0,0 +1,49 @@
+<?php
+
+class QuestyCaptchaTest extends MediaWikiTestCase {
+ /**
+ * @covers QuestyCaptcha::getCaptcha
+ * @dataProvider provideGetCaptcha
+ */
+ public function testGetCaptcha( $config, $expected ) {
+
+ # setMwGlobals() requires $wgCaptchaQuestion to be set
+ if ( !isset( $GLOBALS['wgCaptchaQuestions'] ) ) {
+ $GLOBALS['wgCaptchaQuestions'] = [];
+ }
+ $this->setMwGlobals( 'wgCaptchaQuestions', $config );
+ $this->mergeMwGlobalArrayValue(
+ 'wgAutoloadClasses',
+ [ 'QuestyCaptcha' => __DIR__ . '/../QuestyCaptcha/QuestyCaptcha.class.php' ]
+ );
+
+ $qc = new QuestyCaptcha();
+ $this->assertEquals( $expected, $qc->getCaptcha() );
+ }
+
+ public static function provideGetCaptcha() {
+ return [
+ [
+ [
+ [
+ 'question' => 'FooBar',
+ 'answer' => 'Answer!',
+ ],
+ ],
+ [
+ 'question' => 'FooBar',
+ 'answer' => 'Answer!',
+ ],
+ ],
+ [
+ [
+ 'FooBar' => 'Answer!',
+ ],
+ [
+ 'question' => 'FooBar',
+ 'answer' => 'Answer!',
+ ],
+ ]
+ ];
+ }
+}