summaryrefslogtreecommitdiffstats
path: root/tests/Core/ClassValidationArrayTest.php
diff options
context:
space:
mode:
authorDan Printzell <xwildn00bx@gmail.com>2017-03-15 17:22:46 +0100
committerDan Printzell <xwildn00bx@gmail.com>2017-03-15 17:22:46 +0100
commitb5e1bec83a5059dfb08a6c7b58e8dfd32a3e4138 (patch)
tree1e370f029c850fe462dd193e2590b9079c38aed5 /tests/Core/ClassValidationArrayTest.php
parentb6336a9a994bda1d744c22b88785586fc95fd04f (diff)
downloadip1-php-sdk-b5e1bec83a5059dfb08a6c7b58e8dfd32a3e4138.zip
ip1-php-sdk-b5e1bec83a5059dfb08a6c7b58e8dfd32a3e4138.tar.gz
ip1-php-sdk-b5e1bec83a5059dfb08a6c7b58e8dfd32a3e4138.tar.bz2
Fixed capitalization of test folders
Signed-off-by: Dan Printzell <xwildn00bx@gmail.com>
Diffstat (limited to 'tests/Core/ClassValidationArrayTest.php')
-rw-r--r--tests/Core/ClassValidationArrayTest.php121
1 files changed, 121 insertions, 0 deletions
diff --git a/tests/Core/ClassValidationArrayTest.php b/tests/Core/ClassValidationArrayTest.php
new file mode 100644
index 0000000..33752a1
--- /dev/null
+++ b/tests/Core/ClassValidationArrayTest.php
@@ -0,0 +1,121 @@
+<?php
+/**
+* PHP version 7.1.1
+* @author Hannes Kindströmmer <hannes@kindstrommer.se>
+* @copyright 2017 IP1 SMS
+* @license https://www.gnu.org/licenses/lgpl-3.0.txt LGPL-3.0
+* @version 0.1.0-beta
+* @since File available since Release 0.1.0-beta
+* @link http://api.ip1sms.com/Help
+* @link https://github.com/iP1SMS/ip1-php-sdk
+*/
+use PHPUnit\Framework\TestCase;
+use IP1\RESTClient\Core\ClassValidationArray;
+
+class ClassValidationArrayTest extends TestCase
+{
+
+ /**
+ * @dataProvider getValidNonArrayInputs
+ * @covers ClassValidationArray::__construct
+ */
+ public function testConstructorNonArrayInputs($input)
+ {
+ $this->assertEquals([$input], (new ClassValidationArray($input))->getArrayCopy());
+ }
+ /**
+ * @dataProvider getValidArrayInputs
+ * @covers ClassValidationArray::__construct
+ */
+ public function testConstructorArrayInputs($inputs)
+ {
+ $this->assertEquals($inputs, (new ClassValidationArray($inputs))->getArrayCopy());
+ }
+ /**
+ * @dataProvider getInValidArrays
+ * @covers ClassValidationArray::__construct
+ */
+ public function testInvalidArrayInput($invalidArray)
+ {
+ $this->expectException(InvalidArgumentException::class);
+ new ClassValidationArray($invalidArray);
+ }
+ /**
+ * @dataProvider getScalarTypes
+ * @covers ClassValidationArray::__construct
+ */
+ public function testScalarVariables($scalarVariable)
+ {
+ $this->expectException(InvalidArgumentException::class);
+ $array = new ClassValidationArray($scalarVariable);
+ }
+ /**
+ * @dataProvider getNonEmptyValidArrays
+ * @covers ClassValidationArray::offsetSet
+ * @throws InvalidArgumentException
+ */
+ public function testAddWrongObjectClass($validArray)
+ {
+ $this->expectException(InvalidArgumentException::class);
+ $array = new ClassValidationArray($validArray);
+ $array[] = new ArrayObject();
+ }
+
+ /**
+ * @dataProvider getScalarTypes
+ * @covers ClassValidationArray::offsetSet
+ */
+ public function testAddScalarTypes($scalarVariable)
+ {
+ $this->expectException(InvalidArgumentException::class);
+ $array = new ClassValidationArray([]);
+ $array[] = $scalarVariable;
+ }
+ public function getNonEmptyValidArrays()
+ {
+ return [
+ [
+ [new stdClass,new stdClass,new stdClass,new stdClass,],
+ [new DateTime(),new DateTime(),new DateTime(),new DateTime(),],
+ [new stdClass],
+ ]
+ ];
+ }
+ public function getValidArrayInputs()
+ {
+ return [[
+ [],
+ [new stdClass,new stdClass,new stdClass,new stdClass,],
+ [new DateTime(),new DateTime(),new DateTime(),new DateTime(),],
+ [new stdClass],
+ ]];
+ }
+ public function getInValidArrays()
+ {
+ return [
+ [
+ [new stdClass, new DateTime],
+ [new stdClass, new stdClass, 1],
+ [new stdClass, new stdClass, true],
+ ['Jack', new stdClass],
+ [1,2,1,2,3,5,6,3,1,32],
+ ["","1231", "Jack",],
+ [false, false, false, false,],
+ [true, true, true, true],
+ [false, true, true, false],
+ ]
+ ];
+ }
+ public function getValidNonArrayInputs()
+ {
+ return [
+ [new DateTime(), new stdClass(), new ClassValidationArray()]
+ ];
+ }
+ public function getScalarTypes()
+ {
+ return [
+ [0,1,1.1, "", "filledString", false, true,],
+ ];
+ }
+}