परीक्षण थ्रेड अनुप्रयोग

इस अध्याय में, हम थ्रेड एप्लिकेशन के परीक्षण के बारे में जानेंगे। हम परीक्षण के महत्व को भी जानेंगे।

टेस्ट क्यों?

इससे पहले कि हम परीक्षण के महत्व के बारे में चर्चा में गोता लगाएँ, हमें यह जानना होगा कि परीक्षण क्या है। सामान्य शब्दों में, परीक्षण यह पता लगाने की तकनीक है कि कोई चीज़ कितनी अच्छी तरह काम कर रही है। दूसरी ओर, विशेष रूप से अगर हम कंप्यूटर प्रोग्राम या सॉफ़्टवेयर के बारे में बात करते हैं तो परीक्षण एक सॉफ्टवेयर प्रोग्राम की कार्यक्षमता तक पहुँचने की तकनीक है।

इस खंड में, हम सॉफ्टवेयर परीक्षण के महत्व पर चर्चा करेंगे। सॉफ़्टवेयर डेवलपमेंट में, क्लाइंट को सॉफ़्टवेयर रिलीज़ करने से पहले डबल-चेकिंग होनी चाहिए। इसलिए अनुभवी परीक्षण टीम द्वारा सॉफ्टवेयर का परीक्षण करना बहुत महत्वपूर्ण है। सॉफ्टवेयर परीक्षण के महत्व को समझने के लिए निम्नलिखित बिंदुओं पर विचार करें -

सॉफ्टवेयर की गुणवत्ता में सुधार

निश्चित रूप से, कोई भी कंपनी कम गुणवत्ता वाला सॉफ्टवेयर नहीं देना चाहती है और कोई भी ग्राहक कम गुणवत्ता वाला सॉफ्टवेयर नहीं खरीदना चाहता है। परीक्षण उस बग को खोजने और ठीक करने से सॉफ्टवेयर की गुणवत्ता में सुधार करता है।

ग्राहकों की संतुष्टि

किसी भी व्यवसाय का सबसे महत्वपूर्ण हिस्सा उनके ग्राहकों की संतुष्टि है। बग मुक्त और अच्छी गुणवत्ता वाले सॉफ़्टवेयर प्रदान करके कंपनियां ग्राहकों की संतुष्टि प्राप्त कर सकती हैं।

नई सुविधाओं के प्रभाव को कम

मान लीजिए कि हमने 10000 लाइनों का एक सॉफ्टवेयर सिस्टम बनाया है और हमें एक नई सुविधा जोड़ने की आवश्यकता है तो विकास टीम को इस नए फीचर के पूरे सॉफ्टवेयर पर प्रभाव की चिंता होगी। यहां, परीक्षण भी एक महत्वपूर्ण भूमिका निभाता है, क्योंकि यदि परीक्षण टीम ने परीक्षणों का एक अच्छा सूट बनाया है, तो यह हमें किसी भी संभावित विनाशकारी विराम से बचा सकता है।

प्रयोगकर्ता का अनुभव

किसी भी व्यवसाय का एक और सबसे महत्वपूर्ण हिस्सा उस उत्पाद के उपयोगकर्ताओं का अनुभव है। केवल परीक्षण यह आश्वासन दे सकता है कि अंतिम उपयोगकर्ता को उत्पाद का उपयोग करना सरल और आसान लगता है।

खर्चों में कटौती

परीक्षण सॉफ्टवेयर के कुल लागत में कटौती कर सकता है और प्रसव के बाद इसे ठीक करने के बजाय इसके विकास के परीक्षण चरण में बग्स को ठीक कर सकता है। यदि सॉफ्टवेयर की डिलीवरी के बाद एक प्रमुख बग है तो यह खर्चों के संदर्भ में अपनी मूर्त लागत को बढ़ाएगा और ग्राहक की असंतोष, कंपनी की नकारात्मक प्रतिष्ठा आदि के संदर्भ में अमूर्त लागत कहेगा।

क्या टेस्ट करें?

परीक्षण करने के लिए हमेशा उपयुक्त ज्ञान रखने की सलाह दी जाती है। इस खंड में, हम पहले किसी भी सॉफ़्टवेयर का परीक्षण करते समय परीक्षक के मुख्य उद्देश्य को समझेंगे। कोड कवरेज, यानी, परीक्षण करते समय हमारे परीक्षण सूट हिट कोड की कितनी पंक्तियाँ, से बचा जाना चाहिए। ऐसा इसलिए है क्योंकि परीक्षण करते समय, केवल कोड की लाइनों की संख्या पर ध्यान केंद्रित करना हमारे सिस्टम में कोई वास्तविक मूल्य नहीं जोड़ता है। कुछ कीड़े रह सकते हैं, जो बाद में तैनाती के बाद भी बाद के चरण में प्रतिबिंबित होते हैं।

परीक्षण करने के लिए निम्नलिखित महत्वपूर्ण बिंदुओं पर विचार करें -

  • हमें कोड कवरेज की बजाय कोड की कार्यक्षमता के परीक्षण पर ध्यान देने की आवश्यकता है।

  • हमें पहले कोड के सबसे महत्वपूर्ण भागों का परीक्षण करने की आवश्यकता है और फिर कोड के कम महत्वपूर्ण भागों की ओर बढ़ना चाहिए। इससे समय जरूर बचेगा।

  • परीक्षक के पास विभिन्न परीक्षण होने चाहिए, जो सॉफ़्टवेयर को उसकी सीमा तक धकेल सकते हैं।

समवर्ती सॉफ्टवेयर प्रोग्राम के परीक्षण के लिए अनुमोदन

मल्टी-कोर आर्किटेक्चर की वास्तविक क्षमता का उपयोग करने की क्षमता के कारण, समवर्ती सॉफ्टवेयर सिस्टम अनुक्रमिक प्रणालियों की जगह ले रहे हैं। हाल के समय में, मोबाइल फोन से लेकर वाशिंग मशीन, कारों से लेकर हवाई जहाज आदि सभी में समवर्ती प्रणाली कार्यक्रमों का उपयोग किया जा रहा है। हमें समवर्ती सॉफ्टवेयर कार्यक्रमों के परीक्षण के बारे में अधिक सावधान रहने की आवश्यकता है क्योंकि यदि हमने एकल धागे के अनुप्रयोग में कई सूत्र जोड़े हैं पहले से ही एक बग, तो हम कई बग के साथ समाप्त हो जाएगा।

समवर्ती सॉफ्टवेयर प्रोग्राम के लिए परीक्षण तकनीक व्यापक रूप से उन इंटरलेइंग को चुनने पर ध्यान केंद्रित कर रही है जो संभावित हानिकारक पैटर्न जैसे दौड़ की स्थिति, गतिरोध और परमाणु के उल्लंघन का खुलासा करते हैं। समवर्ती सॉफ्टवेयर प्रोग्राम के परीक्षण के लिए दो दृष्टिकोण निम्नलिखित हैं -

व्यवस्थित अन्वेषण

इस दृष्टिकोण का उद्देश्य व्यापक रूप से संभव के रूप में वार्ताकारों के स्थान का पता लगाना है। इस तरह के दृष्टिकोण एक जानवर-बल तकनीक को अपना सकते हैं और अन्य लोग आंशिक क्रम में कमी की तकनीक या हस्तक्षेप की जगह का पता लगाने के लिए अनुमानी तकनीक को अपना सकते हैं।

संपत्ति पर ही आधारित

प्रॉपर्टी से चलने वाले दृष्टिकोण इस बात पर निर्भर करते हैं कि कंसीलरिटी के तहत कंसीलर फॉल्ट की संभावना अधिक होती है जो विशिष्ट मेमोरी जैसे कि संदिग्ध मेमोरी एक्सेस पैटर्न को उजागर करते हैं। विभिन्न संपत्ति संचालित दृष्टिकोण दौड़ की स्थिति, गतिरोध और परमाणु के उल्लंघन जैसे विभिन्न दोषों को लक्षित करते हैं, जो आगे एक या अन्य विशिष्ट गुणों पर निर्भर करता है।

परीक्षण रणनीतियाँ

टेस्ट रणनीति को टेस्ट दृष्टिकोण के रूप में भी जाना जाता है। रणनीति परिभाषित करती है कि परीक्षण कैसे किया जाएगा। टेस्ट दृष्टिकोण में दो तकनीकें हैं -

सक्रिय

एक दृष्टिकोण जिसमें निर्माण के पहले दोषों को खोजने और उन्हें ठीक करने के लिए परीक्षण डिजाइन प्रक्रिया जितनी जल्दी हो सके शुरू की जाती है।

रिएक्टिव

एक दृष्टिकोण जिसमें विकास प्रक्रिया के पूरा होने तक परीक्षण शुरू नहीं होता है।

अजगर कार्यक्रम पर किसी भी परीक्षण रणनीति या दृष्टिकोण को लागू करने से पहले, हमारे पास एक सॉफ्टवेयर प्रोग्राम के प्रकार की त्रुटियों के बारे में एक मूल विचार होना चाहिए। त्रुटियां इस प्रकार हैं -

वाक्यविन्यास त्रुटियाँ

कार्यक्रम के विकास के दौरान, कई छोटी त्रुटियां हो सकती हैं। गलतियाँ ज्यादातर टाइपिंग गलतियों के कारण होती हैं। उदाहरण के लिए, बृहदान्त्र गायब होना या किसी कीवर्ड की गलत वर्तनी, आदि ऐसी त्रुटियाँ प्रोग्राम सिंटैक्स में गलती के कारण होती हैं न कि तर्क में। इसलिए, इन त्रुटियों को सिंटैक्टिकल त्रुटियाँ कहा जाता है।

शब्दार्थ त्रुटियाँ

शब्दार्थ त्रुटियों को तार्किक त्रुटियां भी कहा जाता है। यदि सॉफ़्टवेयर प्रोग्राम में कोई तार्किक या शब्दार्थ त्रुटि है, तो कथन सही ढंग से संकलित और चलेगा, लेकिन यह वांछित आउटपुट नहीं देगा क्योंकि तर्क सही नहीं है।

इकाई का परीक्षण

यह अजगर कार्यक्रमों के परीक्षण के लिए सबसे अधिक इस्तेमाल की जाने वाली परीक्षण रणनीतियों में से एक है। इस रणनीति का उपयोग परीक्षण इकाइयों या कोड के घटकों के लिए किया जाता है। इकाइयों या घटकों द्वारा, हम कोड के वर्गों या कार्यों का मतलब है। यूनिट परीक्षण "छोटी" इकाइयों का परीक्षण करके बड़ी प्रोग्रामिंग प्रणालियों के परीक्षण को सरल बनाता है। उपरोक्त अवधारणा की सहायता से, यूनिट परीक्षण को एक विधि के रूप में परिभाषित किया जा सकता है जहां स्रोत कोड की व्यक्तिगत इकाइयों को यह निर्धारित करने के लिए परीक्षण किया जाता है कि क्या वे वांछित आउटपुट वापस करते हैं।

हमारे बाद के अनुभागों में, हम यूनिट परीक्षण के लिए विभिन्न पायथन मॉड्यूल के बारे में जानेंगे।

सबसे अच्छा मॉड्यूल

यूनिट परीक्षण के लिए सबसे पहला मॉड्यूल सबसे बेकार मॉड्यूल है। यह JUnit से प्रेरित है और डिफ़ॉल्ट रूप से Python3.6 में शामिल है। यह परीक्षण स्वचालन, परीक्षण के लिए सेटअप और शटडाउन कोड साझा करने, संग्रह में परीक्षणों के एकत्रीकरण और रिपोर्टिंग ढांचे से परीक्षणों की स्वतंत्रता का समर्थन करता है।

निम्नलिखित कुछ महत्वपूर्ण अवधारणाएं हैं जिन्हें यूनिटेस्ट मॉड्यूल द्वारा समर्थित किया गया है

पाठ का निर्धारण

इसका उपयोग एक परीक्षण स्थापित करने के लिए किया जाता है ताकि परीक्षण शुरू करने से पहले इसे चलाया जा सके और परीक्षण समाप्त होने के बाद फाड़ दिया जा सके। इसमें परीक्षण शुरू करने से पहले आवश्यक अस्थायी डेटाबेस, निर्देशिकाओं आदि का निर्माण शामिल हो सकता है।

परीक्षण का मामला

परीक्षण मामला जांचता है कि इनपुट के विशिष्ट सेट से एक आवश्यक प्रतिक्रिया आ रही है या नहीं। यूनिस्टेस्ट मॉड्यूल में टेस्टकेस नामक एक बेस क्लास शामिल है जिसका उपयोग नए परीक्षण मामलों को बनाने के लिए किया जा सकता है। इसमें दो डिफ़ॉल्ट तरीके शामिल हैं -

  • setUp()- व्यायाम करने से पहले परीक्षण स्थिरता स्थापित करने के लिए एक हुक विधि। कार्यान्वित परीक्षण विधियों को कॉल करने से पहले यह कहा जाता है।

  • tearDown( - कक्षा में सभी परीक्षणों को चलाने के बाद कक्षा की स्थिरता को कम करने के लिए एक हुक विधि।

परीक्षण सूट

यह परीक्षण सूट, परीक्षण मामलों या दोनों का एक संग्रह है।

टेस्ट रनर

यह परीक्षण मामलों या सूट के चलने को नियंत्रित करता है और उपयोगकर्ता को परिणाम प्रदान करता है। यह परिणाम प्रदान करने के लिए GUI या सरल पाठ इंटरफ़ेस का उपयोग कर सकता है।

Example

निम्नलिखित पायथन कार्यक्रम नामांकित मॉड्यूल का परीक्षण करने के लिए सबसे उपयुक्त मॉड्यूल का उपयोग करता है Fibonacci। कार्यक्रम किसी संख्या की फाइबोनैचि श्रृंखला की गणना करने में मदद करता है। इस उदाहरण में, हमने विभिन्न तरीकों का उपयोग करके परीक्षण मामलों को परिभाषित करने के लिए, Fibo_test नामक एक वर्ग बनाया है। ये विधियाँ unittest.TestCase से विरासत में मिली हैं। हम डिफ़ॉल्ट तरीकों से दो का उपयोग कर रहे हैं - setUp () और आंसू ()। हम टेस्टफिबोकल विधि को भी परिभाषित करते हैं। परीक्षण के नाम को पत्र परीक्षण के साथ शुरू किया जाना चाहिए। अंतिम ब्लॉक में, unittest.main () परीक्षण स्क्रिप्ट को कमांड-लाइन इंटरफ़ेस प्रदान करता है।

import unittest
def fibonacci(n):
   a, b = 0, 1
   for i in range(n):
   a, b = b, a + b
   return a
class Fibo_Test(unittest.TestCase):
   def setUp(self):
   print("This is run before our tests would be executed")
   def tearDown(self):
   print("This is run after the completion of execution of our tests")

   def testfibocal(self):
   self.assertEqual(fib(0), 0)
   self.assertEqual(fib(1), 1)
   self.assertEqual(fib(5), 5)
   self.assertEqual(fib(10), 55)
   self.assertEqual(fib(20), 6765)

if __name__ == "__main__":
   unittest.main()

जब कमांड लाइन से चलाया जाता है, तो उपरोक्त स्क्रिप्ट एक आउटपुट उत्पन्न करता है जो इस तरह दिखता है -

उत्पादन

This runs before our tests would be executed.
This runs after the completion of execution of our tests.
.
----------------------------------------------------------------------
Ran 1 test in 0.006s
OK

अब, इसे स्पष्ट करने के लिए, हम अपना कोड बदल रहे हैं, जिससे फाइबोनैचि मॉड्यूल को परिभाषित करने में मदद मिली।

एक उदाहरण के रूप में निम्नलिखित कोड ब्लॉक पर विचार करें -

def fibonacci(n):
   a, b = 0, 1
   for i in range(n):
   a, b = b, a + b
   return a

कोड ब्लॉक में कुछ बदलाव निम्नानुसार किए गए हैं -

def fibonacci(n):
   a, b = 1, 1
   for i in range(n):
   a, b = b, a + b
   return a

अब, बदले हुए कोड के साथ स्क्रिप्ट चलाने के बाद, हम निम्नलिखित आउटपुट प्राप्त करेंगे -

This runs before our tests would be executed.
This runs after the completion of execution of our tests.
F
======================================================================
FAIL: testCalculation (__main__.Fibo_Test)
----------------------------------------------------------------------
Traceback (most recent call last):
File "unitg.py", line 15, in testCalculation
self.assertEqual(fib(0), 0)
AssertionError: 1 != 0
----------------------------------------------------------------------
Ran 1 test in 0.007s

FAILED (failures = 1)

उपरोक्त आउटपुट से पता चलता है कि मॉड्यूल वांछित आउटपुट देने में विफल रहा है।

डॉकटेस्ट मॉड्यूल

डॉकटेस्ट मॉड्यूल यूनिट टेस्टिंग में भी मदद करता है। यह भी अजगर के साथ prepackaged आता है। यह सबसे आसान मॉड्यूल की तुलना में उपयोग करना आसान है। जटिल परीक्षणों के लिए सबसे उपयुक्त मॉड्यूल अधिक उपयुक्त है। सिद्धांत मॉड्यूल का उपयोग करने के लिए, हमें इसे आयात करने की आवश्यकता है। संबंधित फ़ंक्शन के डॉकस्ट्रिंग में उनके आउटपुट के साथ-साथ इंटरैक्टिव पायथन सत्र होना चाहिए।

यदि हमारे कोड में सब कुछ ठीक है, तो डॉकस्टेस्ट मॉड्यूल से कोई आउटपुट नहीं होगा; अन्यथा, यह आउटपुट प्रदान करेगा।

उदाहरण

निम्नलिखित पायथन उदाहरण फाइबोनैचि नामक मॉड्यूल का परीक्षण करने के लिए डॉकस्टेस्ट मॉड्यूल का उपयोग करता है, जो किसी संख्या की फाइबोनैचि श्रृंखला की गणना करने में मदद करता है।

import doctest
def fibonacci(n):
   """
   Calculates the Fibonacci number

   >>> fibonacci(0)
   0
   >>> fibonacci(1)
   1
   >>> fibonacci(10)
   55
   >>> fibonacci(20)
   6765
   >>>

   """
   a, b = 1, 1
   for i in range(n):
   a, b = b, a + b
   return a
      if __name__ == "__main__":
   doctest.testmod()

हम देख सकते हैं कि फ़ॉब नाम के संबंधित फ़ंक्शन के डॉकस्ट्रिंग में आउटपुट के साथ-साथ इंटरैक्टिव पायथन सत्र था। यदि हमारा कोड ठीक है, तो सिद्धांत मॉड्यूल से कोई आउटपुट नहीं होगा। लेकिन यह देखने के लिए कि यह कैसे काम करता है हम इसे -v विकल्प के साथ चला सकते हैं।

(base) D:\ProgramData>python dock_test.py -v
Trying:
   fibonacci(0)
Expecting:
   0
ok
Trying:
   fibonacci(1)
Expecting:
   1
ok
Trying:
   fibonacci(10)
Expecting:
   55
ok
Trying:
   fibonacci(20)
Expecting:
   6765
ok
1 items had no tests:
   __main__
1 items passed all tests:
4 tests in __main__.fibonacci
4 tests in 2 items.
4 passed and 0 failed.
Test passed.

अब, हम उस कोड को बदल देंगे जिसने फाइबोनैचि मॉड्यूल को परिभाषित करने में मदद की

एक उदाहरण के रूप में निम्नलिखित कोड ब्लॉक पर विचार करें -

def fibonacci(n):
   a, b = 0, 1
   for i in range(n):
   a, b = b, a + b
   return a

निम्नलिखित कोड ब्लॉक परिवर्तनों के साथ मदद करता है -

def fibonacci(n):
   a, b = 1, 1
   for i in range(n):
   a, b = b, a + b
   return a

स्क्रिप्ट को बिना -v विकल्प के भी चलाने के बाद, बदले हुए कोड के साथ, हम आउटपुट को नीचे दिखाए गए अनुसार प्राप्त करेंगे।

उत्पादन

(base) D:\ProgramData>python dock_test.py
**********************************************************************
File "unitg.py", line 6, in __main__.fibonacci
Failed example:
   fibonacci(0)
Expected:
   0
Got:
   1
**********************************************************************
File "unitg.py", line 10, in __main__.fibonacci
Failed example:
   fibonacci(10)
Expected:
   55
Got:
   89
**********************************************************************
File "unitg.py", line 12, in __main__.fibonacci
Failed example:
   fibonacci(20)
Expected:
   6765
Got:
   10946
**********************************************************************
1 items had failures:
   3 of 4 in __main__.fibonacci
***Test Failed*** 3 failures.

हम उपरोक्त आउटपुट में देख सकते हैं कि तीन परीक्षण विफल हो गए हैं।