| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901 | 
							- <?php
 - /**
 -  *    base include file for SimpleTest
 -  *    @package    SimpleTest
 -  *    @subpackage    UnitTester
 -  *    @version    $Id: expectation.php 1788 2008-04-27 11:01:59Z pp11 $
 -  */
 - 
 - /**#@+
 -  *    include other SimpleTest class files
 -  */
 - require_once(dirname(__FILE__) . '/dumper.php');
 - require_once(dirname(__FILE__) . '/compatibility.php');
 - /**#@-*/
 - 
 - /**
 -  *    Assertion that can display failure information.
 -  *    Also includes various helper methods.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  *    @abstract
 -  */
 - class SimpleExpectation {
 -     protected $dumper = false;
 -     private $message;
 - 
 -     /**
 -      *    Creates a dumper for displaying values and sets
 -      *    the test message.
 -      *    @param string $message    Customised message on failure.
 -      */
 -     function __construct($message = '%s') {
 -         $this->message = $message;
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if correct.
 -      *    @param mixed $compare        Comparison value.
 -      *    @return boolean              True if correct.
 -      *    @access public
 -      *    @abstract
 -      */
 -     function test($compare) {
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      *    @abstract
 -      */
 -     function testMessage($compare) {
 -     }
 - 
 -     /**
 -      *    Overlays the generated message onto the stored user
 -      *    message. An additional message can be interjected.
 -      *    @param mixed $compare        Comparison value.
 -      *    @param SimpleDumper $dumper  For formatting the results.
 -      *    @return string               Description of success
 -      *                                 or failure.
 -      *    @access public
 -      */
 -     function overlayMessage($compare, $dumper) {
 -         $this->dumper = $dumper;
 -         return sprintf($this->message, $this->testMessage($compare));
 -     }
 - 
 -     /**
 -      *    Accessor for the dumper.
 -      *    @return SimpleDumper    Current value dumper.
 -      *    @access protected
 -      */
 -     protected function getDumper() {
 -         if (! $this->dumper) {
 -             $dumper = new SimpleDumper();
 -             return $dumper;
 -         }
 -         return $this->dumper;
 -     }
 - 
 -     /**
 -      *    Test to see if a value is an expectation object.
 -      *    A useful utility method.
 -      *    @param mixed $expectation    Hopefully an Expectation
 -      *                                 class.
 -      *    @return boolean              True if descended from
 -      *                                 this class.
 -      *    @access public
 -      */
 -     static function isExpectation($expectation) {
 -         return is_object($expectation) &&
 -                 SimpleTestCompatibility::isA($expectation, 'SimpleExpectation');
 -     }
 - }
 - 
 - /**
 -  *    A wildcard expectation always matches.
 -  *    @package SimpleTest
 -  *    @subpackage MockObjects
 -  */
 - class AnythingExpectation extends SimpleExpectation {
 - 
 -     /**
 -      *    Tests the expectation. Always true.
 -      *    @param mixed $compare  Ignored.
 -      *    @return boolean        True.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return true;
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         return 'Anything always matches [' . $dumper->describeValue($compare) . ']';
 -     }
 - }
 - 
 - /**
 -  *    An expectation that never matches.
 -  *    @package SimpleTest
 -  *    @subpackage MockObjects
 -  */
 - class FailedExpectation extends SimpleExpectation {
 - 
 -     /**
 -      *    Tests the expectation. Always false.
 -      *    @param mixed $compare  Ignored.
 -      *    @return boolean        True.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return false;
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         return 'Failed expectation never matches [' . $dumper->describeValue($compare) . ']';
 -     }
 - }
 - 
 - /**
 -  *    An expectation that passes on boolean true.
 -  *    @package SimpleTest
 -  *    @subpackage MockObjects
 -  */
 - class TrueExpectation extends SimpleExpectation {
 - 
 -     /**
 -      *    Tests the expectation.
 -      *    @param mixed $compare  Should be true.
 -      *    @return boolean        True on match.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return (boolean)$compare;
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         return 'Expected true, got [' . $dumper->describeValue($compare) . ']';
 -     }
 - }
 - 
 - /**
 -  *    An expectation that passes on boolean false.
 -  *    @package SimpleTest
 -  *    @subpackage MockObjects
 -  */
 - class FalseExpectation extends SimpleExpectation {
 - 
 -     /**
 -      *    Tests the expectation.
 -      *    @param mixed $compare  Should be false.
 -      *    @return boolean        True on match.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return ! (boolean)$compare;
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         return 'Expected false, got [' . $dumper->describeValue($compare) . ']';
 -     }
 - }
 - 
 - /**
 -  *    Test for equality.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class EqualExpectation extends SimpleExpectation {
 -     private $value;
 - 
 -     /**
 -      *    Sets the value to compare against.
 -      *    @param mixed $value        Test value to match.
 -      *    @param string $message     Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($value, $message = '%s') {
 -         parent::__construct($message);
 -         $this->value = $value;
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if it matches the
 -      *    held value.
 -      *    @param mixed $compare        Comparison value.
 -      *    @return boolean              True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return (($this->value == $compare) && ($compare == $this->value));
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         if ($this->test($compare)) {
 -             return "Equal expectation [" . $this->dumper->describeValue($this->value) . "]";
 -         } else {
 -             return "Equal expectation fails " .
 -                     $this->dumper->describeDifference($this->value, $compare);
 -         }
 -     }
 - 
 -     /**
 -      *    Accessor for comparison value.
 -      *    @return mixed       Held value to compare with.
 -      *    @access protected
 -      */
 -     protected function getValue() {
 -         return $this->value;
 -     }
 - }
 - 
 - /**
 -  *    Test for inequality.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class NotEqualExpectation extends EqualExpectation {
 - 
 -     /**
 -      *    Sets the value to compare against.
 -      *    @param mixed $value       Test value to match.
 -      *    @param string $message    Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($value, $message = '%s') {
 -         parent::__construct($value, $message);
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if it differs from the
 -      *    held value.
 -      *    @param mixed $compare        Comparison value.
 -      *    @return boolean              True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return ! parent::test($compare);
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         if ($this->test($compare)) {
 -             return "Not equal expectation passes " .
 -                     $dumper->describeDifference($this->getValue(), $compare);
 -         } else {
 -             return "Not equal expectation fails [" .
 -                     $dumper->describeValue($this->getValue()) .
 -                     "] matches";
 -         }
 -     }
 - }
 - 
 - /**
 -  *    Test for being within a range.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class WithinMarginExpectation extends SimpleExpectation {
 -     private $upper;
 -     private $lower;
 - 
 -     /**
 -      *    Sets the value to compare against and the fuzziness of
 -      *    the match. Used for comparing floating point values.
 -      *    @param mixed $value        Test value to match.
 -      *    @param mixed $margin       Fuzziness of match.
 -      *    @param string $message     Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($value, $margin, $message = '%s') {
 -         parent::__construct($message);
 -         $this->upper = $value + $margin;
 -         $this->lower = $value - $margin;
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if it matches the
 -      *    held value.
 -      *    @param mixed $compare        Comparison value.
 -      *    @return boolean              True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return (($compare <= $this->upper) && ($compare >= $this->lower));
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         if ($this->test($compare)) {
 -             return $this->withinMessage($compare);
 -         } else {
 -             return $this->outsideMessage($compare);
 -         }
 -     }
 - 
 -     /**
 -      *    Creates a the message for being within the range.
 -      *    @param mixed $compare        Value being tested.
 -      *    @access private
 -      */
 -     protected function withinMessage($compare) {
 -         return "Within expectation [" . $this->dumper->describeValue($this->lower) . "] and [" .
 -                 $this->dumper->describeValue($this->upper) . "]";
 -     }
 - 
 -     /**
 -      *    Creates a the message for being within the range.
 -      *    @param mixed $compare        Value being tested.
 -      *    @access private
 -      */
 -     protected function outsideMessage($compare) {
 -         if ($compare > $this->upper) {
 -             return "Outside expectation " .
 -                     $this->dumper->describeDifference($compare, $this->upper);
 -         } else {
 -             return "Outside expectation " .
 -                     $this->dumper->describeDifference($compare, $this->lower);
 -         }
 -     }
 - }
 - 
 - /**
 -  *    Test for being outside of a range.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class OutsideMarginExpectation extends WithinMarginExpectation {
 - 
 -     /**
 -      *    Sets the value to compare against and the fuzziness of
 -      *    the match. Used for comparing floating point values.
 -      *    @param mixed $value        Test value to not match.
 -      *    @param mixed $margin       Fuzziness of match.
 -      *    @param string $message     Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($value, $margin, $message = '%s') {
 -         parent::__construct($value, $margin, $message);
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if it matches the
 -      *    held value.
 -      *    @param mixed $compare        Comparison value.
 -      *    @return boolean              True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return ! parent::test($compare);
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         if (! $this->test($compare)) {
 -             return $this->withinMessage($compare);
 -         } else {
 -             return $this->outsideMessage($compare);
 -         }
 -     }
 - }
 - 
 - /**
 -  *    Test for reference.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class ReferenceExpectation {
 -     private $value;
 - 
 -     /**
 -      *    Sets the reference value to compare against.
 -      *    @param mixed $value       Test reference to match.
 -      *    @param string $message    Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct(&$value, $message = '%s') {
 -         $this->message = $message;
 -         $this->value = &$value;
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if it exactly
 -      *    references the held value.
 -      *    @param mixed $compare        Comparison reference.
 -      *    @return boolean              True if correct.
 -      *    @access public
 -      */
 -     function test(&$compare) {
 -         return SimpleTestCompatibility::isReference($this->value, $compare);
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         if ($this->test($compare)) {
 -             return "Reference expectation [" . $this->dumper->describeValue($this->value) . "]";
 -         } else {
 -             return "Reference expectation fails " .
 -                     $this->dumper->describeDifference($this->value, $compare);
 -         }
 -     }
 - 
 -     /**
 -      *    Overlays the generated message onto the stored user
 -      *    message. An additional message can be interjected.
 -      *    @param mixed $compare        Comparison value.
 -      *    @param SimpleDumper $dumper  For formatting the results.
 -      *    @return string               Description of success
 -      *                                 or failure.
 -      *    @access public
 -      */
 -     function overlayMessage($compare, $dumper) {
 -         $this->dumper = $dumper;
 -         return sprintf($this->message, $this->testMessage($compare));
 -     }
 - 
 -     /**
 -      *    Accessor for the dumper.
 -      *    @return SimpleDumper    Current value dumper.
 -      *    @access protected
 -      */
 -     protected function getDumper() {
 -         if (! $this->dumper) {
 -             $dumper = new SimpleDumper();
 -             return $dumper;
 -         }
 -         return $this->dumper;
 -     }
 - }
 - 
 - /**
 -  *    Test for identity.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class IdenticalExpectation extends EqualExpectation {
 - 
 -     /**
 -      *    Sets the value to compare against.
 -      *    @param mixed $value       Test value to match.
 -      *    @param string $message    Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($value, $message = '%s') {
 -         parent::__construct($value, $message);
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if it exactly
 -      *    matches the held value.
 -      *    @param mixed $compare        Comparison value.
 -      *    @return boolean              True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return SimpleTestCompatibility::isIdentical($this->getValue(), $compare);
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         if ($this->test($compare)) {
 -             return "Identical expectation [" . $dumper->describeValue($this->getValue()) . "]";
 -         } else {
 -             return "Identical expectation [" . $dumper->describeValue($this->getValue()) .
 -                     "] fails with [" .
 -                     $dumper->describeValue($compare) . "] " .
 -                     $dumper->describeDifference($this->getValue(), $compare, TYPE_MATTERS);
 -         }
 -     }
 - }
 - 
 - /**
 -  *    Test for non-identity.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class NotIdenticalExpectation extends IdenticalExpectation {
 - 
 -     /**
 -      *    Sets the value to compare against.
 -      *    @param mixed $value        Test value to match.
 -      *    @param string $message     Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($value, $message = '%s') {
 -         parent::__construct($value, $message);
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if it differs from the
 -      *    held value.
 -      *    @param mixed $compare        Comparison value.
 -      *    @return boolean              True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return ! parent::test($compare);
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         if ($this->test($compare)) {
 -             return "Not identical expectation passes " .
 -                     $dumper->describeDifference($this->getValue(), $compare, TYPE_MATTERS);
 -         } else {
 -             return "Not identical expectation [" . $dumper->describeValue($this->getValue()) . "] matches";
 -         }
 -     }
 - }
 - 
 - /**
 -  *    Test for a pattern using Perl regex rules.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class PatternExpectation extends SimpleExpectation {
 -     private $pattern;
 - 
 -     /**
 -      *    Sets the value to compare against.
 -      *    @param string $pattern    Pattern to search for.
 -      *    @param string $message    Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($pattern, $message = '%s') {
 -         parent::__construct($message);
 -         $this->pattern = $pattern;
 -     }
 - 
 -     /**
 -      *    Accessor for the pattern.
 -      *    @return string       Perl regex as string.
 -      *    @access protected
 -      */
 -     protected function getPattern() {
 -         return $this->pattern;
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if the Perl regex
 -      *    matches the comparison value.
 -      *    @param string $compare        Comparison value.
 -      *    @return boolean               True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return (boolean)preg_match($this->getPattern(), $compare);
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         if ($this->test($compare)) {
 -             return $this->describePatternMatch($this->getPattern(), $compare);
 -         } else {
 -             $dumper = $this->getDumper();
 -             return "Pattern [" . $this->getPattern() .
 -                     "] not detected in [" .
 -                     $dumper->describeValue($compare) . "]";
 -         }
 -     }
 - 
 -     /**
 -      *    Describes a pattern match including the string
 -      *    found and it's position.
 -      *    @param string $pattern        Regex to match against.
 -      *    @param string $subject        Subject to search.
 -      *    @access protected
 -      */
 -     protected function describePatternMatch($pattern, $subject) {
 -         preg_match($pattern, $subject, $matches);
 -         $position = strpos($subject, $matches[0]);
 -         $dumper = $this->getDumper();
 -         return "Pattern [$pattern] detected at character [$position] in [" .
 -                 $dumper->describeValue($subject) . "] as [" .
 -                 $matches[0] . "] in region [" .
 -                 $dumper->clipString($subject, 100, $position) . "]";
 -     }
 - }
 - 
 - /**
 -  *    Fail if a pattern is detected within the
 -  *    comparison.
 -  *    @package SimpleTest
 -  *    @subpackage UnitTester
 -  */
 - class NoPatternExpectation extends PatternExpectation {
 - 
 -     /**
 -      *    Sets the reject pattern
 -      *    @param string $pattern    Pattern to search for.
 -      *    @param string $message    Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($pattern, $message = '%s') {
 -         parent::__construct($pattern, $message);
 -     }
 - 
 -     /**
 -      *    Tests the expectation. False if the Perl regex
 -      *    matches the comparison value.
 -      *    @param string $compare        Comparison value.
 -      *    @return boolean               True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return ! parent::test($compare);
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param string $compare      Comparison value.
 -      *    @return string              Description of success
 -      *                                or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         if ($this->test($compare)) {
 -             $dumper = $this->getDumper();
 -             return "Pattern [" . $this->getPattern() .
 -                     "] not detected in [" .
 -                     $dumper->describeValue($compare) . "]";
 -         } else {
 -             return $this->describePatternMatch($this->getPattern(), $compare);
 -         }
 -     }
 - }
 - 
 - /**
 -  *    Tests either type or class name if it's an object.
 -  *      @package SimpleTest
 -  *      @subpackage UnitTester
 -  */
 - class IsAExpectation extends SimpleExpectation {
 -     private $type;
 - 
 -     /**
 -      *    Sets the type to compare with.
 -      *    @param string $type       Type or class name.
 -      *    @param string $message    Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($type, $message = '%s') {
 -         parent::__construct($message);
 -         $this->type = $type;
 -     }
 - 
 -     /**
 -      *    Accessor for type to check against.
 -      *    @return string    Type or class name.
 -      *    @access protected
 -      */
 -     protected function getType() {
 -         return $this->type;
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if the type or
 -      *    class matches the string value.
 -      *    @param string $compare        Comparison value.
 -      *    @return boolean               True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         if (is_object($compare)) {
 -             return SimpleTestCompatibility::isA($compare, $this->type);
 -         } else {
 -             return (strtolower(gettype($compare)) == $this->canonicalType($this->type));
 -         }
 -     }
 - 
 -     /**
 -      *    Coerces type name into a gettype() match.
 -      *    @param string $type        User type.
 -      *    @return string             Simpler type.
 -      *    @access private
 -      */
 -     protected function canonicalType($type) {
 -         $type = strtolower($type);
 -         $map = array(
 -                 'bool' => 'boolean',
 -                 'float' => 'double',
 -                 'real' => 'double',
 -                 'int' => 'integer');
 -         if (isset($map[$type])) {
 -             $type = $map[$type];
 -         }
 -         return $type;
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         return "Value [" . $dumper->describeValue($compare) .
 -                 "] should be type [" . $this->type . "]";
 -     }
 - }
 - 
 - /**
 -  *    Tests either type or class name if it's an object.
 -  *    Will succeed if the type does not match.
 -  *      @package SimpleTest
 -  *      @subpackage UnitTester
 -  */
 - class NotAExpectation extends IsAExpectation {
 -     private $type;
 - 
 -     /**
 -      *    Sets the type to compare with.
 -      *    @param string $type       Type or class name.
 -      *    @param string $message    Customised message on failure.
 -      *    @access public
 -      */
 -     function __construct($type, $message = '%s') {
 -         parent::__construct($type, $message);
 -     }
 - 
 -     /**
 -      *    Tests the expectation. False if the type or
 -      *    class matches the string value.
 -      *    @param string $compare        Comparison value.
 -      *    @return boolean               True if different.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return ! parent::test($compare);
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         return "Value [" . $dumper->describeValue($compare) .
 -                 "] should not be type [" . $this->getType() . "]";
 -     }
 - }
 - 
 - /**
 -  *    Tests for existance of a method in an object
 -  *      @package SimpleTest
 -  *      @subpackage UnitTester
 -  */
 - class MethodExistsExpectation extends SimpleExpectation {
 -     private $method;
 - 
 -     /**
 -      *    Sets the value to compare against.
 -      *    @param string $method     Method to check.
 -      *    @param string $message    Customised message on failure.
 -      *    @access public
 -      *    @return void
 -      */
 -     function __construct($method, $message = '%s') {
 -         parent::__construct($message);
 -         $this->method = &$method;
 -     }
 - 
 -     /**
 -      *    Tests the expectation. True if the method exists in the test object.
 -      *    @param string $compare        Comparison method name.
 -      *    @return boolean               True if correct.
 -      *    @access public
 -      */
 -     function test($compare) {
 -         return (boolean)(is_object($compare) && method_exists($compare, $this->method));
 -     }
 - 
 -     /**
 -      *    Returns a human readable test message.
 -      *    @param mixed $compare      Comparison value.
 -      *    @return string             Description of success
 -      *                               or failure.
 -      *    @access public
 -      */
 -     function testMessage($compare) {
 -         $dumper = $this->getDumper();
 -         if (! is_object($compare)) {
 -             return 'No method on non-object [' . $dumper->describeValue($compare) . ']';
 -         }
 -         $method = $this->method;
 -         return "Object [" . $dumper->describeValue($compare) .
 -                 "] should contain method [$method]";
 -     }
 - }
 - ?>
 
 
  |