कोड अखंडता: Difference between revisions
No edit summary |
m (added Category:Vigyan Ready using HotCat) |
||
Line 43: | Line 43: | ||
[[Category: Machine Translated Page]] | [[Category: Machine Translated Page]] | ||
[[Category:Created On 15/05/2023]] | [[Category:Created On 15/05/2023]] | ||
[[Category:Vigyan Ready]] |
Revision as of 14:18, 9 June 2023
कोड अखंडता एक माप है जिसका उपयोग सॉफ़्टवेयर वितरण जीवनचक्र में किया जाता है। यह मापता है कि गुणवत्ता आश्वासन के लिए पारित होने पर स्रोत कोड की गुणवत्ता कितनी उच्च होती है, और शुद्धता-जांच प्रक्रियाओं (चाहे मैन्युअल या स्वचालित) द्वारा कोड को कितनी अच्छी तरह से संसाधित किया गया था, इससे प्रभावित होता है। ऐसी शुद्धता-जांच प्रक्रियाओं के उदाहरण इकाई परीक्षण और एकीकरण परीक्षण, कोड समीक्षा, परीक्षण स्वचालन, एआई-आधारित कोड विश्लेषण इत्यादि हो सकते हैं।[1] कोड अखंडता मेट्रिक्स के साथ कोड शुद्धता प्रक्रियाओं (सॉफ्टवेयर गुणवत्ता) को प्रयुक्त करने का संयोजन है जो इन शुद्धता-जांच प्रक्रियाओं की पूर्णता को मापता है, जैसे, उदाहरण के लिए, कोड कवरेज जबकि कोड अखंडता सामान्यतः उच्च कोड कवरेज तक पहुंचने के लिए स्रोत कोड का परीक्षण करके प्राप्त की जाती है, यह निश्चित रूप से कोड अखंडता प्राप्त करने का एकमात्र विधि या सबसे अच्छा विधि नहीं है। वास्तव में, कोड कवरेज, ईकाई परीक्षणों की पूर्णता को मापने के लिए एक लोकप्रिय मीट्रिक वास्तविक कोड अखंडता के माप के साथ सीमित सहसंबंध के लिए जाना जाता है।[2]
डेवलपर का विश्वास
कोड अखंडता केवल कोड की शुद्धता के बारे में नहीं है, चूँकि डेवलपर्स के अपने कोड की शुद्धता के बारे में विश्वास के बारे में भी है। कोड अखंडता के साथ, डेवलपर यह सुनिश्चित कर सकता है कि क्यूए को पास करते समय उसका कोड सही विधि से लिखा गया है। वास्तव में यह कोड का अपेक्षित गुणवत्ता स्तर है। कोड अखंडता डेवलपर्स और कंपनियों को कम समय में कम बग के साथ उत्तम उत्पाद जारी करने में सहायता करती है।[3]
शिफ्ट-लेफ्ट टेस्टिंग और शिफ्ट-लेफ्ट कोड इंटीग्रिटी
कोड अखंडता का अभ्यास करने वाली कंपनियां क्लासिक परिदृश्य से बचती हैं जहां विकास चरण में देरी हो रही है, क्यूए चरण में देरी हो रही है, रिलीज चरण में देरी हो रही है। कोड अखंडता को नहीं अपनाने वाली कंपनियों के उत्पाद अधिक बग (समय के दबाव के कारण) के साथ जारी किए जाते हैं, उपयोगकर्ता विकास टीम को टन बग वापस रिपोर्ट करते हैं, और संस्करण 1.0 जारी करने के तुरंत बाद वे संस्करण 1.1 पर काम करना प्रारंभ करते हैं, केवल बग को ठीक करने के लिए टाला जा सकता था।
शिफ्ट-लेफ्ट परीक्षण सॉफ्टवेयर विकास की प्रारंभिक प्रक्रियाओं के समय संबंधित परीक्षण करने की एक विधि है, क्योंकि क्यूए विभाग कोड की अखंडता को उनके सभी परीक्षणों के चलने के बाद भी माप नहीं सकता है। शिफ्ट-लेफ्ट टेस्टिंग और कोड इंटीग्रिटी कसकर जुड़े हुए हैं, किन्तु इंटीग्रिटी में न केवल जॉब का टेस्टिंग पार्ट होता है, जो शिफ्ट-लेफ्ट कोड इंटीग्रिटी की बड़ी प्रक्रिया का एक उप-कार्य है। यह प्रक्रिया न केवल उच्च कोड कवरेज के साथ अधिक ईकाई परीक्षण प्रयुक्त करती है, चूँकि प्रासंगिक डेटा के विरुद्ध विभिन्न अन्य शुद्धता-जांच प्रक्रियाओं को भी सम्मिलित करती है।[4] यहां कुछ उदाहरण दिए गए हैं:
- कोड का ईकाई परीक्षण
- एकीकरण जांच
- को़ड समीक्षा
- एआई-आधारित कोड विश्लेषण
- स्वचालित परीक्षण
- एक कोड अखंडता प्रबंधक असाइन करना
शुद्धता-जांच पूर्णता मेट्रिक्स के उदाहरण:
- शुद्ध कोड अखंडता मीट्रिक सूत्रीकरण है: 1 - (गैर-कवर किए गए बग) / (कुल बग), शब्दों में: सही कोड अखंडता माइनस बग की संख्या जो इकाई परीक्षण द्वारा कवर नहीं की गई थी, के समय पाए गए कुल बग से विभाजित विकास सहित संपूर्ण उत्पाद चक्र, कोड अखंडता में नहीं है।
- विभिन्न प्रकार के कोड कवरेज (लाइन-कवरेज, शाखा-कवरेज आदि)
- उत्परिवर्तन परीक्षण
शिफ्ट-लेफ्ट कोड इंटीग्रिटी के लाभ
- कम विकास समय - विकास के चरण के समय पाए जाने वाले बग को बाद के चरणों में पाए जाने वाले बग की तुलना में तेजी से और आसानी से ठीक किया जाता है।
- कम विकास लागत - बाद के चरणों की तुलना में विकास चरण के समय पाए जाने वाले बग को ठीक करना सस्ता है।
- अपने कोड की गुणवत्ता में विश्वास - उच्च कोड अखंडता वाले उत्पादों को जारी करने का अर्थ है आपके ग्राहकों से अधिक सकारात्मक प्रतिक्रिया है ।
- क्यूए के काम को और अधिक कुशल बनाता है - क्यूए बग के बारे में चिंता किए बिना प्रणाली के परीक्षण पर ध्यान केंद्रित करता है जो उचित इकाई परीक्षण के माध्यम से आसानी से पाया जा सकता था।
शिफ्ट-बाएं कोड अखंडता सक्षमता
यह अवधारणा इस तथ्य पर आधारित है कि डेवलपर्स तकनीकी लाभ का पूरा उपयोग करने में सक्षम होंगे यदि उनके पास प्रारंभ से ही प्रासंगिक परीक्षण उपकरण उपलब्ध हों। जैसे-जैसे नए सॉफ्टवेयर अधिक से अधिक जटिल होते जाते हैं और अधिक निर्भरताएं सम्मिलित होती हैं, डेवलपर्स की भूमिकाओं में बी मॉडल के दाहिने भाग सहित, उन्हें ईकाई परीक्षण और एकीकरण प्रक्रियाओं का नियंत्रण ग्रहण करने में सहायता मिलेगी।[3][5] परिणाम डेवलपर्स को कई सॉफ्टवेयर कंपनियों में पूर्ण वातावरण लाने की अनुमति देगा। यह प्रवृत्ति जारी रहने की उम्मीद है क्योंकि कई स्थितियों में पूरे प्रणाली के संदर्भ के बिना इकाई/एकीकरण परीक्षण करना असंभव है।[6]
संदर्भ
- ↑ "स्रोत कोड विश्लेषण के लिए मशीन लर्निंग तकनीक पर एक सर्वेक्षण". Retrieved 15 March 2023.
- ↑ "How Effective Are Code Coverage Criteria?". Retrieved 15 March 2023.
- ↑ 3.0 3.1 Gadi Zimerman (11 November 2022). "Tests are not enough – Why code integrity matters?". Retrieved 16 March 2023.
- ↑ "High Level Test Driven Development – Shift Left". Retrieved 15 March 2023.
- ↑ Rook, Paul, E. Rook (1986). "सॉफ्टवेयर परियोजनाओं को नियंत्रित करना". IEEE Software Engineering Journal. 1 (1): 7-16. Retrieved 15 March 2023.
{{cite journal}}
: CS1 maint: multiple names: authors list (link) - ↑ "डेवलपर और संचालन के बीच के अंतर को कम करने के लिए DevOps में निरंतर एकीकरण (CI) और सतत वितरण (CD) परिनियोजन का उपयोग करने का प्रभाव". Retrieved 15 March 2023.