Wie verwende ich PHPUnit und Mockery für Unit-Tests?
In der PHP-Projektentwicklung ist Unit-Test eine sehr wichtige Aufgabe. PHPUnit und Mockery sind zwei sehr beliebte PHP-Unit-Test-Frameworks. PHPUnit ist ein weit verbreitetes Unit-Testing-Tool, während Mockery ein Objektsimulationstool ist, das sich auf die Bereitstellung einer einheitlichen und prägnanten API zum Erstellen und Verwalten von Objekt-Mocks konzentriert.
Durch die Verwendung von PHPUnit und Mockery können Entwickler schnell und effizient Unit-Tests durchführen, um die Korrektheit und Stabilität ihrer Codebasis sicherzustellen. In diesem Artikel wird erläutert, wie Sie PHPUnit und Mockery für Unit-Tests verwenden, sodass Sie solche Tests bequem durchführen können.
- Zuerst müssen wir PHPUnit und Mockery installieren. Hier verwenden wir Composer, um diese beiden Tools schnell zu installieren. Führen Sie im Projektverzeichnis, in dem Sie PHPUnit und Mockery verwenden möchten, den folgenden Befehl aus:
composer require --dev phpunit/phpunit mockery/mockery
Dieser Befehl installiert PHPUnit und Mockery als Entwicklungsabhängigkeiten in Ihrem Projekt, um die Ausführung des Komponententests zu erleichtern .
- Als nächstes zeigen wir, wie man mit PHPUnit einen Testfall erstellt. Angenommen, Sie schreiben eine Klasse namens „Calculator“, die grundlegende arithmetische Operationen verarbeitet. Wir erstellen einen Testfall für diese Klasse und prüfen, ob sie die Additionsoperation korrekt ausführen kann.
Erstellen Sie in Ihrem Projektordner eine Datei mit dem Namen „CalculatorTest.php“ und schreiben Sie den folgenden Code hinein:
use PHPUnitFrameworkTestCase; use MyAppCalculator; class CalculatorTest extends TestCase { public function testAddition() { $calculator = new Calculator(); $result = $calculator->add(2, 2); $this->assertEquals(4, $result); } }
In diesem Testfall Wir instanziieren zunächst ein Calculator-Objekt und verwenden dann die Methode add(), um die Additionsoperation auszuführen. Abschließend verwenden wir die Methode „assertEquals()“, um zu überprüfen, ob das Ergebnis der Operation dem erwarteten Wert entspricht.
- Als nächstes schauen wir uns an, wie man mit Mockery ein Objekt simuliert. In vielen Fällen möchten wir beim Testen keine realen Objekte verwenden, sondern diese durch ein Scheinobjekt ersetzen, damit das Testen verfeinert und effizienter werden kann. Mockery macht es einfach, diese Scheinobjekte zu erstellen und zu verwenden.
Angenommen, wir schreiben eine Klasse mit dem Namen „UserService“, um benutzerbezogene Geschäftslogik zu verarbeiten. Diese Klasse ist für den Zugriff auf den Benutzerdatenspeicher von einer anderen Klasse namens „UserRepository“ abhängig. Wir können Mockery verwenden, um diese Abhängigkeit zu simulieren und zu überprüfen, ob der UserService im Test normal läuft.
Erstellen Sie in Ihrem Projektordner eine Datei mit dem Namen „UserServiceTest.php“ und schreiben Sie den folgenden Code hinein:
use PHPUnitFrameworkTestCase; use MyAppUserService; use MyAppUserRepository; use MockeryAdapterPhpunitMockeryPHPUnitIntegration; class UserServiceTest extends TestCase { use MockeryPHPUnitIntegration; public function testCreateUser() { $repo = Mockery::mock(UserRepository::class); $repo->shouldReceive('create') ->once() ->with(['name' => 'Alice']); $service = new UserService($repo); $service->createUser('Alice'); } }
In diesem Testfall verwenden wir die Funktion „Mockery: :mock()“-Funktion zum Erstellen eines Schein-UserRepository-Objekts. Dann erwarten wir, dass über die Methode „shouldReceive()“ die Methode „create()“ dieses Scheinobjekts einmal aufgerufen wird und ein Array mit dem Namen „‚Alice‘“ als Parameter übergeben wird. Schließlich instanziieren wir ein UserService-Objekt und rufen die Methode „create()“ des Scheinobjekts über seine Methode „createUser()“ auf.
- Lassen Sie uns abschließend besprechen, wie Testfälle in PHPUnit und Mockery ausgeführt werden. Vorausgesetzt, wir haben die beiden oben genannten Testfälle erstellt, können wir sie mit dem folgenden Befehl ausführen:
./vendor/bin/phpunit
Dieser Befehl findet automatisch alle Testfälle im Projekt und führt sie aus. Wenn alle Tests erfolgreich sind, gibt PHPUnit eine Meldung aus, um dies zu bestätigen.
Wenn Sie nur einen bestimmten Testfall ausführen möchten, können Sie nach dem Befehl die Testdatei oder Testmethode angeben. Um beispielsweise die Methode testAddition() in „CalculatorTest.php“ auszuführen, können Sie den folgenden Befehl ausführen:
./vendor/bin/phpunit tests/CalculatorTest.php --filter testAddition
Mit diesen einfachen Schritten können Sie PHPUnit und Mockery für PHP-Unit-Tests verwenden. Eine korrekte und vollständige Testsuite trägt dazu bei, die Qualität und Stabilität der Codebasis des PHP-Projekts sicherzustellen und eine kontinuierliche Verbesserung und Weiterentwicklung zu ermöglichen.
Das obige ist der detaillierte Inhalt vonWie verwende ich PHPUnit und Mockery für Unit-Tests?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



In diesem Kapitel werden wir die Umgebungsvariablen, die allgemeine Konfiguration, die Datenbankkonfiguration und die E-Mail-Konfiguration in CakePHP verstehen.

PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

Um in cakephp4 mit Datum und Uhrzeit zu arbeiten, verwenden wir die verfügbare FrozenTime-Klasse.

Um am Datei-Upload zu arbeiten, verwenden wir den Formular-Helfer. Hier ist ein Beispiel für den Datei-Upload.

In diesem Kapitel lernen wir die folgenden Themen im Zusammenhang mit dem Routing kennen.

CakePHP ist ein Open-Source-Framework für PHP. Es soll die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich vereinfachen. CakePHP basiert auf einer MVC-ähnlichen Architektur, die sowohl leistungsstark als auch leicht zu verstehen ist. Modelle, Ansichten und Controller gu

Das Arbeiten mit der Datenbank in CakePHP ist sehr einfach. In diesem Kapitel werden wir die CRUD-Operationen (Erstellen, Lesen, Aktualisieren, Löschen) verstehen.

Der Validator kann durch Hinzufügen der folgenden zwei Zeilen im Controller erstellt werden.
