class Constraint
Same name in this branch
- 11.1.x vendor/composer/semver/src/Constraint/Constraint.php \Composer\Semver\Constraint\Constraint
- 11.1.x vendor/justinrainbow/json-schema/src/JsonSchema/Constraints/Constraint.php \JsonSchema\Constraints\Constraint
- 11.1.x vendor/symfony/validator/Constraint.php \Symfony\Component\Validator\Constraint
- 11.1.x core/lib/Drupal/Core/Validation/Annotation/Constraint.php \Drupal\Core\Validation\Annotation\Constraint
- 11.1.x core/lib/Drupal/Core/Validation/Attribute/Constraint.php \Drupal\Core\Validation\Attribute\Constraint
- 11.1.x core/lib/Drupal/Component/Version/Constraint.php \Drupal\Component\Version\Constraint
@no-named-arguments Parameter names are not covered by the backward compatibility promise for PHPUnit
Hierarchy
- class \PHPUnit\Framework\Constraint\Constraint implements \Countable, \PHPUnit\Framework\SelfDescribing
Expanded class hierarchy of Constraint
37 files declare their use of Constraint
- Assert.php in vendor/
phpunit/ phpunit/ src/ Framework/ Assert.php - BrowserCookieValueSame.php in vendor/
symfony/ browser-kit/ Test/ Constraint/ BrowserCookieValueSame.php - BrowserHasCookie.php in vendor/
symfony/ browser-kit/ Test/ Constraint/ BrowserHasCookie.php - CommandIsSuccessful.php in vendor/
symfony/ console/ Tester/ Constraint/ CommandIsSuccessful.php - CrawlerAnySelectorTextContains.php in vendor/
symfony/ dom-crawler/ Test/ Constraint/ CrawlerAnySelectorTextContains.php
2 string references to 'Constraint'
- Problem::getMissingPackageReason in vendor/
composer/ composer/ src/ Composer/ DependencyResolver/ Problem.php - @internal
- RuleReasonDataReturnTypeExtension::getTypeFromMethodCall in vendor/
composer/ composer/ src/ Composer/ PHPStan/ RuleReasonDataReturnTypeExtension.php
File
-
vendor/
phpunit/ phpunit/ src/ Framework/ Constraint/ Constraint.php, line 24
Namespace
PHPUnit\Framework\ConstraintView source
abstract class Constraint implements Countable, SelfDescribing {
/**
* Evaluates the constraint for parameter $other.
*
* If $returnResult is set to false (the default), an exception is thrown
* in case of a failure. null is returned otherwise.
*
* If $returnResult is true, the result of the evaluation is returned as
* a boolean value instead: true in case of success, false in case of a
* failure.
*
* @throws ExpectationFailedException
*/
public function evaluate(mixed $other, string $description = '', bool $returnResult = false) : ?bool {
$success = false;
if ($this->matches($other)) {
$success = true;
}
if ($returnResult) {
return $success;
}
if (!$success) {
$this->fail($other, $description);
}
return null;
}
/**
* Counts the number of constraint elements.
*/
public function count() : int {
return 1;
}
/**
* @deprecated
*/
protected function exporter() : \SebastianBergmann\Exporter\Exporter {
return new \SebastianBergmann\Exporter\Exporter();
}
/**
* Evaluates the constraint for parameter $other. Returns true if the
* constraint is met, false otherwise.
*
* This method can be overridden to implement the evaluation algorithm.
*/
protected function matches(mixed $other) : bool {
return false;
}
/**
* Throws an exception for the given compared value and test description.
*
* @throws ExpectationFailedException
*/
protected function fail(mixed $other, string $description, ?ComparisonFailure $comparisonFailure = null) : never {
$failureDescription = sprintf('Failed asserting that %s.', $this->failureDescription($other));
$additionalFailureDescription = $this->additionalFailureDescription($other);
if ($additionalFailureDescription) {
$failureDescription .= "\n" . $additionalFailureDescription;
}
if (!empty($description)) {
$failureDescription = $description . "\n" . $failureDescription;
}
throw new ExpectationFailedException($failureDescription, $comparisonFailure);
}
/**
* Return additional failure description where needed.
*
* The function can be overridden to provide additional failure
* information like a diff
*/
protected function additionalFailureDescription(mixed $other) : string {
return '';
}
/**
* Returns the description of the failure.
*
* The beginning of failure messages is "Failed asserting that" in most
* cases. This method should return the second part of that sentence.
*
* To provide additional failure information additionalFailureDescription
* can be used.
*/
protected function failureDescription(mixed $other) : string {
return Exporter::export($other, true) . ' ' . $this->toString(true);
}
/**
* Returns a custom string representation of the constraint object when it
* appears in context of an $operator expression.
*
* The purpose of this method is to provide meaningful descriptive string
* in context of operators such as LogicalNot. Native PHPUnit constraints
* are supported out of the box by LogicalNot, but externally developed
* ones had no way to provide correct strings in this context.
*
* The method shall return empty string, when it does not handle
* customization by itself.
*/
protected function toStringInContext(Operator $operator, mixed $role) : string {
return '';
}
/**
* Returns the description of the failure when this constraint appears in
* context of an $operator expression.
*
* The purpose of this method is to provide meaningful failure description
* in context of operators such as LogicalNot. Native PHPUnit constraints
* are supported out of the box by LogicalNot, but externally developed
* ones had no way to provide correct messages in this context.
*
* The method shall return empty string, when it does not handle
* customization by itself.
*/
protected function failureDescriptionInContext(Operator $operator, mixed $role, mixed $other) : string {
$string = $this->toStringInContext($operator, $role);
if ($string === '') {
return '';
}
return Exporter::export($other, true) . ' ' . $string;
}
/**
* Reduces the sub-expression starting at $this by skipping degenerate
* sub-expression and returns first descendant constraint that starts
* a non-reducible sub-expression.
*
* Returns $this for terminal constraints and for operators that start
* non-reducible sub-expression, or the nearest descendant of $this that
* starts a non-reducible sub-expression.
*
* A constraint expression may be modelled as a tree with non-terminal
* nodes (operators) and terminal nodes. For example:
*
* LogicalOr (operator, non-terminal)
* + LogicalAnd (operator, non-terminal)
* | + IsType('int') (terminal)
* | + GreaterThan(10) (terminal)
* + LogicalNot (operator, non-terminal)
* + IsType('array') (terminal)
*
* A degenerate sub-expression is a part of the tree, that effectively does
* not contribute to the evaluation of the expression it appears in. An example
* of degenerate sub-expression is a BinaryOperator constructed with single
* operand or nested BinaryOperators, each with single operand. An
* expression involving a degenerate sub-expression is equivalent to a
* reduced expression with the degenerate sub-expression removed, for example
*
* LogicalAnd (operator)
* + LogicalOr (degenerate operator)
* | + LogicalAnd (degenerate operator)
* | + IsType('int') (terminal)
* + GreaterThan(10) (terminal)
*
* is equivalent to
*
* LogicalAnd (operator)
* + IsType('int') (terminal)
* + GreaterThan(10) (terminal)
*
* because the subexpression
*
* + LogicalOr
* + LogicalAnd
* + -
*
* is degenerate. Calling reduce() on the LogicalOr object above, as well
* as on LogicalAnd, shall return the IsType('int') instance.
*
* Other specific reductions can be implemented, for example cascade of
* LogicalNot operators
*
* + LogicalNot
* + LogicalNot
* +LogicalNot
* + IsTrue
*
* can be reduced to
*
* LogicalNot
* + IsTrue
*/
protected function reduce() : self {
return $this;
}
/**
* @psalm-return non-empty-string
*/
protected function valueToTypeStringFragment(mixed $value) : string {
$type = strtolower(gettype($value));
if ($type === 'double') {
$type = 'float';
}
if ($type === 'resource (closed)') {
$type = 'closed resource';
}
return match ($type) { 'array', 'integer', 'object' => 'an ' . $type . ' ',
'boolean', 'closed resource', 'float', 'resource', 'string' => 'a ' . $type . ' ',
'null' => 'null ',
default => 'a value of ' . $type . ' ',
};
}
}
Members
Title Sort descending | Modifiers | Object type | Summary | Overrides |
---|---|---|---|---|
Constraint::additionalFailureDescription | protected | function | Return additional failure description where needed. | 7 |
Constraint::count | public | function | Counts the number of constraint elements. | 3 |
Constraint::evaluate | public | function | Evaluates the constraint for parameter $other. | 7 |
Constraint::exporter | protected | function | ||
Constraint::fail | protected | function | Throws an exception for the given compared value and test description. | 1 |
Constraint::failureDescription | protected | function | Returns the description of the failure. | 51 |
Constraint::failureDescriptionInContext | protected | function | Returns the description of the failure when this constraint appears in context of an $operator expression. |
|
Constraint::matches | protected | function | Evaluates the constraint for parameter $other. Returns true if the constraint is met, false otherwise. |
70 |
Constraint::reduce | protected | function | Reduces the sub-expression starting at $this by skipping degenerate sub-expression and returns first descendant constraint that starts a non-reducible sub-expression. |
2 |
Constraint::toStringInContext | protected | function | Returns a custom string representation of the constraint object when it appears in context of an $operator expression. |
|
Constraint::valueToTypeStringFragment | protected | function | @psalm-return non-empty-string | |
SelfDescribing::toString | public | function | Returns a string representation of the object. | 84 |