• Willkommen im Zend Framework Forum

    ZF1 Zend Framework 1 + ZF2 Zend Framework 2

    Das Zend Framework Forum ist seit 2006 die erste Anlaufstelle für Zend Framework Entwickler in Deutschland. Mit über 70.000 Beiträgen und einer steigenden Nutzerzahl bietet das Forum hilfreiche Themen und ZF-Tutorials für professionelle Entwickler, fortgeschrittene Programmierer sowie Zend Framework Einsteiger.
    Wenn dies Dein erster Besuch in der Zend Framework Community ist, lies bitte zuerst die Hilfe - FAQ durch. Du musst Dich registrieren, bevor Du Beiträge verfassen kannst. Klicke oben auf 'Registrieren', um die Registrierung zu starten. Du kannst auch jetzt schon Beiträge lesen. Hier im Forum findest Du die Zend Framework Hilfe, die Du suchst!

    Grüße an alle Zend Framework Entwickler. Das Team vom Zend Framework Forum!

    Drupal Agentur

Quote bei Unit-Tests?

Leider habe ich einen Fall, der mich schafft. Vielleicht habt ihr eine Idee?

LoggingListener
PHP:
  class LoggingListener implements ListenerAggregateInterface
  {
    protected $_aListeners = array();

    public function attach(EventManagerInterface $oEvents)
    {
      $this->_aListeners[] = $oEvents->attach(MvcEvent::EVENT_DISPATCH_ERROR, array($this, 'logErrors'), -100);
      $this->_aListeners[] = $oEvents->attach(MvcEvent::EVENT_RENDER_ERROR, array($this, 'logErrors'), -101);
    }

    public function detach(EventManagerInterface $oEvents)
    {
      foreach ($this->_aListeners as $iIndex => $mListener)
      {
        if ($oEvents->detach($mListener))
        {
          unset($this->_aListeners[$iIndex]);
        }
      }
    }

    public function logErrors(MvcEvent $oEvent)
    {
      $oServiceManager = $oEvent->getApplication()->getServiceManager();

      $oLogger = $oServiceManager->get('BGLog\Model\LogFile')->getLog('Log\Logging\ErrorDispatch');

      $oResult = $oEvent->getResult();

      if ($oException = $oEvent->getResult()->exception)
      {
        $sMessage = $oException->getCode() . ': ' .
                    $oException->getMessage() . "\n" .
                    str_pad('-', 120, '-') . "\n" .
                    $oException->getFile() . " (" .
                    $oException->getLine() . ")\n" .
                    str_pad('-', 120, '-') . "\n" .
                    $oException->getTraceAsString() . "\n";

        $oLogger->log(Logger::ERR, $sMessage);
      }
      else if ($oVariables = $oEvent->getResult()->getVariables())
      {
        $sMessage = $oVariables->message . "\n" .
                    $oVariables->controller . "\n" .
                    $oVariables->controller_class . "\n";

        $oLogger->log(Logger::ERR, $sMessage);
      }
    }
  }
Dieser wurde in der Module.php in der onBootstrap()-Methode registriert.

PHP:
public function onBootstrap(EventInterface $oEvent)
    {
      $oServiceManager = $oEvent->getApplication()->getServiceManager();

      $oEventManager = $oEvent->getApplication()->getEventManager();
      $oEventManager->attachAggregate($oServiceManager->get('Log\Listener\Logging'));
    }
Wie kann ich jetzt die Methode logErrors() testen? Es geht dabei mir um den IF-Fall mit der Exception.

Normalerweise müsste es wie folgt ablaufen (so stelle ich es mir mal vor):
  1. MvcEvent erzeugen
  2. LoggingListener erzeugen
  3. Event triggern
PHP:
$oMvcEvent = $this->getMock('Zend\Mvc\MvcEvent');
$oLoggingListener = $this->getMock('Log\Listener\LoggingListener');

...
 

[-UFO-]Melkor

New member
Wie kann ich jetzt die Methode logErrors() testen? Es geht dabei mir um den IF-Fall mit der Exception.

Normalerweise müsste es wie folgt ablaufen (so stelle ich es mir mal vor):
  1. MvcEvent erzeugen
  2. LoggingListener erzeugen
  3. Event triggern
Du willst nur die Methode logErrors testen, dafür musst du keinen Event triggern. Du musst lediglich die Abhängigkeiten mocken und die Methode aufrufen.

PHP:
$oMvcEvent = $this->getMock('Zend\Mvc\MvcEvent');
$oLoggingListener = $this->getMock('Log\Listener\LoggingListener');
Du willst die Methode logErrors der Klasse Log\Listener\LoggingListener testen. Wenn du die Klasse mockst, kannst du sie nicht testen ;-)

PHP:
$errorLog = $this->getMock('Log\Logging\ErrorDispatch');
// Hier überprüfen wir, ob die passende Fehlermeldung gesetzt wird
$errorLog->expects($this->once())->method('log')->with('<meine_fehlermeldung>');


$logFile     = $this->getMock('BGLog\Model\LogFile');
$logFile->expects($this->any())->method('getLog')->with('Log\Logging\ErrorDispatch')->will($this->returnValue($errorLog));
$services    = $this->getMockForAbstractClass('Zend\ServiceManager\ServiceLocatorInterface');
$services->expects($this->any())->method('get')->with('BGLog\Model\LogFile')->will($this->returnValue($logFile));
$application = $this->getMockForAbstractClass('Zend\Mvc\ApplicationInterface');
$application->expects($this->any())->method('getServiceManager')->will($this->returnValue($services));
$event       = $this->getMock('Zend\Mvc\MvcEvent');
$event->expects($this->any())->method('getApplication')->will($this->returnValue($application));

$exception   = $this->getMock('Exception');
$exception->expects($this->any())->method('getCode')->will($this->returnValue(42));
// die restlichen Exception-Methods, die benötigt werden, um die Fehlermeldung zu bauen, müssen ebenfalls gemockt werden.

$result = new stdClass();
$result->exception = $exception;

$event->expects($this->any())->method('getResult')->will($this->returnValue($result));

$listener = new \Log\Listener\Logging();
$listener->logErrors($event);
 
Oben