निरंतर एकीकरण - जोखिम कम करना
ऐसी संभावना है कि किसी परियोजना पर चीजें गलत हो जाएंगी। सीआई को प्रभावी ढंग से अभ्यास करके, आपको पता चलता है कि रास्ते में हर कदम पर क्या होता है, बल्कि बाद में जब परियोजना विकास चक्र में होती है। सीआई आपको तब होने वाले जोखिमों की पहचान करने और उन्हें कम करने में मदद करता है, जिससे ठोस सबूतों के आधार पर परियोजना के स्वास्थ्य पर मूल्यांकन और रिपोर्ट करना आसान हो जाता है।
यह खंड उन जोखिमों पर ध्यान केंद्रित करने जा रहा है जिन्हें निरंतर एकीकरण का उपयोग करके टाला जा सकता है।
किसी भी परियोजना पर, कई जोखिम हैं जिन्हें प्रबंधित करने की आवश्यकता है। विकास जीवनचक्र में पहले के जोखिमों को समाप्त करके, बाद में मुद्दों पर इन जोखिमों के कम होने की संभावना है, जब सिस्टम वास्तव में जीवित रहेगा।
जोखिम 1 - कमज़ोर सॉफ्टवेयर की कमी
“It works on my machine but does not work on another”- यह शायद किसी भी सॉफ्टवेयर संगठन में सामना किए जाने वाले सबसे आम वाक्यांशों में से एक है। सॉफ़्टवेयर में किए गए परिवर्तनों की संख्या दैनिक आधार पर बनती है, कभी-कभी इस बात पर बहुत कम विश्वास होता है कि सॉफ़्टवेयर का निर्माण वास्तव में काम करता है या नहीं। इस चिंता के निम्नलिखित तीन दुष्प्रभाव हैं।
कम या कोई भरोसा नहीं कि हम सॉफ्टवेयर का निर्माण भी कर सकते थे।
आंतरिक रूप से (यानी, परीक्षण टीम) या बाहरी रूप से (यानी, ग्राहक) को वितरित करने से पहले लंबा एकीकरण चरण, जिसके दौरान और कुछ नहीं किया जाता है।
परीक्षण योग्य बिल्ड का उत्पादन और पुन: पेश करने में असमर्थता।
समाधान
आईडीई और निर्माण प्रक्रियाओं के बीच तंग युग्मन को खत्म करना। सॉफ्टवेयर को एकीकृत करने के लिए पूरी तरह से एक अलग मशीन का उपयोग करें। सुनिश्चित करें कि सॉफ्टवेयर बनाने के लिए आपको जो कुछ भी चाहिए वह संस्करण नियंत्रण भंडार में निहित है। अंत में, एक सतत एकीकरण प्रणाली बनाएँ।
कंटीन्यूअस इंटीग्रेशन सर्वर वर्जन कंट्रोल रिपॉजिटरी में बदलाव के लिए देख सकता है और रिपोजिटरी में बदलाव का पता लगाने पर प्रोजेक्ट बिल्ड स्क्रिप्ट चला सकता है। कंटीन्यूअस इंटीग्रेशन सिस्टम की क्षमता को टेस्ट के माध्यम से बिल्ड रन को शामिल करने, निरीक्षण करने और विकास और परीक्षण वातावरण में सॉफ़्टवेयर को तैनात करने के लिए बढ़ाया जा सकता है; इस तरह से आपके पास हमेशा एक काम करने वाला सॉफ्टवेयर होता है।
“Inability to synchronize with the database”- कभी-कभी डेवलपर्स विकास के दौरान डेटाबेस को जल्दी से फिर से बनाने में असमर्थ होते हैं, और इसलिए परिवर्तन करना मुश्किल होता है। अक्सर यह डेटाबेस टीम और विकास टीम के बीच अलगाव के कारण होता है। प्रत्येक टीम अपनी जिम्मेदारियों पर केंद्रित होगी और एक-दूसरे के बीच बहुत कम सहयोग करेगी। इस चिंता के निम्नलिखित तीन दुष्प्रभाव हैं -
डेटाबेस या स्रोत कोड को बदलने या फिर से बनाने का डर।
परीक्षण डेटा के विभिन्न सेट के साथ डेटाबेस को आबाद करने में कठिनाई।
विकास और परीक्षण वातावरण को बनाए रखने में कठिनाई (जैसे, विकास, एकीकरण, QA और परीक्षण)।
समाधान
उपरोक्त समस्या का समाधान यह सुनिश्चित करना है कि संस्करण नियंत्रण रिपॉजिटरी में सभी डेटाबेस कलाकृतियों का प्लेसमेंट किया जाए। इसका मतलब है कि डेटाबेस स्कीमा और डेटा को फिर से बनाने के लिए आवश्यक सब कुछ: डेटाबेस निर्माण स्क्रिप्ट, डेटा हेरफेर स्क्रिप्ट, संग्रहीत कार्यविधियाँ, ट्रिगर, और किसी भी अन्य डेटाबेस परिसंपत्तियों की आवश्यकता होती है।
अपने डेटाबेस और तालिकाओं को छोड़ने और पुन: निर्माण करके, अपनी बिल्ड स्क्रिप्ट से डेटाबेस और डेटा का पुनर्निर्माण करें। अगला, संग्रहीत कार्यविधियाँ और ट्रिगर लागू करें, और अंत में, परीक्षण डेटा डालें।
अपने डेटाबेस का परीक्षण (और निरीक्षण) करें। आमतौर पर, आप डेटाबेस और डेटा का परीक्षण करने के लिए घटक परीक्षणों का उपयोग करेंगे। कुछ मामलों में, आपको डेटाबेस-विशिष्ट परीक्षण लिखने की आवश्यकता होगी।
जोखिम 2 - जीवनचक्र में देरी की खोज करना
चूंकि बहुत सारे परिवर्तन होते हैं जो कई डेवलपर्स द्वारा स्रोत कोड में अक्सर होते हैं, हमेशा संभावना होती है कि कोड में एक दोष पेश किया जा सकता है जिसे केवल बाद के चरण में पता लगाया जा सकता है। ऐसे मामलों में, यह एक बड़ा प्रभाव पैदा कर सकता है क्योंकि बाद में सॉफ़्टवेयर में दोष का पता लगाया जाता है, दोष को दूर करने के लिए यह जितना अधिक महंगा होता है।
समाधान
Regression Testing- यह किसी भी सॉफ्टवेयर विकास चक्र, परीक्षण और परीक्षण का सबसे महत्वपूर्ण पहलू है। यदि सॉफ़्टवेयर कोड में कोई बड़ा बदलाव है, तो यह सुनिश्चित करना अनिवार्य है कि सभी परीक्षण चलाए जाएं। और इसे Continuous Integration सर्वर की मदद से स्वचालित किया जा सकता है।
Test Coverage- परीक्षण का कोई मतलब नहीं है अगर परीक्षण के मामले कोड की पूरी कार्यक्षमता को कवर नहीं करते हैं। यह सुनिश्चित करना महत्वपूर्ण है कि आवेदन का परीक्षण करने के लिए बनाए गए परीक्षण मामले पूर्ण हैं और सभी कोड पथ का परीक्षण किया गया है।
उदाहरण के लिए, यदि आपके पास एक लॉगिन स्क्रीन है जिसे जांचने की आवश्यकता है, तो आपके पास एक परीक्षण मामला नहीं हो सकता है जिसमें सफल लॉगिन का परिदृश्य हो। आपके पास एक नकारात्मक परीक्षण मामला होना चाहिए जिसमें एक उपयोगकर्ता उपयोगकर्ता नामों और पासवर्डों के एक अलग संयोजन में प्रवेश करता है और फिर यह देखना आवश्यक है कि ऐसे परिदृश्यों में क्या होता है।
जोखिम 3 - प्रोजेक्ट विजिबिलिटी का अभाव
नियत समय पर सही लोगों को परियोजना की जानकारी का प्रसार सुनिश्चित करने के लिए मैनुअल संचार तंत्र में बहुत समन्वय की आवश्यकता होती है। आपके बगल में डेवलपर को झुकना और उन्हें यह बताना कि नवीनतम निर्माण साझा ड्राइव पर है, बल्कि प्रभावी है, फिर भी यह बहुत अच्छा नहीं है।
क्या होगा अगर अन्य डेवलपर्स हैं जिन्हें इस जानकारी की आवश्यकता है और वे ब्रेक पर हैं या अन्यथा अनुपलब्ध हैं? यदि कोई सर्वर डाउन हो जाता है, तो आपको कैसे सूचित किया जाता है? कुछ का मानना है कि वे स्वयं ई-मेल भेजकर इस जोखिम को कम कर सकते हैं। हालाँकि, यह सुनिश्चित नहीं कर सकता है कि सूचना सही समय पर सही लोगों को दी गई है क्योंकि आप गलती से इच्छुक पार्टियों को छोड़ सकते हैं, और कुछ के पास उस समय उनके ई-मेल तक पहुंच नहीं हो सकती है।
समाधान
इस समस्या का समाधान फिर से कंटीन्यूअस इंटीग्रेशन सर्वर है। सभी सीआई सर्वर में स्वचालित ईमेल होने की सुविधा है जब भी बिल्ड विफल हो जाते हैं। सभी प्रमुख हितधारकों के लिए इस स्वचालित अधिसूचना द्वारा, यह भी सुनिश्चित किया जाता है कि हर कोई सॉफ्टवेयर की वर्तमान स्थिति पर बोर्ड पर है।
जोखिम 4 - निम्न गुणवत्ता सॉफ्टवेयर
दोष हैं और फिर संभावित दोष हैं। जब आपके सॉफ़्टवेयर को अच्छी तरह से डिज़ाइन नहीं किया गया है या यदि यह प्रोजेक्ट मानकों का पालन नहीं कर रहा है, या बनाए रखने के लिए जटिल है, तो आपके पास संभावित दोष हो सकते हैं। कभी-कभी लोग इसे कोड या डिज़ाइन की गंध के रूप में संदर्भित करते हैं - "एक लक्षण जो कुछ गलत हो सकता है।"
कुछ का मानना है कि कम-गुणवत्ता वाले सॉफ़्टवेयर केवल एक आस्थगित परियोजना लागत (डिलीवरी के बाद) है। यह एक आस्थगित परियोजना लागत हो सकती है, लेकिन इससे पहले कि आप उपयोगकर्ताओं को सॉफ़्टवेयर वितरित करें, इससे कई अन्य समस्याएं भी हो सकती हैं। अत्यधिक जटिल कोड, कोड जो आर्किटेक्चर का पालन नहीं करता है, और डुप्लिकेट कोड - सभी आमतौर पर सॉफ़्टवेयर में दोष पैदा करते हैं। इन कोड और डिज़ाइन को खोजने से पहले वे दोष में प्रकट होते हैं और समय और धन दोनों बचा सकते हैं, और उच्च गुणवत्ता वाले सॉफ़्टवेयर का नेतृत्व कर सकते हैं।
समाधान
एक कोड गुणवत्ता जांच करने के लिए सॉफ्टवेयर घटक हैं जिन्हें CI सॉफ्टवेयर के साथ एकीकृत किया जा सकता है। यह कोड के निर्माण के बाद चलाया जा सकता है ताकि यह सुनिश्चित हो सके कि कोड वास्तव में उचित कोडिंग दिशानिर्देशों के अनुरूप है।