definitionparameterttest.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. /**
  3. * @author Robin McCorkell <robin@mccorkell.me.uk>
  4. *
  5. * @copyright Copyright (c) 2016, ownCloud, Inc.
  6. * @license AGPL-3.0
  7. *
  8. * This code is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU Affero General Public License, version 3,
  10. * as published by the Free Software Foundation.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU Affero General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Affero General Public License, version 3,
  18. * along with this program. If not, see <http://www.gnu.org/licenses/>
  19. *
  20. */
  21. namespace OCA\Files_External\Tests;
  22. use \OCA\Files_External\Lib\DefinitionParameter as Param;
  23. class DefinitionParameterTest extends \Test\TestCase {
  24. public function testJsonSerialization() {
  25. $param = new Param('foo', 'bar');
  26. $this->assertEquals([
  27. 'value' => 'bar',
  28. 'flags' => 0,
  29. 'type' => 0
  30. ], $param->jsonSerialize());
  31. $param->setType(Param::VALUE_BOOLEAN);
  32. $this->assertEquals([
  33. 'value' => 'bar',
  34. 'flags' => 0,
  35. 'type' => Param::VALUE_BOOLEAN
  36. ], $param->jsonSerialize());
  37. $param->setType(Param::VALUE_PASSWORD);
  38. $param->setFlag(Param::FLAG_OPTIONAL);
  39. $this->assertEquals([
  40. 'value' => 'bar',
  41. 'flags' => Param::FLAG_OPTIONAL,
  42. 'type' => Param::VALUE_PASSWORD
  43. ], $param->jsonSerialize());
  44. $param->setType(Param::VALUE_HIDDEN);
  45. $param->setFlags(Param::FLAG_NONE);
  46. $this->assertEquals([
  47. 'value' => 'bar',
  48. 'flags' => Param::FLAG_NONE,
  49. 'type' => Param::VALUE_HIDDEN
  50. ], $param->jsonSerialize());
  51. }
  52. public function validateValueProvider() {
  53. return [
  54. [Param::VALUE_TEXT, Param::FLAG_NONE, 'abc', true],
  55. [Param::VALUE_TEXT, Param::FLAG_NONE, '', false],
  56. [Param::VALUE_TEXT, Param::FLAG_OPTIONAL, '', true],
  57. [Param::VALUE_BOOLEAN, Param::FLAG_NONE, false, true],
  58. [Param::VALUE_BOOLEAN, Param::FLAG_NONE, 123, false],
  59. // conversion from string to boolean
  60. [Param::VALUE_BOOLEAN, Param::FLAG_NONE, 'false', true, false],
  61. [Param::VALUE_BOOLEAN, Param::FLAG_NONE, 'true', true, true],
  62. [Param::VALUE_PASSWORD, Param::FLAG_NONE, 'foobar', true],
  63. [Param::VALUE_PASSWORD, Param::FLAG_NONE, '', false],
  64. [Param::VALUE_HIDDEN, Param::FLAG_NONE, '', false]
  65. ];
  66. }
  67. /**
  68. * @dataProvider validateValueProvider
  69. */
  70. public function testValidateValue($type, $flags, $value, $success, $expectedValue = null) {
  71. $param = new Param('foo', 'bar');
  72. $param->setType($type);
  73. $param->setFlags($flags);
  74. $this->assertEquals($success, $param->validateValue($value));
  75. if (isset($expectedValue)) {
  76. $this->assertEquals($expectedValue, $value);
  77. }
  78. }
  79. }