सॉफ्टवेयर परीक्षण - स्तर
परीक्षण की प्रक्रिया के दौरान विभिन्न स्तर होते हैं। इस अध्याय में, इन स्तरों के बारे में एक संक्षिप्त विवरण प्रदान किया गया है।
परीक्षण के स्तरों में अलग-अलग कार्यप्रणालियाँ शामिल हैं जिनका उपयोग सॉफ्टवेयर परीक्षण करते समय किया जा सकता है। सॉफ्टवेयर परीक्षण के मुख्य स्तर हैं -
क्रियात्मक परीक्षण
गैर-कार्यात्मक परीक्षण
क्रियात्मक परीक्षण
यह एक प्रकार का ब्लैक-बॉक्स परीक्षण है जो परीक्षण किए जाने वाले सॉफ़्टवेयर की विशिष्टताओं पर आधारित है। एप्लिकेशन को इनपुट प्रदान करके परीक्षण किया जाता है और फिर परिणामों की जांच की जाती है कि इसके लिए इच्छित कार्यक्षमता के अनुरूप होने की आवश्यकता है। किसी सॉफ्टवेयर का कार्यात्मक परीक्षण प्रणाली के अनुपालन के लिए उसकी निर्दिष्ट आवश्यकताओं के मूल्यांकन के लिए एक पूर्ण, एकीकृत प्रणाली पर किया जाता है।
कार्यक्षमता के लिए एक आवेदन का परीक्षण करते समय पांच चरण शामिल होते हैं।
कदम | विवरण |
---|---|
मैं | कार्यक्षमता का निर्धारण जो इच्छित अनुप्रयोग प्रदर्शन करने के लिए है। |
द्वितीय | आवेदन के विनिर्देशों के आधार पर परीक्षण डेटा का निर्माण। |
तृतीय | परीक्षण डेटा और एप्लिकेशन के विनिर्देशों के आधार पर आउटपुट। |
चतुर्थ | परीक्षण परिदृश्यों का लेखन और परीक्षण मामलों का निष्पादन। |
वी | निष्पादित परीक्षण मामलों के आधार पर वास्तविक और अपेक्षित परिणामों की तुलना। |
एक प्रभावी परीक्षण अभ्यास हर संगठन की परीक्षण नीतियों पर लागू उपरोक्त चरणों को देखेगा और इसलिए यह सुनिश्चित करेगा कि सॉफ्टवेयर गुणवत्ता की बात करते समय संगठन मानकों को सबसे सख्त बनाए रखता है।
इकाई का परीक्षण
परीक्षण मामलों को औपचारिक रूप से निष्पादित करने के लिए परीक्षण टीम को सौंपने से पहले इस प्रकार का परीक्षण डेवलपर्स द्वारा किया जाता है। यूनिट परीक्षण संबंधित डेवलपर्स द्वारा स्रोत कोड निर्दिष्ट क्षेत्रों की व्यक्तिगत इकाइयों द्वारा किया जाता है। डेवलपर्स परीक्षण डेटा का उपयोग करते हैं जो गुणवत्ता आश्वासन टीम के परीक्षण डेटा से अलग है।
इकाई परीक्षण का लक्ष्य कार्यक्रम के प्रत्येक भाग को अलग करना और यह दिखाना है कि व्यक्तिगत भाग आवश्यकताओं और कार्यक्षमता के मामले में सही हैं।
यूनिट परीक्षण की सीमाएं
परीक्षण एक आवेदन में प्रत्येक बग को पकड़ नहीं सकता है। प्रत्येक सॉफ़्टवेयर एप्लिकेशन में प्रत्येक निष्पादन पथ का मूल्यांकन करना असंभव है। यही हाल यूनिट टेस्टिंग का है।
परिदृश्यों और परीक्षण डेटा की संख्या की एक सीमा है जो एक डेवलपर किसी स्रोत कोड को सत्यापित करने के लिए उपयोग कर सकता है। सभी विकल्पों को समाप्त करने के बाद, यूनिट परीक्षण को रोकने और अन्य इकाइयों के साथ कोड सेगमेंट को मर्ज करने के अलावा कोई विकल्प नहीं है।
एकीकरण जांच
एकीकरण परीक्षण को किसी अनुप्रयोग के संयुक्त भागों के परीक्षण के रूप में परिभाषित किया जाता है ताकि यह निर्धारित किया जा सके कि वे सही ढंग से कार्य करते हैं। एकीकरण परीक्षण दो तरीकों से किया जा सकता है: नीचे-अप एकीकरण परीक्षण और टॉप-डाउन एकीकरण परीक्षण।
अनु क्रमांक। | एकीकरण परीक्षण विधि |
---|---|
1 | Bottom-up integration यह परीक्षण इकाई परीक्षण से शुरू होता है, इसके बाद मॉड्यूल या बिल्ड नामक इकाइयों के उत्तरोत्तर उच्च-स्तरीय संयोजनों का परीक्षण किया जाता है। |
2 | Top-down integration इस परीक्षण में, उच्चतम-स्तरीय मॉड्यूल का परीक्षण पहले और उत्तरोत्तर, निचले-स्तर के मॉड्यूल का परीक्षण किया जाता है। |
एक व्यापक सॉफ्टवेयर विकास वातावरण में, बॉटम-अप परीक्षण आमतौर पर पहले किया जाता है, उसके बाद टॉप-डाउन परीक्षण किया जाता है। प्रक्रिया पूरी तरह से आवेदन के कई परीक्षणों के साथ समाप्त होती है, अधिमानतः वास्तविक स्थितियों की नकल करने के लिए डिज़ाइन किए गए परिदृश्यों में।
सिस्टम परीक्षण
सिस्टम टेस्टिंग पूरे सिस्टम को टेस्ट करता है। एक बार जब सभी घटक एकीकृत हो जाते हैं, तो एक पूरे के रूप में आवेदन को यह देखने के लिए कड़ाई से परीक्षण किया जाता है कि यह निर्दिष्ट गुणवत्ता मानकों को पूरा करता है। इस प्रकार का परीक्षण एक विशेष परीक्षण टीम द्वारा किया जाता है।
निम्नलिखित कारणों से सिस्टम परीक्षण महत्वपूर्ण है -
सिस्टम टेस्टिंग सॉफ्टवेयर डेवलपमेंट लाइफ साइकल का पहला चरण है, जहाँ एप्लिकेशन का संपूर्ण रूप से परीक्षण किया जाता है।
यह सत्यापित करने के लिए कि यह कार्यात्मक और तकनीकी विशिष्टताओं को पूरा करता है, एप्लिकेशन को अच्छी तरह से जांचा जाता है।
एप्लिकेशन का परीक्षण एक ऐसे वातावरण में किया जाता है जो उत्पादन वातावरण के बहुत करीब होता है, जहां एप्लिकेशन को तैनात किया जाएगा।
सिस्टम परीक्षण हमें व्यावसायिक आवश्यकताओं के साथ-साथ एप्लिकेशन आर्किटेक्चर दोनों का परीक्षण, सत्यापन और सत्यापन करने में सक्षम बनाता है।
प्रतिगमन परीक्षण
जब भी किसी सॉफ़्टवेयर एप्लिकेशन में कोई परिवर्तन किया जाता है, तो यह बहुत संभव है कि अनुप्रयोग के भीतर के अन्य क्षेत्र इस परिवर्तन से प्रभावित हुए हों। प्रतिगमन परीक्षण यह सत्यापित करने के लिए किया जाता है कि एक निश्चित बग किसी अन्य कार्यक्षमता या व्यावसायिक नियम के उल्लंघन का परिणाम नहीं है। प्रतिगमन परीक्षण का उद्देश्य यह सुनिश्चित करना है कि बग फिक्स के रूप में एक परिवर्तन, आवेदन में एक और गलती का परिणाम नहीं होना चाहिए।
निम्नलिखित कारणों से प्रतिगमन परीक्षण महत्वपूर्ण है -
परीक्षण में अंतराल कम करें जब किए गए परिवर्तनों के साथ एक आवेदन का परीक्षण किया जाना है।
यह सत्यापित करने के लिए कि परिवर्तन किए गए नए परिवर्तनों का परीक्षण आवेदन के किसी अन्य क्षेत्र को प्रभावित नहीं करता है।
जब आवेदन पर प्रतिगमन परीक्षण किया जाता है, तो जोखिमों को कम करता है।
समयसीमा से समझौता किए बिना टेस्ट कवरेज बढ़ाया जाता है।
उत्पाद की मार्केटिंग के लिए गति बढ़ाएं।
स्वीकृति परीक्षण
यह यकीनन सबसे महत्वपूर्ण प्रकार का परीक्षण है, क्योंकि यह क्वालिटी एश्योरेंस टीम द्वारा संचालित किया जाता है, जो इस बात का अनुमान लगाएगा कि क्या आवेदन विशिष्ट विनिर्देशों को पूरा करता है और ग्राहक की आवश्यकता को पूरा करता है। क्यूए टीम में पूर्व-लिखित परिदृश्य और परीक्षण मामलों का एक सेट होगा, जिसका उपयोग अनुप्रयोग का परीक्षण करने के लिए किया जाएगा।
आवेदन के बारे में अधिक विचार साझा किए जाएंगे और इसकी सटीकता और उन कारणों के बारे में अधिक परीक्षण किए जा सकते हैं, जिनके कारण परियोजना शुरू की गई थी। स्वीकृति परीक्षणों का उद्देश्य न केवल सरल वर्तनी की गलतियों, कॉस्मेटिक त्रुटियों या इंटरफ़ेस अंतराल को इंगित करना है, बल्कि आवेदन में किसी भी कीड़े को इंगित करना है जिसके परिणामस्वरूप सिस्टम क्रैश या एप्लिकेशन में बड़ी त्रुटियां होंगी।
एक आवेदन पर स्वीकृति परीक्षण करके, परीक्षण टीम कम कर देगी कि आवेदन उत्पादन में कैसा प्रदर्शन करेगा। प्रणाली की स्वीकृति के लिए कानूनी और संविदात्मक आवश्यकताएं भी हैं।
अल्फा परीक्षण
यह परीक्षण परीक्षण का पहला चरण है और टीमों (डेवलपर और क्यूए टीमों) के बीच किया जाएगा। यूनिट टेस्टिंग, इंटीग्रेशन टेस्टिंग और सिस्टम टेस्टिंग जब एक साथ होते हैं तो अल्फा टेस्टिंग के रूप में जाना जाता है। इस चरण के दौरान, आवेदन में निम्नलिखित पहलुओं का परीक्षण किया जाएगा -
वर्तनी त्रुटि
टूटे हुए लिंक
बादल की दिशाएँ
लोडिंग समय और किसी भी विलंबता समस्याओं का परीक्षण करने के लिए सबसे कम विनिर्देशन वाली मशीनों पर एप्लिकेशन का परीक्षण किया जाएगा।
बीटा परीक्षण
अल्फा परीक्षण सफलतापूर्वक किए जाने के बाद यह परीक्षण किया जाता है। बीटा परीक्षण में, इच्छित दर्शकों का एक नमूना अनुप्रयोग का परीक्षण करता है। बीटा परीक्षण के रूप में भी जाना जाता हैpre-release testing। सॉफ्टवेयर के बीटा परीक्षण संस्करणों को आदर्श रूप से वेब पर एक विस्तृत दर्शकों को वितरित किया जाता है, आंशिक रूप से कार्यक्रम को "वास्तविक दुनिया" परीक्षण देने के लिए और आंशिक रूप से अगली रिलीज का पूर्वावलोकन प्रदान करने के लिए। इस चरण में, दर्शक निम्नलिखित परीक्षण करेंगे -
उपयोगकर्ता एप्लिकेशन इंस्टॉल करेंगे, और प्रोजेक्ट टीम को अपनी प्रतिक्रिया भेजेंगे।
टंकण संबंधी त्रुटियां, भ्रामक अनुप्रयोग प्रवाह, और यहां तक कि क्रैश भी।
प्रतिक्रिया प्राप्त करना, परियोजना टीम वास्तविक उपयोगकर्ताओं को सॉफ़्टवेयर जारी करने से पहले समस्याओं को ठीक कर सकती है।
आप वास्तविक उपयोगकर्ता की समस्याओं को हल करने वाले मुद्दों को जितना अधिक हल करेंगे, आपके आवेदन की गुणवत्ता उतनी ही अधिक होगी।
जब आप इसे आम जनता के लिए जारी करते हैं तो उच्च-गुणवत्ता वाला अनुप्रयोग होने से ग्राहकों की संतुष्टि बढ़ेगी।
गैर-कार्यात्मक परीक्षण
यह खंड अपने गैर-कार्यात्मक विशेषताओं से एक आवेदन का परीक्षण करने पर आधारित है। गैर-कार्यात्मक परीक्षण में आवश्यकताओं से एक सॉफ्टवेयर का परीक्षण करना शामिल है जो प्रकृति में गैर-विचारणीय है लेकिन प्रदर्शन, सुरक्षा, उपयोगकर्ता इंटरफ़ेस आदि जैसे महत्वपूर्ण हैं।
कुछ महत्वपूर्ण और आमतौर पर उपयोग किए जाने वाले गैर-कार्यात्मक परीक्षण प्रकार नीचे चर्चा किए गए हैं।
प्रदर्शन का परीक्षण
इसका उपयोग ज्यादातर किसी सॉफ़्टवेयर में बग ढूंढने के बजाय किसी भी अड़चन या प्रदर्शन के मुद्दों की पहचान करने के लिए किया जाता है। अलग-अलग कारण हैं जो एक सॉफ्टवेयर के प्रदर्शन को कम करने में योगदान करते हैं -
नेटवर्क में देरी
ग्राहक-पक्ष प्रसंस्करण
डेटाबेस लेनदेन प्रसंस्करण
सर्वर के बीच लोड संतुलन
डेटा रेंडरिंग
प्रदर्शन परीक्षण को निम्नलिखित पहलुओं के संदर्भ में महत्वपूर्ण और अनिवार्य परीक्षण प्रकार में से एक माना जाता है -
स्पीड (यानी रिस्पांस टाइम, डेटा रेंडरिंग और एक्सेसिंग)
Capacity
Stability
Scalability
प्रदर्शन परीक्षण या तो गुणात्मक या मात्रात्मक हो सकता है और विभिन्न उप-प्रकारों में विभाजित किया जा सकता है जैसे कि Load testing तथा Stress testing।
लोड परीक्षण
यह सॉफ्टवेयर के उपयोग और बड़े इनपुट डेटा में हेरफेर करने के मामले में अधिकतम भार को लागू करके सॉफ्टवेयर के व्यवहार का परीक्षण करने की एक प्रक्रिया है। यह सामान्य और शिखर लोड दोनों स्थितियों में किया जा सकता है। इस प्रकार का परीक्षण सॉफ्टवेयर की अधिकतम क्षमता और चरम समय पर इसके व्यवहार की पहचान करता है।
ज्यादातर समय, लोड परीक्षण स्वचालित उपकरण जैसे लोड रनर, अप्प्लाडर, आईबीएम तर्कसंगत प्रदर्शन परीक्षक, अपाचे जेमीटर, सिल्क कलाकार, विज़ुअल स्टूडियो लोड टेस्ट, आदि की सहायता से किया जाता है।
वर्चुअल उपयोगकर्ताओं (VUsers) को स्वचालित परीक्षण उपकरण में परिभाषित किया गया है और सॉफ्टवेयर के लिए लोड परीक्षण को सत्यापित करने के लिए स्क्रिप्ट निष्पादित की गई है। आवश्यकताओं के आधार पर उपयोगकर्ताओं की संख्या समवर्ती या वृद्धिशील रूप से बढ़ाई या घटाई जा सकती है।
तनाव परीक्षण
तनाव परीक्षण में असामान्य परिस्थितियों में एक सॉफ्टवेयर के व्यवहार का परीक्षण शामिल है। उदाहरण के लिए, इसमें कुछ संसाधनों को निकालना या वास्तविक लोड सीमा से परे लोड लागू करना शामिल हो सकता है।
तनाव परीक्षण का उद्देश्य सिस्टम में लोड को लागू करके सॉफ़्टवेयर का परीक्षण करना है और ब्रेकिंग पॉइंट की पहचान करने के लिए सॉफ़्टवेयर द्वारा उपयोग किए गए संसाधनों को लेना है। यह परीक्षण विभिन्न परिदृश्यों जैसे -
नेटवर्क पोर्ट को बेतरतीब ढंग से बंद करना या फिर से शुरू करना
डेटाबेस को चालू या बंद करना
विभिन्न प्रक्रियाओं को चलाना जो CPU, मेमोरी, सर्वर आदि जैसे संसाधनों का उपभोग करते हैं।
उपयोगिता परीक्षण
प्रयोज्यता परीक्षण एक ब्लैक-बॉक्स तकनीक है और इसका उपयोग उपयोगकर्ताओं को उनके उपयोग और संचालन के माध्यम से सॉफ्टवेयर में किसी भी त्रुटि (सुधारों) की पहचान करने के लिए किया जाता है।
नीलसन के अनुसार, प्रयोज्य को पाँच कारकों के संदर्भ में परिभाषित किया जा सकता है, अर्थात् उपयोग की दक्षता, सीखने की क्षमता, स्मृति-क्षमता, त्रुटियां / सुरक्षा और संतुष्टि। उनके अनुसार, किसी उत्पाद की प्रयोज्यता अच्छी होगी और उपरोक्त कारकों के पास होने पर यह प्रणाली प्रयोग करने योग्य होगी।
निगेल बेवन और मैकलोड ने माना कि प्रयोज्य गुणवत्ता की आवश्यकता है जिसे कंप्यूटर प्रणाली के साथ बातचीत के परिणाम के रूप में मापा जा सकता है। इस आवश्यकता को पूरा किया जा सकता है और अंत-उपयोगकर्ता संतुष्ट हो जाएगा यदि उचित लक्ष्यों को उचित संसाधनों के उपयोग के साथ प्रभावी ढंग से प्राप्त किया जाता है।
2000 में मोलिच ने कहा कि एक उपयोगकर्ता के अनुकूल प्रणाली को निम्नलिखित पांच लक्ष्यों को पूरा करना चाहिए, अर्थात, सीखना आसान, याद रखना आसान, उपयोग करने में कुशल, उपयोग करने में संतोषजनक और समझने में आसान।
प्रयोज्य की विभिन्न परिभाषाओं के अलावा, कुछ मानक और गुणवत्ता वाले मॉडल और विधियां हैं जो आईएसओ-9126, आईएसओ -9241-11, आईएसओ-13407, और आईईईई सीडी जैसी विशेषताओं और उप-विशेषताओं के रूप में प्रयोज्यता को परिभाषित करते हैं। 610.12, आदि।
यूआई बनाम उपयोगिता परीक्षण
यूआई परीक्षण में सॉफ्टवेयर के ग्राफिकल यूजर इंटरफेस का परीक्षण शामिल है। यूआई परीक्षण यह सुनिश्चित करता है कि जीयूआई आवश्यकताओं के अनुसार कार्य करता है और रंग, संरेखण, आकार और अन्य गुणों के संदर्भ में परीक्षण किया जाता है।
दूसरी ओर, प्रयोज्य परीक्षण एक अच्छा और उपयोगकर्ता के अनुकूल जीयूआई सुनिश्चित करता है जिसे आसानी से नियंत्रित किया जा सकता है। यूआई परीक्षण को प्रयोज्य परीक्षण का एक उप-भाग माना जा सकता है।
सुरक्षा परीक्षण
सुरक्षा परीक्षण में सुरक्षा और भेद्यता बिंदु से किसी भी खामियों और अंतराल की पहचान करने के लिए एक सॉफ्टवेयर का परीक्षण शामिल है। नीचे सूचीबद्ध मुख्य पहलू हैं जिन्हें सुरक्षा परीक्षण सुनिश्चित करना चाहिए -
Confidentiality
Integrity
Authentication
Availability
Authorization
Non-repudiation
सॉफ्टवेयर ज्ञात और अज्ञात कमजोरियों के खिलाफ सुरक्षित है
सॉफ्टवेयर डेटा सुरक्षित है
सॉफ्टवेयर सभी सुरक्षा नियमों के अनुसार है
इनपुट जाँच और सत्यापन
एसक्यूएल प्रविष्टि हमलों
इंजेक्शन की खामियां
सत्र प्रबंधन मुद्दे
क्रॉस-साइट स्क्रिप्टिंग हमले
बफर कमजोरियों को ओवरफ्लो करता है
निर्देशिका ट्रैवर्सल हमले
पोर्टेबिलिटी परीक्षण
पोर्टेबिलिटी परीक्षण में पुन: प्रयोज्य सुनिश्चित करने के उद्देश्य से एक सॉफ्टवेयर का परीक्षण शामिल है और इसे किसी अन्य सॉफ़्टवेयर से भी स्थानांतरित किया जा सकता है। पोर्टेबिलिटी परीक्षण के लिए इस्तेमाल की जा सकने वाली रणनीतियाँ निम्नलिखित हैं -
एक कंप्यूटर से दूसरे में स्थापित सॉफ़्टवेयर को स्थानांतरित करना।
विभिन्न प्लेटफार्मों पर सॉफ्टवेयर को चलाने के लिए निष्पादन योग्य (.exe) का निर्माण।
पोर्टेबिलिटी परीक्षण को सिस्टम परीक्षण के उप-भागों में से एक के रूप में माना जा सकता है, क्योंकि इस परीक्षण प्रकार में विभिन्न वातावरणों पर इसके उपयोग के संबंध में एक सॉफ्टवेयर का समग्र परीक्षण शामिल है। कंप्यूटर हार्डवेयर, ऑपरेटिंग सिस्टम और ब्राउज़र पोर्टेबिलिटी परीक्षण का प्रमुख केंद्र हैं। पोर्टेबिलिटी परीक्षण के लिए कुछ पूर्व शर्तें निम्नानुसार हैं -
पोर्टेबिलिटी आवश्यकताओं को ध्यान में रखते हुए सॉफ्टवेयर को डिज़ाइन और कोडित किया जाना चाहिए।
संबंधित घटकों पर यूनिट परीक्षण किया गया है।
एकीकरण परीक्षण किया गया है।
परीक्षण वातावरण स्थापित किया गया है।