सॉफ्टवेयर परीक्षण अवलोकन

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

सॉफ्टवेयर सत्यापन

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

  • सत्यापन सुनिश्चित करता है कि उत्पाद विकास के तहत उपयोगकर्ता की आवश्यकताओं के अनुसार है।
  • सत्यापन प्रश्न का उत्तर देता है - "क्या हम उस उत्पाद को विकसित कर रहे हैं जो इस सॉफ़्टवेयर से उपयोगकर्ता की सभी जरूरतों का प्रयास करता है?"।
  • सत्यापन उपयोगकर्ता की आवश्यकताओं पर जोर देता है।

सॉफ्टवेयर सत्यापन

सत्यापन यह पुष्टि करने की प्रक्रिया है कि क्या सॉफ्टवेयर व्यावसायिक आवश्यकताओं को पूरा कर रहा है, और उचित विनिर्देशों और कार्यप्रणाली का पालन करते हुए विकसित किया गया है।

  • सत्यापन यह सुनिश्चित करता है कि विकसित किया जा रहा उत्पाद डिजाइन विनिर्देशों के अनुसार हो।
  • सत्यापन प्रश्न का उत्तर देता है- "क्या हम इस उत्पाद को सभी डिजाइन विनिर्देशों का दृढ़ता से पालन करते हुए विकसित कर रहे हैं?"
  • सत्यापन डिजाइन और सिस्टम विनिर्देशों पर ध्यान केंद्रित करता है।

परीक्षण के लक्ष्य हैं -

  • Errors- ये डेवलपर्स द्वारा की गई वास्तविक कोडिंग गलतियाँ हैं। इसके अलावा, सॉफ्टवेयर के उत्पादन और वांछित आउटपुट में अंतर होता है, इसे त्रुटि माना जाता है।

  • Fault- जब गलती मौजूद हो तो गलती होती है। एक गलती, जिसे बग के रूप में भी जाना जाता है, एक त्रुटि का परिणाम है जो सिस्टम को विफल करने का कारण बन सकता है।

  • Failure - विफलता को वांछित कार्य करने के लिए सिस्टम की अक्षमता कहा जाता है। विफलता तब होती है जब सिस्टम में गलती मौजूद होती है।

मैनुअल बनाम स्वचालित परीक्षण

परीक्षण या तो मैन्युअल रूप से या स्वचालित परीक्षण उपकरण का उपयोग करके किया जा सकता है:

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

    मैनुअल परीक्षण समय और संसाधन खपत है। परीक्षक को यह पुष्टि करने की आवश्यकता है कि क्या सही परीक्षण मामलों का उपयोग किया जाता है या नहीं। परीक्षण के प्रमुख भाग में मैनुअल परीक्षण शामिल है।

  • Automatedयह परीक्षण स्वचालित परीक्षण उपकरण की सहायता से किया गया परीक्षण प्रक्रिया है। स्वचालित परीक्षण उपकरणों का उपयोग करके मैन्युअल परीक्षण की सीमाओं को दूर किया जा सकता है।

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

सॉफ्टवेयर और हार्डवेयर उपकरण हैं जो लोड परीक्षण, तनाव परीक्षण, प्रतिगमन परीक्षण करने में परीक्षक की मदद करते हैं।

परीक्षण दृष्टिकोण

टेस्ट दो दृष्टिकोणों के आधार पर आयोजित किए जा सकते हैं -

  • कार्यात्मकता परीक्षण
  • कार्यान्वयन परीक्षण

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

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

ब्लैक-बॉक्स परीक्षण

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

इस परीक्षण विधि में, कोड का डिज़ाइन और संरचना परीक्षक को ज्ञात नहीं है, और परीक्षण इंजीनियर और अंतिम उपयोगकर्ता सॉफ़्टवेयर पर इस परीक्षण का संचालन करते हैं।

ब्लैक-बॉक्स परीक्षण तकनीक:

  • Equivalence class- इनपुट को समान वर्गों में विभाजित किया गया है। यदि किसी कक्षा का एक तत्व परीक्षा पास करता है, तो यह माना जाता है कि सभी कक्षा उत्तीर्ण है।

  • Boundary values- इनपुट को उच्च और निम्न अंत मानों में विभाजित किया गया है। यदि ये मान परीक्षण को पास करते हैं, तो यह माना जाता है कि बीच में सभी मान भी पास हो सकते हैं।

  • Cause-effect graphing- पिछले दोनों तरीकों में, एक समय में केवल एक इनपुट वैल्यू का परीक्षण किया जाता है। कारण (इनपुट) - प्रभाव (आउटपुट) एक परीक्षण तकनीक है जहां इनपुट मूल्यों के संयोजन को एक व्यवस्थित तरीके से परीक्षण किया जाता है।

  • Pair-wise Testing- सॉफ्टवेयर का व्यवहार कई मापदंडों पर निर्भर करता है। जोड़ीवार परीक्षण में, कई मापदंडों को उनके विभिन्न मूल्यों के लिए जोड़ी-वार परीक्षण किया जाता है।

  • State-based testing- इनपुट के प्रावधान पर सिस्टम में परिवर्तन होता है। इन प्रणालियों का परीक्षण उनके राज्यों और इनपुट के आधार पर किया जाता है।

सफेद बॉक्स परीक्षण

यह कोड दक्षता या संरचना को बेहतर बनाने के लिए कार्यक्रम और इसके कार्यान्वयन का परीक्षण करने के लिए आयोजित किया जाता है। इसे 'स्ट्रक्चरल' परीक्षण के रूप में भी जाना जाता है।

इस परीक्षण विधि में, कोड के डिजाइन और संरचना को परीक्षक को जाना जाता है। कोड के प्रोग्रामर इस टेस्ट को कोड पर आयोजित करते हैं।

नीचे कुछ व्हाइट-बॉक्स परीक्षण तकनीकें दी गई हैं:

  • Control-flow testing- परीक्षण मामलों को सेट करने के लिए नियंत्रण-प्रवाह परीक्षण का उद्देश्य जो सभी बयानों और शाखा स्थितियों को कवर करता है। शाखा की स्थितियों का परीक्षण सही और गलत दोनों के लिए किया जाता है, ताकि सभी विवरणों को कवर किया जा सके।

  • Data-flow testing- यह परीक्षण तकनीक कार्यक्रम में शामिल सभी डेटा चर को कवर करने पर जोर देती है। यह परीक्षण करता है कि चर कहां घोषित किए गए थे और परिभाषित किए गए थे और कहां उनका उपयोग किया गया था या बदल दिया गया था।

परीक्षण स्तर

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

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

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

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

एकीकरण जांच

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

सिस्टम परीक्षण

सॉफ्टवेयर को उत्पाद के रूप में संकलित किया जाता है और फिर इसे संपूर्ण रूप में परखा जाता है। यह निम्नलिखित परीक्षणों में से एक या अधिक का उपयोग करके पूरा किया जा सकता है:

  • Functionality testing - आवश्यकता के विरुद्ध सॉफ्टवेयर की सभी क्रियाओं का परीक्षण।

  • Performance testing- यह परीक्षण साबित करता है कि सॉफ्टवेयर कितना कुशल है। यह वांछित कार्य करने के लिए सॉफ्टवेयर द्वारा लिए गए प्रभावशीलता और औसत समय का परीक्षण करता है। प्रदर्शन परीक्षण लोड परीक्षण और तनाव परीक्षण के माध्यम से किया जाता है जहां सॉफ्टवेयर को विभिन्न उपयोगकर्ता स्थितियों के तहत उच्च उपयोगकर्ता और डेटा लोड के तहत रखा जाता है।

  • Security & Portability - ये परीक्षण तब किए जाते हैं जब सॉफ्टवेयर विभिन्न प्लेटफार्मों पर काम करने के लिए होता है और व्यक्तियों की संख्या के आधार पर पहुंचता है।

स्वीकृति परीक्षण

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

  • Alpha testing- डेवलपर की टीम सिस्टम का उपयोग करके स्वयं अल्फा परीक्षण करती है जैसे कि यह कार्य वातावरण में उपयोग किया जा रहा है। वे यह पता लगाने की कोशिश करते हैं कि उपयोगकर्ता सॉफ़्टवेयर में कुछ कार्रवाई पर कैसे प्रतिक्रिया देगा और सिस्टम को इनपुट पर प्रतिक्रिया कैसे देनी चाहिए।

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

प्रतिगमन परीक्षण

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

परीक्षण प्रलेखन

परीक्षण दस्तावेज विभिन्न चरणों में तैयार किए जाते हैं -

परीक्षण से पहले

परीक्षण परीक्षण मामलों की पीढ़ी के साथ शुरू होता है। संदर्भ के लिए निम्नलिखित दस्तावेजों की आवश्यकता है -

  • SRS document - कार्यात्मक आवश्यकताएँ दस्तावेज़

  • Test Policy document - यह बताता है कि उत्पाद को जारी करने से पहले कितनी दूर परीक्षण करना चाहिए।

  • Test Strategy document - इसमें परीक्षण टीम, जिम्मेदारी मैट्रिक्स और परीक्षण प्रबंधक और परीक्षण इंजीनियर के अधिकारों / जिम्मेदारी के विस्तार पहलुओं का उल्लेख है।

  • Traceability Matrix document- यह एसडीएलसी दस्तावेज है, जो आवश्यकता एकत्र करने की प्रक्रिया से संबंधित है। जैसे ही नई आवश्यकताएं आती हैं, उन्हें इस मैट्रिक्स में जोड़ दिया जाता है। ये मैट्रीस परीक्षकों को आवश्यकता के स्रोत को जानने में मदद करते हैं। उन्हें आगे और पीछे का पता लगाया जा सकता है।

जबकि परीक्षण किया जा रहा है

परीक्षण शुरू होने के दौरान निम्नलिखित दस्तावेजों की आवश्यकता हो सकती है और किया जा रहा है:

  • Test Case document- इस दस्तावेज़ में आयोजित किए जाने वाले परीक्षणों की सूची है। इसमें इकाई परीक्षण योजना, एकीकरण परीक्षण योजना, प्रणाली परीक्षण योजना और स्वीकृति परीक्षण योजना शामिल हैं।

  • Test description - यह दस्तावेज़ उन्हें निष्पादित करने के लिए सभी परीक्षण मामलों और प्रक्रियाओं का विस्तृत विवरण है।

  • Test case report - इस दस्तावेज़ में परीक्षण के परिणामस्वरूप परीक्षण मामले की रिपोर्ट है।

  • Test logs - इस दस्तावेज़ में प्रत्येक परीक्षण मामले की रिपोर्ट के लिए परीक्षण लॉग होते हैं।

परीक्षण के बाद

परीक्षण के बाद निम्नलिखित दस्तावेज तैयार किए जा सकते हैं:

  • Test summary- यह परीक्षण सारांश सभी परीक्षण रिपोर्ट और लॉग का सामूहिक विश्लेषण है। यह संक्षेप और निष्कर्ष निकालता है कि सॉफ्टवेयर लॉन्च होने के लिए तैयार है या नहीं। सॉफ्टवेयर संस्करण नियंत्रण प्रणाली के तहत जारी किया जाता है अगर यह लॉन्च करने के लिए तैयार है।

परीक्षण बनाम गुणवत्ता नियंत्रण, गुणवत्ता आश्वासन और लेखा परीक्षा

हमें यह समझने की आवश्यकता है कि सॉफ़्टवेयर परीक्षण सॉफ़्टवेयर गुणवत्ता आश्वासन, सॉफ़्टवेयर गुणवत्ता नियंत्रण और सॉफ़्टवेयर ऑडिटिंग से अलग है।

  • Software quality assurance- ये सॉफ्टवेयर डेवलपमेंट प्रोसेस मॉनिटरिंग साधन हैं, जिनके द्वारा यह आश्वासन दिया जाता है कि संगठन के मानकों के अनुसार सभी उपाय किए जाते हैं। यह निगरानी यह सुनिश्चित करने के लिए की जाती है कि उचित सॉफ्टवेयर विकास विधियों का पालन किया गया था।

  • Software quality control- यह सॉफ्टवेयर उत्पाद की गुणवत्ता को बनाए रखने के लिए एक प्रणाली है। इसमें सॉफ्टवेयर उत्पाद के कार्यात्मक और गैर-कार्यात्मक पहलू शामिल हो सकते हैं, जो संगठन की सद्भावना को बढ़ाते हैं। यह प्रणाली यह सुनिश्चित करती है कि ग्राहक अपनी आवश्यकता के लिए गुणवत्तापूर्ण उत्पाद प्राप्त कर रहा है और उत्पाद 'उपयोग के लिए उपयुक्त' के रूप में प्रमाणित है।

  • Software audit- यह सॉफ्टवेयर को विकसित करने के लिए संगठन द्वारा उपयोग की जाने वाली प्रक्रिया की समीक्षा है। ऑडिटर्स की एक टीम, विकास टीम से स्वतंत्र सॉफ्टवेयर प्रक्रिया, प्रक्रिया, आवश्यकताओं और एसडीएलसी के अन्य पहलुओं की जांच करती है। सॉफ्टवेयर ऑडिट का उद्देश्य उस सॉफ्टवेयर और उसकी विकास प्रक्रिया की जांच करना है, दोनों मानकों, नियमों और विनियमों के अनुरूप हैं।