summaryrefslogtreecommitdiffstats
path: root/apps/files_external/tests/definitionparameterttest.php
diff options
context:
space:
mode:
Diffstat (limited to 'apps/files_external/tests/definitionparameterttest.php')
-rw-r--r--apps/files_external/tests/definitionparameterttest.php70
1 files changed, 70 insertions, 0 deletions
diff --git a/apps/files_external/tests/definitionparameterttest.php b/apps/files_external/tests/definitionparameterttest.php
new file mode 100644
index 00000000000..6be00508698
--- /dev/null
+++ b/apps/files_external/tests/definitionparameterttest.php
@@ -0,0 +1,70 @@
+<?php
+/**
+ * @author Robin McCorkell <rmccorkell@owncloud.com>
+ *
+ * @copyright Copyright (c) 2015, ownCloud, Inc.
+ * @license AGPL-3.0
+ *
+ * This code is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License, version 3,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License, version 3,
+ * along with this program. If not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+namespace OCA\Files_External\Tests;
+
+use \OCA\Files_External\Lib\DefinitionParameter as Param;
+
+class DefinitionParameterTest extends \Test\TestCase {
+
+ public function testJsonSerialization() {
+ $param = new Param('foo', 'bar');
+ $this->assertEquals('bar', $param->jsonSerialize());
+
+ $param->setType(Param::VALUE_BOOLEAN);
+ $this->assertEquals('!bar', $param->jsonSerialize());
+
+ $param->setType(Param::VALUE_PASSWORD);
+ $param->setFlag(Param::FLAG_OPTIONAL);
+ $this->assertEquals('&*bar', $param->jsonSerialize());
+
+ $param->setType(Param::VALUE_HIDDEN);
+ $param->setFlags(Param::FLAG_NONE);
+ $this->assertEquals('#bar', $param->jsonSerialize());
+ }
+
+ public function validateValueProvider() {
+ return [
+ [Param::VALUE_TEXT, Param::FLAG_NONE, 'abc', true],
+ [Param::VALUE_TEXT, Param::FLAG_NONE, '', false],
+ [Param::VALUE_TEXT, Param::FLAG_OPTIONAL, '', true],
+
+ [Param::VALUE_BOOLEAN, Param::FLAG_NONE, false, true],
+ [Param::VALUE_BOOLEAN, Param::FLAG_NONE, 123, false],
+
+ [Param::VALUE_PASSWORD, Param::FLAG_NONE, 'foobar', true],
+ [Param::VALUE_PASSWORD, Param::FLAG_NONE, '', false],
+
+ [Param::VALUE_HIDDEN, Param::FLAG_NONE, '', false]
+ ];
+ }
+
+ /**
+ * @dataProvider validateValueProvider
+ */
+ public function testValidateValue($type, $flags, $value, $success) {
+ $param = new Param('foo', 'bar');
+ $param->setType($type);
+ $param->setFlags($flags);
+
+ $this->assertEquals($success, $param->validateValue($value));
+ }
+}