Debugger

Le debug est une inévitable et nécessaire partie de tout cycle de développement. Tandis que CakePHP n’offre pas d’outils qui se connectent directement avec tout IDE ou éditeur, CakePHP fournit plusieurs outils pour l’aide au debug et ce qui est lancé sous le capot de votre application.

Debug basique

debug(mixed $var, boolean $showHtml = null, $showFrom = true)
Paramètres:
  • $var (mixed) – Les contenus à afficher. Les tableaux et objets fonctionnent bien.

  • $showHTML (boolean) – Défini à true, pour activer l’échappement. L’échappement est activé par défaut dans 2.0 quand on sert les requêtes web.

  • $showFrom (boolean) – Montre la ligne et le fichier pour lesquels le debug() apparaît.

La fonction debug() est une fonction disponible partout qui fontionne de la même manière que la fonction PHP print_r(). La fonction debug() vous permet de montrer les contenus d’un variable de différentes façons. Premièrement, si vous voulez que vos données soient montrées d’une façon sympa en HTML, définissez le deuxième paramètre à true. La fonction affiche aussi la ligne et le fichier dont ils sont originaires par défaut.

La sortie de cette fonction est seulement montrée si la variable de debug du coeur a été définie à une valeur supérieure à 0.

Modifié dans la version 2.1: La sortie de debug() ressemble plus var_dump(), et utilise Debugger en interne.

Classe Debugger

La classe debugger a été introduite avec CakePHP 1.2 et offre même plus d’options pour obtenir les informations de debug. Elle a plusieurs fonctions qui sont appelées statiquement, et fournissent le dumping, logging et les fonctions de gestion des erreurs.

La Classe Debugger écrase la gestion des erreurs PHP par défaut, le remplaçant avec bien plus de rapports d’erreurs utiles. La gestion des erreurs de Debugger est utilisée par défaut dans CakePHP. Comme pour toutes les fonctions de debug, Configure::debug doit être défini à une valeur supérieure à 0.

Quand une erreur est levée, Debugger affiche à la fois l’information de la page et fait une entrée dans le fichier error.log. Le rapport d’erreurs qui est généré a les deux stack trace et un extrait de où l’erreur a été levée. Cliquez sur le type de lien « Error » pour revéler le stack trace, et sur le lien « Code » pour revéler les lignes d’erreurs en cause.

Utiliser la Classe Debugger

class Debugger

Pour utiliser le debugger, assurez-vous d’abord que Configure::read(“debug”) est défini à une valeur supérieure à 0.

static Debugger::dump($var, $depth = 3)

Dump prints out the contents of a variable. Elle affiche toutes les propriétés et méthodes (si il y en a) de la variable fournie:

$foo = array(1,2,3);

Debugger::dump($foo);

// sortie
array(
    1,
    2,
    3
)

// objet simple
$car = new Car();

Debugger::dump($car);

// sortie
Car
Car::colour = 'red'
Car::make = 'Toyota'
Car::model = 'Camry'
Car::mileage = '15000'
Car::acclerate()
Car::decelerate()
Car::stop()

Modifié dans la version 2.1: Dans 2.1 forward, la sortie a été modifiée pour la lisibilité. Regardez Debugger::exportVar().

Modifié dans la version 2.5.0: Le paramètre depth a été ajouté.

static Debugger::log($var, $level = 7, $depth = 3)

Crée un stack trace log détaillé au moment de l’invocation. La méthode log() affiche les données identiques à celles faites par Debugger::dump(), mais dans debug.log au lieu de les sortir buffer. Notez que votre répertoire app/tmp directory (et son contenu) doit être ouvert en écriture par le serveur web pour que le log() fonctionne correctement.

Modifié dans la version 2.5.0: Le paramètre depth a été ajouté.

static Debugger::trace($options)

Retourne le stack trace courant. Chaque ligne des traces inclut la méthode appelée, incluant chaque fichier et ligne d’où est originaire l’appel.

//Dans PostsController::index()
pr( Debugger::trace() );

//sorties
PostsController::index() - APP/Controller/DownloadsController.php, line 48
Dispatcher::_invoke() - CORE/lib/Cake/Routing/Dispatcher.php, line 265
Dispatcher::dispatch() - CORE/lib/Cake/Routing/Dispatcher.php, line 237
[main] - APP/webroot/index.php, line 84

Ci-dessus se trouve le stack trace généré en appelant Debugger::trace() dans une action d’un controller. Lire le stack trace de bas en haut montre l’ordre des fonctions lancées actuellement (stack frames). Dans l’exemple du dessus, index.php appelé Dispatcher::dispatch(), qui est appelé in-turn Dispatcher::_invoke(). La méthode _invoke() appelé ensuite par PostsController::index(). Cette information est utile quand vous travaillez avec des opérations récursives ou des stacks profonds, puisqu’il identifie les fonctions qui sont actuellement lancées au moment du trace().

static Debugger::excerpt($file, $line, $context)

Récupérer un extrait du fichier dans $path (qui est un chemin de fichier absolu), mettant en évidence le numéro de la ligne $line avec le nombre de lignes $context autour.

pr( Debugger::excerpt(ROOT.DS.LIBS.'debugger.php', 321, 2) );

//sortira ce qui suit.
Array
(
    [0] => <code><span style="color: #000000"> * @access public</span></code>
    [1] => <code><span style="color: #000000"> */</span></code>
    [2] => <code><span style="color: #000000">    function excerpt($file, $line, $context = 2) {</span></code>

    [3] => <span class="code-highlight"><code><span style="color: #000000">        $data = $lines = array();</span></code></span>
    [4] => <code><span style="color: #000000">        $data = @explode("\n", file_get_contents($file));</span></code>
)

Bien que cette méthode est utilisée en interne, elle peut être pratique si vous créez vos propres messages d’erreurs ou les logs pour les situations personnalisées.

static Debugger::exportVar($var, $recursion = 0)

Convertir une variable de tout type en une chaîne de caractères pour l’utilisation dans la sortie de debug. Cette méthode est aussi utilisée par la plupart de Debugger pour les conversions de variable en interne, et peut aussi être utilisée dans vos propres Debuggers.

Modifié dans la version 2.1: Cette fonction génère une sortie différente dans 2.1 et suivants.

static Debugger::invoke($debugger)

Remplace le Debugger de CakePHP avec une nouvelle instance.

static Debugger::getType($var)

Récupère le type de variable. Les objets retourneront leur nom de classe.

Nouveau dans la version 2.1.

Utiliser Logging pour debug

Logger des messages est une autre bonne façon de debugger les applications, et vous pouvez utiliser CakeLog pour faire le logging dans votre application. Tous les objets qui étendent Object ont une méthode d’instanciation log() qui peut êtreui peut être utilisée pour logger les messages:

$this->log('Got here', 'debug');

Ce qui est au-dessus écrit Got here dans le debug du log. Vous pouvez utiliser les logs (log entries) pour aider les méthodes de débug qui impliquent les redirections ou les boucles compliquées. Vous pouvez aussi utiliser CakeLog::write() pour écrire les messages de log. Cette méthode peut être appelée statiquement partout dans votre application où CakeLog a été chargée:

// Dans app/Config/bootstrap.php
App::uses('CakeLog', 'Log');

// N'importe où dans votre application
CakeLog::write('debug', 'Got here');

Kit de Debug

DebugKit est un plugin qui fournit un nombre de bons outils de debug. Il fournit principalement une barre d’outils dans le HTML rendu, qui fournit une pléthore d’informations sur votre application et la requête courante. Vous pouvez télécharger DebugKit sur GitHub.

Xdebug

Si votre environnement a l’extension PHP Xdebug, des erreurs fatales vont montrer des détails de stack trace supplémentaires de Xdebug. Plus de détails sur Xdebug .