class PHPUnit_Framework_Constraint_IsInstanceOf in Zircon Profile 8
Same name and namespace in other branches
- 8.0 vendor/phpunit/phpunit/src/Framework/Constraint/IsInstanceOf.php \PHPUnit_Framework_Constraint_IsInstanceOf
Constraint that asserts that the object it is evaluated for is an instance of a given class.
The expected class name is passed in the constructor.
@since Class available since Release 3.0.0
Hierarchy
- class \PHPUnit_Framework_Constraint implements \Countable, PHPUnit_Framework_SelfDescribing
Expanded class hierarchy of PHPUnit_Framework_Constraint_IsInstanceOf
File
- vendor/
phpunit/ phpunit/ src/ Framework/ Constraint/ IsInstanceOf.php, line 19
View source
class PHPUnit_Framework_Constraint_IsInstanceOf extends PHPUnit_Framework_Constraint {
/**
* @var string
*/
protected $className;
/**
* @param string $className
*/
public function __construct($className) {
parent::__construct();
$this->className = $className;
}
/**
* Evaluates the constraint for parameter $other. Returns true if the
* constraint is met, false otherwise.
*
* @param mixed $other Value or object to evaluate.
* @return bool
*/
protected function matches($other) {
return $other instanceof $this->className;
}
/**
* 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.
*
* @param mixed $other Evaluated value or object.
* @return string
*/
protected function failureDescription($other) {
return sprintf('%s is an instance of %s "%s"', $this->exporter
->shortenedExport($other), $this
->getType(), $this->className);
}
/**
* Returns a string representation of the constraint.
*
* @return string
*/
public function toString() {
return sprintf('is instance of %s "%s"', $this
->getType(), $this->className);
}
private function getType() {
try {
$reflection = new ReflectionClass($this->className);
if ($reflection
->isInterface()) {
return 'interface';
}
} catch (ReflectionException $e) {
}
return 'class';
}
}