Skip to content

Commit

Permalink
Refactor unit tests
Browse files Browse the repository at this point in the history
  • Loading branch information
tvdijen committed Jan 20, 2025
1 parent 74ce7e7 commit 7139ecf
Show file tree
Hide file tree
Showing 101 changed files with 1,628 additions and 745 deletions.
27 changes: 26 additions & 1 deletion src/Type/AbstractValueType.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@

namespace SimpleSAML\XML\Type;

use function preg_replace;
use function trim;

/**
* Abstract class to be implemented by all types
*
Expand Down Expand Up @@ -69,7 +72,7 @@ protected function sanitizeValue(string $value): string
* @throws \Exception on failure
* @return void
*/
protected function validateValue(/** @scrutinizer ignore-unused */ string $value): void
protected function validateValue(/** @scrutinizer-ignore */string $value): void
{
/**
* Perform no validation by default.
Expand All @@ -78,6 +81,28 @@ protected function validateValue(/** @scrutinizer ignore-unused */ string $value
}


/**
* Normalize whitespace in the value
*
* @return string
*/
protected static function normalizeWhitespace(string $value): string
{
return preg_replace('/\s/', ' ', $value);
}


/**
* Collapse whitespace
*
* @return string
*/
protected static function collapseWhitespace(string $value): string
{
return trim(preg_replace('/\s+/', ' ', $value));
}


/**
* @param string $value
* @return static
Expand Down
12 changes: 12 additions & 0 deletions src/Type/AnyURIValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,18 @@
*/
class AnyURIValue extends AbstractValueType
{
/**
* Sanitize the value.
*
* @param string $value The unsanitized value
* @return string
*/
protected function sanitizeValue(string $value): string
{
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


/**
* Validate the value.
*
Expand Down
4 changes: 1 addition & 3 deletions src/Type/Base64BinaryValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,12 @@ class Base64BinaryValue extends AbstractValueType
/**
* Sanitize the value.
*
* Note: There are no processing rules for xs:base64 regarding whitespace. General consensus is to strip them
*
* @param string $value The unsanitized value
* @return string
*/
protected function sanitizeValue(string $value): string
{
return str_replace(["\f", "\r", "\n", "\t", "\v", ' '], '', $value);
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/BooleanValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ class BooleanValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return str_replace(["\f", "\r", "\n", "\t", "\v", ' '], '', $value);
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/DateTimeValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ class DateTimeValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return trim(preg_replace('/\s+/', ' ', $value));
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/DateValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class DateValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return trim(preg_replace('/\s+/', ' ', $value));
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/DayValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class DayValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return trim(preg_replace('/\s+/', ' ', $value));
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/DecimalValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ class DecimalValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return str_replace(["\f", "\r", "\n", "\t", "\v", ' '], '', $value);
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/DoubleValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ class DoubleValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return str_replace(["\f", "\r", "\n", "\t", "\v", ' '], '', $value);
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/DurationValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class DurationValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return trim(preg_replace('/\s+/', ' ', $value));
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/FloatValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ class FloatValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return str_replace(["\f", "\r", "\n", "\t", "\v", ' '], '', $value);
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
4 changes: 1 addition & 3 deletions src/Type/HexBinaryValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,12 @@ class HexBinaryValue extends AbstractValueType
/**
* Sanitize the value.
*
* Note: There are no processing rules for xs:hexBinary regarding whitespace. General consensus is to strip them
*
* @param string $value The unsanitized value
* @return string
*/
protected function sanitizeValue(string $value): string
{
return str_replace(["\f", "\r", "\n", "\t", "\v", ' '], '', $value);
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/LanguageValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ class LanguageValue extends TokenValue
*/
protected function validateValue(string $value): void
{
// Note: content must already be sanitized before validating
// Note: value must already be sanitized before validating
Assert::validLanguage($this->sanitizeValue($value), SchemaViolationException::class);
}
}
2 changes: 1 addition & 1 deletion src/Type/MonthValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class MonthValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return trim(preg_replace('/\s+/', ' ', $value));
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/NormalizedStringValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,6 @@ class NormalizedStringValue extends StringValue
*/
protected function sanitizeValue(string $value): string
{
return preg_replace('/\s/', ' ', $value);
return static::normalizeWhitespace($value);
}
}
48 changes: 48 additions & 0 deletions src/Type/QNameValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,27 @@
use SimpleSAML\XML\Assert\Assert;
use SimpleSAML\XML\Exception\SchemaViolationException;

use function explode;
use function preg_replace;
use function trim;

/**
* @package simplesaml/xml-common
*/
class QNameValue extends AbstractValueType
{
/**
* Sanitize the value.
*
* @param string $value The unsanitized value
* @return string
*/
protected function sanitizeValue(string $value): string
{
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


/**
* Validate the value.
*
Expand All @@ -24,4 +40,36 @@ protected function validateValue(string $value): void
// Note: value must already be sanitized before validating
Assert::validQName($this->sanitizeValue($value), SchemaViolationException::class);
}


/**
* Get the namespace-prefix for this qualified name.
*
* @return \SimpleSAML\XML\Type\NCNameValue|null
*/
public function getNamespacePrefix(): ?NCNameValue
{
$qname = explode(':', $this->getValue(), 2);
if (count($qname) === 2) {
return NCNameValue::fromString($qname[0]);
}

return null;
}


/**
* Get the local name for this qualified name.
*
* @return \SimpleSAML\XML\Type\NCNameValue
*/
public function getLocalName(): NCNameValue
{
$qname = explode(':', $this->getValue(), 2);
if (count($qname) === 2) {
return NCNameValue::fromString($qname[1]);
}

return NCNameValue::fromString($qname[0]);
}
}
14 changes: 13 additions & 1 deletion src/Type/TimeValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,18 @@
*/
class TimeValue extends AbstractValueType
{
/**
* Sanitize the value.
*
* @param string $value The unsanitized value
* @return string
*/
protected function sanitizeValue(string $value): string
{
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


/**
* Validate the value.
*
Expand All @@ -21,6 +33,6 @@ class TimeValue extends AbstractValueType
*/
protected function validateValue(string $value): void
{
Assert::validTime($value, SchemaViolationException::class);
Assert::validTime($this->sanitizeValue($value), SchemaViolationException::class);
}
}
2 changes: 1 addition & 1 deletion src/Type/TokenValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,6 @@ class TokenValue extends NormalizedStringValue
*/
protected function sanitizeValue(string $value): string
{
return trim(preg_replace('/\s+/', ' ', parent::sanitizeValue($value)));
return static::collapseWhitespace(static::normalizeWhitespace($value));
}
}
2 changes: 1 addition & 1 deletion src/Type/YearMonthValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class YearMonthValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return trim(preg_replace('/\s+/', ' ', $value));
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
2 changes: 1 addition & 1 deletion src/Type/YearValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class YearValue extends AbstractValueType
*/
protected function sanitizeValue(string $value): string
{
return trim(preg_replace('/\s+/', ' ', $value));
return static::collapseWhitespace(static::normalizeWhitespace($value));
}


Expand Down
4 changes: 2 additions & 2 deletions tests/Assert/AnyURITest.php
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ final class AnyURITest extends TestCase
* @param boolean $shouldPass
* @param string $uri
*/
#[DataProvider('provideURI')]
#[DataProvider('provideValidURI')]
public function testValidURI(bool $shouldPass, string $uri): void
{
try {
Expand All @@ -36,7 +36,7 @@ public function testValidURI(bool $shouldPass, string $uri): void
/**
* @return array<string, array{0: bool, 1: string}>
*/
public static function provideURI(): array
public static function provideValidURI(): array
{
return [
'urn' => [true, 'urn:x-simplesamlphp:phpunit'],
Expand Down
19 changes: 15 additions & 4 deletions tests/Assert/Base64BinaryTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@ final class Base64BinaryTest extends TestCase
* @param boolean $shouldPass
* @param string $base64
*/
#[DataProvider('provideBase64')]
#[DataProvider('provideInvalidBase64')]
#[DataProvider('provideValidBase64')]
public function testValidBase64Binary(bool $shouldPass, string $base64): void
{
try {
Expand All @@ -34,13 +35,23 @@ public function testValidBase64Binary(bool $shouldPass, string $base64): void


/**
* @return array<string, array{0: bool, 1: string}>
* @return array<string, array{0: true, 1: string}>
*/
public static function provideBase64(): array
public static function provideValidBase64(): array
{
return [
'empty' => [false, ''],
'valid' => [true, 'U2ltcGxlU0FNTHBocA=='],
];
}


/**
* @return array<string, array{0: false, 1: string}>
*/
public static function provideInvalidBase64(): array
{
return [
'empty' => [false, ''],
'illegal characters' => [false, '&*$(#&^@!(^%$'],
'length not dividable by 4' => [false, 'U2ltcGxlU0FTHBocA=='],
];
Expand Down
Loading

0 comments on commit 7139ecf

Please sign in to comment.