Zend फ्रेमवर्क - यूनिट परीक्षण
सामान्य तौर पर, हम PHP अनुप्रयोग का उपयोग करके डीबग कर सकते हैं advanced debugger tool या जैसे साधारण कमांड का उपयोग करके echo तथा die। एक वेब परिदृश्य में, हमें व्यावसायिक लॉगिक्स के साथ-साथ प्रस्तुति परत का भी परीक्षण करने की आवश्यकता है। वेब एप्लिकेशन में प्रपत्रों को यह सुनिश्चित करने के लिए प्रासंगिक परीक्षण डेटा दर्ज करके परीक्षण किया जा सकता है कि प्रपत्र अपेक्षित रूप से काम कर रहे हैं।
ब्राउज़र का उपयोग करके वेबसाइट के डिज़ाइन को मैन्युअल रूप से परीक्षण किया जा सकता है। इस प्रकार की परीक्षण प्रक्रियाएँ इकाई परीक्षण का उपयोग करके स्वचालित की जा सकती हैं। बड़ी परियोजनाओं में एक इकाई परीक्षण आवश्यक है। ये इकाई परीक्षण परीक्षण प्रक्रिया को स्वचालित करने और डेवलपर को कुछ गलत होने पर सतर्क करने में मदद करेंगे।
PHPUnit की स्थापना
Zend फ्रेमवर्क PHPUnit इकाई परीक्षण ढांचे के साथ एकीकृत करता है। Zend फ्रेमवर्क के लिए एक यूनिट टेस्ट लिखने के लिए, हमें PHPUnit को सेटअप करने की आवश्यकता है, जिसे निम्नलिखित कंपोजिट कमांड का उपयोग करके आसानी से किया जा सकता है।
$ composer require --dev phpunit/phpunit
उपरोक्त कमांड को निष्पादित करने के बाद, आपको एक प्रतिक्रिया मिलेगी जैसा कि निम्नलिखित कोड ब्लॉक में दिखाया गया है।
Using version ^5.7 for phpunit/phpunit
./composer.json has been updated
Loading composer repositories with package information
Updating dependencies (including require-dev)
Nothing to install or update
Writing lock file
Generating autoload files
अब, जब आप "composer.json" फ़ाइल खोलेंगे, तो आपको निम्नलिखित परिवर्तन दिखाई देंगे -
"require-dev": {
"phpunit/phpunit": "^5.7"
}
TestCase और जोर
Zend फ्रेमवर्क कंट्रोलर को यूनिट टेस्ट करने के लिए हेल्पर कक्षाएं प्रदान करता है। TestCase में मुख्य घटक है PHPUnit परीक्षण मामलों और Zend फ्रेमवर्क को लिखने के लिए फ्रेमवर्क TestCase का एक सार कार्यान्वयन प्रदान करता है जिसे कहा जाता है AbstractHttpControllerTestCase।
यह AbstractHttpControllerTestCase विभिन्न प्रदान करता है Assertतरीकों और कार्यक्षमता के आधार पर समूहीकृत किया जा सकता है। वे इस प्रकार हैं -
Request Assertions- http अनुरोध का दावा करने के लिए उपयोग किया जाता है। उदाहरण के लिए, assertControllerName।
CSS Select Assertions - HTML डोम मॉडल का उपयोग करके प्रतिक्रिया HTML की जांच करने के लिए उपयोग किया जाता है।
XPath Assertions - CSS का विकल्प XPath के आधार पर चयन का दावा करता है।
Redirect Assertions - पृष्ठ पुनर्निर्देशन की जांच करने के लिए उपयोग किया जाता है।
Response Header Assertions - स्टेटस कोड (assertResponseStatusCode) जैसे प्रतिक्रिया हेडर की जांच करने के लिए उपयोग किया जाता है
टेस्ट डायरेक्टरी बनाएं
प्रत्येक मॉड्यूल के लिए एक यूनिट टेस्ट अलग से लिखा जा सकता है। सभी परीक्षण संबंधित कोडिंग के अंदर बनाए जाने की आवश्यकता हैtest मॉड्यूल की रूट निर्देशिका के तहत फ़ोल्डर।
उदाहरण के लिए, ट्यूटोरियल मॉड्यूल के तहत उपलब्ध TutorialController के लिए एक परीक्षण लिखने के लिए, परीक्षण वर्ग को myapp / मॉड्यूल / ट्यूटोरियल / परीक्षण / नियंत्रक / निर्देशिका के तहत रखा जाना चाहिए।
उदाहरण
आइए हम एक टेस्ट क्लास टू यूनिट टेस्ट लिखें TutorialController।
शुरू करने के लिए, हमें TutorialControllerTest नामक एक वर्ग लिखना चाहिए और इसे AbstractHttpControllerTestCase पर विस्तारित करना चाहिए।
अगला कदम एक लिखना है Setupपरीक्षण वातावरण सेटअप करने के लिए विधि। यह कॉल करके किया जा सकता हैsetApplicationConfig पद्धति और हमारा मुख्य एप्लिकेशन कॉन्फिगर करने का तरीका myapp / config / application.config.php फाइल है
public function setUp() {
$configOverrides = [];
$this->setApplicationConfig(ArrayUtils::merge( include __DIR__ . '/../../../../config/application.config.php', $configOverrides
));
parent::setUp();
}
एक या एक से अधिक विधियाँ लिखें और आवश्यकता के आधार पर विभिन्न मुखर विधियों को बुलाएँ।
$this->assertMatchedRouteName('tutorial');
हमने टेस्ट क्लास लिखी है और पूरी लिस्टिंग इस प्रकार है -
<?php
namespace TutorialTest\Controller;
use Tutorial\Controller\TutorialController;
use Zend\Stdlib\ArrayUtils;
use Zend\Test\PHPUnit\Controller\AbstractHttpControllerTestCase;
class TutorialControllerTest extends AbstractHttpControllerTestCase {
public function setUp() {
$configOverrides = [];
$this->setApplicationConfig(ArrayUtils::merge( include __DIR__ . '/../../../../config/application.config.php', $configOverrides
));
parent::setUp();
}
public function testIndexActionCanBeAccessed() {
$this->dispatch('/tutorial', 'GET'); $this->assertResponseStatusCode(200);
$this->assertModuleName('tutorial'); $this->assertControllerName(TutorialController::class);
$this->assertControllerClass('TutorialController'); $this->assertMatchedRouteName('tutorial');
}
}
अब, कमांड प्रॉम्प्ट खोलें, एप्लिकेशन रूट डायरेक्टरी पर जाएं और निष्पादित करें phpunit निष्पादन योग्य अंदर उपलब्ध है vendor फ़ोल्डर।
cd /path/to/app
./vendor/bin/phpunit ./vendor/bin/phpunit module/
Tutorial/test/Controller/TutorialControllerTest.php
परिणाम निम्न कोड ब्लॉक में दिखाया जाएगा -
PHPUnit 5.7.5 by Sebastian Bergmann and contributors.
.1 / 1 (100%)
Time: 96 ms, Memory: 8.00MB
OK (1 test, 5 assertions)