Browse Source
- Database functions now accept any input, but throw typeViolation exceptions where appropriate instead of idMissing or subjectMissing - Added unit tests for the new Misc\ValueInfo static class - Added ValueInfo::id() method to centrally validate database IDs, and made use of it consistently - Made use of PHP's filter_var() function where appropriate when validating or sanitizing input - Made the NCN protocol handler reject most invalid IDs before handing off to method handlers - Made NCN's feedUpdate and subscriptionMove methods return 422 on invalid input - Adjusted several tests to handler type violationsmicrosub
J. King
7 years ago
13 changed files with 446 additions and 136 deletions
@ -0,0 +1,185 @@ |
|||||
|
<?php |
||||
|
declare(strict_types=1); |
||||
|
namespace JKingWeb\Arsse; |
||||
|
|
||||
|
use JKingWeb\Arsse\Misc\ValueInfo as I; |
||||
|
|
||||
|
/** @covers \JKingWeb\Arsse\Misc\ValueInfo */ |
||||
|
class TestValueInfo extends Test\AbstractTest { |
||||
|
public function testGetIntegerInfo() { |
||||
|
$tests = [ |
||||
|
[null, I::NULL], |
||||
|
["", I::NULL], |
||||
|
[1, I::VALID], |
||||
|
[PHP_INT_MAX, I::VALID], |
||||
|
[1.0, I::VALID], |
||||
|
["1.0", I::VALID], |
||||
|
["001.0", I::VALID], |
||||
|
["1.0e2", I::VALID], |
||||
|
["1", I::VALID], |
||||
|
["001", I::VALID], |
||||
|
["1e2", I::VALID], |
||||
|
["+1.0", I::VALID], |
||||
|
["+001.0", I::VALID], |
||||
|
["+1.0e2", I::VALID], |
||||
|
["+1", I::VALID], |
||||
|
["+001", I::VALID], |
||||
|
["+1e2", I::VALID], |
||||
|
[0, I::VALID | I::ZERO], |
||||
|
["0", I::VALID | I::ZERO], |
||||
|
["000", I::VALID | I::ZERO], |
||||
|
[0.0, I::VALID | I::ZERO], |
||||
|
["0.0", I::VALID | I::ZERO], |
||||
|
["000.000", I::VALID | I::ZERO], |
||||
|
["+0", I::VALID | I::ZERO], |
||||
|
["+000", I::VALID | I::ZERO], |
||||
|
["+0.0", I::VALID | I::ZERO], |
||||
|
["+000.000", I::VALID | I::ZERO], |
||||
|
[-1, I::VALID | I::NEG], |
||||
|
[-1.0, I::VALID | I::NEG], |
||||
|
["-1.0", I::VALID | I::NEG], |
||||
|
["-001.0", I::VALID | I::NEG], |
||||
|
["-1.0e2", I::VALID | I::NEG], |
||||
|
["-1", I::VALID | I::NEG], |
||||
|
["-001", I::VALID | I::NEG], |
||||
|
["-1e2", I::VALID | I::NEG], |
||||
|
[-0, I::VALID | I::ZERO], |
||||
|
["-0", I::VALID | I::ZERO], |
||||
|
["-000", I::VALID | I::ZERO], |
||||
|
[-0.0, I::VALID | I::ZERO], |
||||
|
["-0.0", I::VALID | I::ZERO], |
||||
|
["-000.000", I::VALID | I::ZERO], |
||||
|
[false, 0], |
||||
|
[true, 0], |
||||
|
[INF, 0], |
||||
|
[-INF, 0], |
||||
|
[NAN, 0], |
||||
|
[[], 0], |
||||
|
["some string", 0], |
||||
|
[" ", 0], |
||||
|
[new \StdClass, 0], |
||||
|
]; |
||||
|
foreach ($tests as $test) { |
||||
|
list($value, $exp) = $test; |
||||
|
$this->assertSame($exp, I::int($value), "Test returned ".decbin(I::int($value))." for value: ".var_export($value, true)); |
||||
|
} |
||||
|
} |
||||
|
public function testGetStringInfo() { |
||||
|
$tests = [ |
||||
|
[null, I::NULL], |
||||
|
["", I::VALID | I::EMPTY], |
||||
|
[1, I::VALID], |
||||
|
[PHP_INT_MAX, I::VALID], |
||||
|
[1.0, I::VALID], |
||||
|
["1.0", I::VALID], |
||||
|
["001.0", I::VALID], |
||||
|
["1.0e2", I::VALID], |
||||
|
["1", I::VALID], |
||||
|
["001", I::VALID], |
||||
|
["1e2", I::VALID], |
||||
|
["+1.0", I::VALID], |
||||
|
["+001.0", I::VALID], |
||||
|
["+1.0e2", I::VALID], |
||||
|
["+1", I::VALID], |
||||
|
["+001", I::VALID], |
||||
|
["+1e2", I::VALID], |
||||
|
[0, I::VALID], |
||||
|
["0", I::VALID], |
||||
|
["000", I::VALID], |
||||
|
[0.0, I::VALID], |
||||
|
["0.0", I::VALID], |
||||
|
["000.000", I::VALID], |
||||
|
["+0", I::VALID], |
||||
|
["+000", I::VALID], |
||||
|
["+0.0", I::VALID], |
||||
|
["+000.000", I::VALID], |
||||
|
[-1, I::VALID], |
||||
|
[-1.0, I::VALID], |
||||
|
["-1.0", I::VALID], |
||||
|
["-001.0", I::VALID], |
||||
|
["-1.0e2", I::VALID], |
||||
|
["-1", I::VALID], |
||||
|
["-001", I::VALID], |
||||
|
["-1e2", I::VALID], |
||||
|
[-0, I::VALID], |
||||
|
["-0", I::VALID], |
||||
|
["-000", I::VALID], |
||||
|
[-0.0, I::VALID], |
||||
|
["-0.0", I::VALID], |
||||
|
["-000.000", I::VALID], |
||||
|
[false, 0], |
||||
|
[true, 0], |
||||
|
[INF, 0], |
||||
|
[-INF, 0], |
||||
|
[NAN, 0], |
||||
|
[[], 0], |
||||
|
["some string", I::VALID], |
||||
|
[" ", I::VALID | I::WHITE], |
||||
|
[new \StdClass, 0], |
||||
|
]; |
||||
|
foreach ($tests as $test) { |
||||
|
list($value, $exp) = $test; |
||||
|
$this->assertSame($exp, I::str($value), "Test returned ".decbin(I::str($value))." for value: ".var_export($value, true)); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
public function testValidateDatabaseIdentifier() { |
||||
|
$tests = [ |
||||
|
[null, false, true], |
||||
|
["", false, true], |
||||
|
[1, true, true], |
||||
|
[PHP_INT_MAX, true, true], |
||||
|
[1.0, true, true], |
||||
|
["1.0", true, true], |
||||
|
["001.0", true, true], |
||||
|
["1.0e2", true, true], |
||||
|
["1", true, true], |
||||
|
["001", true, true], |
||||
|
["1e2", true, true], |
||||
|
["+1.0", true, true], |
||||
|
["+001.0", true, true], |
||||
|
["+1.0e2", true, true], |
||||
|
["+1", true, true], |
||||
|
["+001", true, true], |
||||
|
["+1e2", true, true], |
||||
|
[0, false, true], |
||||
|
["0", false, true], |
||||
|
["000", false, true], |
||||
|
[0.0, false, true], |
||||
|
["0.0", false, true], |
||||
|
["000.000", false, true], |
||||
|
["+0", false, true], |
||||
|
["+000", false, true], |
||||
|
["+0.0", false, true], |
||||
|
["+000.000", false, true], |
||||
|
[-1, false, false], |
||||
|
[-1.0, false, false], |
||||
|
["-1.0", false, false], |
||||
|
["-001.0", false, false], |
||||
|
["-1.0e2", false, false], |
||||
|
["-1", false, false], |
||||
|
["-001", false, false], |
||||
|
["-1e2", false, false], |
||||
|
[-0, false, true], |
||||
|
["-0", false, true], |
||||
|
["-000", false, true], |
||||
|
[-0.0, false, true], |
||||
|
["-0.0", false, true], |
||||
|
["-000.000", false, true], |
||||
|
[false, false, false], |
||||
|
[true, false, false], |
||||
|
[INF, false, false], |
||||
|
[-INF, false, false], |
||||
|
[NAN, false, false], |
||||
|
[[], false, false], |
||||
|
["some string", false, false], |
||||
|
[" ", false, false], |
||||
|
[new \StdClass, false, false], |
||||
|
]; |
||||
|
foreach ($tests as $test) { |
||||
|
list($value, $exp, $expNull) = $test; |
||||
|
$this->assertSame($exp, I::id($value), "Non-null test failed for value: ".var_export($value, true)); |
||||
|
$this->assertSame($expNull, I::id($value, true), "Null test failed for value: ".var_export($value, true)); |
||||
|
} |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue