Maison  >  Article  >  développement back-end  >  Quand devriez-vous vous moquer des méthodes privées dans PHPUnit ?

Quand devriez-vous vous moquer des méthodes privées dans PHPUnit ?

Barbara Streisand
Barbara Streisandoriginal
2024-10-30 04:55:28904parcourir

 When Should You Mock Private Methods in PHPUnit?

Se moquer des méthodes privées avec PHPUnit

Introduction

Se moquer des méthodes privées peut être une technique utile pour tester la logique au sein d'un classe sans exposer les détails de son implémentation. Cependant, il est important d'aborder cela avec prudence pour éviter de rompre l'encapsulation et de compromettre l'intégrité de votre code.

Problème

Considérez l'exemple suivant :

<code class="php">class A {
  public function b() { 
    // some code
    $this->c(); 
    // some more code
  }

  private function c(){ 
    // some code
  }
}</code>

Comment pouvez-vous écraser le résultat de la méthode privée c() pour tester la partie "un peu plus de code" de la fonction publique b() en utilisant PHPUnit ?

Solution

Option 1 : Envisagez le refactoring

En général, il n'est pas considéré comme une bonne pratique de tester directement les méthodes privées. Concentrez-vous plutôt sur le test de l’API publique de la classe. Tous les détails de mise en œuvre interne doivent être considérés comme une boîte noire.

Option 2 : Utiliser des simulations (procéder avec prudence)

Cependant, dans certains scénarios, des méthodes privées moqueuses peuvent être nécessaire. Pour y parvenir en utilisant PHPUnit :

  1. Créez un objet fictif pour la classe testée :

    <code class="php">$mock = $this->getMockBuilder('A')
                ->disableOriginalConstructor()
                ->getMock();</code>
  2. Définissez le comportement attendu du méthode :

    <code class="php">$mock->expects($this->once())
        ->method('c')
        ->will($this->returnValue(YOUR_STUBBED_VALUE));</code>
  3. Remplacez l'instance d'origine par la simulation dans votre test :

    <code class="php">$originalInstance = new A();
    $this->reflection()->setProtectedProperty(
       $originalInstance,
       'c',
       $mock
    );</code>
  4. Exécutez votre test comme d'habitude.

Conclusion

Bien qu'il puisse être tentant de se moquer des méthodes privées à des fins de test, il est important de donner la priorité aux principes d'encapsulation et d'éviter d'exposer inutilement des détails internes. Pensez à refactoriser votre code pour permettre les tests sans recourir à la moquerie de méthodes privées.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn