Basel का एक सब-कमांड होता है. यह coverage
सब-कमांड की मदद से, डेटा स्टोर करने की जगहों पर कोड कवरेज की रिपोर्ट तैयार करता है. इन रिपोर्ट को bazel coverage
की मदद से टेस्ट किया जा सकता है. अलग-अलग भाषा के नेटवर्क की खास बातें होती हैं. इसलिए, किसी प्रोजेक्ट के लिए यह काम करना हमेशा आसान नहीं होता.
इस पेज में कवरेज रिपोर्ट बनाने और देखने की सामान्य प्रक्रिया बताई गई है. साथ ही, इसमें उन भाषाओं के लिए कुछ खास भाषा के नोट भी दिए गए हैं जिनका कॉन्फ़िगरेशन काफ़ी मशहूर है. सबसे पहले सामान्य सेक्शन को पढ़ें और फिर किसी खास भाषा की ज़रूरी शर्तों के बारे में पढ़ें. रिमोट तरीके से एक्ज़ीक्यूट करने की सुविधा देने वाले सेक्शन पर भी ध्यान दें, इसके लिए कुछ और बातों का ध्यान रखना पड़ता है.
इस दस्तावेज़ को अपनी पसंद के मुताबिक बनाने के कई विकल्प मौजूद हैं. हालांकि, इस दस्तावेज़ में lcov
रिपोर्ट बनाने और उन्हें इस्तेमाल करने पर फ़ोकस किया गया है. फ़िलहाल, यह ऐसा रूट है जिस पर काम किया जा सकता है.
कवरेज रिपोर्ट बनाना
वीडियो की रणनीति
कवरेज रिपोर्ट बनाने के लिए बुनियादी वर्कफ़्लो के लिए ये ज़रूरी हैं:
- टेस्ट टारगेट के साथ बुनियादी डेटा स्टोर करने की जगह
- भाषा के हिसाब से कोड कवरेज टूल इंस्टॉल करने वाला टूलचेन
- एक सही "इंस्ट्रुमेंटेशन" कॉन्फ़िगरेशन
पहले दो, भाषा के हिसाब से हैं और ज़्यादातर आसान हैं. हालांकि, बाद वाले प्रोजेक्ट जटिल प्रोजेक्ट के लिए ज़्यादा मुश्किल हो सकते हैं.
इस मामले में, "इंस्ट्रुमेंटेशन" का मतलब ऐसे कवरेज टूल से है जिनका इस्तेमाल किसी खास टारगेट के लिए किया जाता है. Baze, --instrumentation_filter
फ़्लैग का इस्तेमाल करके फ़ाइलों के एक खास सबसेट के लिए इसे चालू करने की अनुमति देता है.
इससे, उन टारगेट के लिए एक फ़िल्टर तय होता है जिनकी जांच
इंस्ट्रूमेंटेशन के साथ की जाती है. टेस्ट के लिए इंस्ट्रुमेंटेशन चालू करने के लिए, --instrument_test_targets
फ़्लैग ज़रूरी है.
डिफ़ॉल्ट रूप से, बैज टारगेट पैकेज को मैच करने की कोशिश करता है और ज़रूरत के हिसाब से बने फ़िल्टर को INFO
मैसेज के तौर पर प्रिंट करता है.
कवरेज की संख्या
कवरेज रिपोर्ट बनाने के लिए, bazel coverage
--combined_report=lcov
[target]
का इस्तेमाल करें. इससे टारगेट के लिए जांच की जाती है. साथ ही, हर फ़ाइल के लिए lcov फ़ॉर्मैट में कवरेज रिपोर्ट जनरेट होती हैं.
काम पूरा हो जाने के बाद, बैजल एक ऐसी कार्रवाई करता है जो बनाई गई सभी कवरेज फ़ाइलें इकट्ठा करके उन्हें एक फ़ाइल में मर्ज कर देती है, जो आखिर में $(bazel info
output_path)/_coverage/_coverage_report.dat
में बन जाती है.
टेस्ट फ़ेल होने पर भी कवरेज रिपोर्ट बनाई जाती हैं. हालांकि, ध्यान दें कि यह फ़ेल होने वाले टेस्ट के लिए भी उपलब्ध नहीं है - सिर्फ़ पासिंग टेस्ट को ही रिपोर्ट किया जाता है.
कवरेज देखना
कवरेज रिपोर्ट सिर्फ़ ऐसे lcov
फ़ॉर्मैट में होती है जिसे इंसान पढ़ सकते हैं. इससे, हम ऐसी रिपोर्ट बनाने के लिए genhtml
यूटिलिटी का इस्तेमाल कर सकते हैं जो वेब ब्राउज़र में देखी जा सकती है. यह रिपोर्ट lcov प्रोजेक्ट का हिस्सा है:
genhtml --output genhtml "$(bazel info output_path)/_coverage/_coverage_report.dat"
ध्यान दें कि genhtml
इन फ़ाइलों में अनुपलब्ध कवरेज के बारे में बताने के लिए, सोर्स कोड को भी पढ़ता है. यह काम करे, इसके लिए उम्मीद है कि
genhtml
को बेज़ल प्रोजेक्ट के रूट में लागू किया गया है.
नतीजा देखने के लिए, genhtml
डायरेक्ट्री में बनाई गई index.html
फ़ाइल को किसी भी वेब ब्राउज़र में खोलें.
genhtml
टूल या lcov
कवरेज फ़ॉर्मैट के बारे में ज़्यादा मदद पाने और ज़्यादा जानकारी पाने के लिए, lcov प्रोजेक्ट देखें.
रिमोट तरीके से एक्ज़ीक्यूट करें
रिमोट तरीके से टेस्ट करने की प्रोसेस चलाने के दौरान, फ़िलहाल कुछ चेतावनियां दी गई हैं:
- रिपोर्ट संयोजन कार्रवाई अभी दूर से नहीं चलाई जा सकती. ऐसा इसलिए होता है, क्योंकि Basel, कवरेज आउटपुट फ़ाइलों को अपने ग्राफ़ (यह समस्या देखें) का हिस्सा नहीं मानता. इसलिए, वे कॉम्बिनेशन ऐक्शन के लिए उन्हें इनपुट के तौर पर सही तरीके से इस्तेमाल नहीं कर सकते. इससे बचने के लिए,
--strategy=CoverageReport=local
का इस्तेमाल करें.- ध्यान दें: अगर Basel को
local,remote
आज़माने के लिए सेट अप किया गया है, तो इसके बजाय--strategy=CoverageReport=local,remote
जैसा कुछ बताना ज़रूरी हो सकता है. ऐसा इस वजह से होता है कि Baज़र, रणनीतियों को कैसे हल करता है.
- ध्यान दें: अगर Basel को
- पुरानी नीति की वजह से,
--remote_download_minimal
और इससे मिलते-जुलते फ़्लैग का इस्तेमाल नहीं किया जा सकता. - अगर टेस्ट पहले से कैश मेमोरी में सेव किए गए हैं, तो फ़िलहाल Basel, कवरेज की जानकारी नहीं बना पाएगा. इसे ठीक करने के लिए,
--nocache_test_results
को खास तौर पर, कवरेज चलाने के लिए सेट किया जा सकता है. हालांकि, जांच में लगने वाले समय के हिसाब से, इस सुविधा के लिए ज़्यादा शुल्क देना पड़ता है. --experimental_split_coverage_postprocessing
और--experimental_fetch_all_coverage_outputs
- आम तौर पर, कवरेज को टेस्ट ऐक्शन के तौर पर चलाया जाता है. इसलिए, हमें डिफ़ॉल्ट रूप से सभी कवरेज को रिमोट तौर पर की जाने वाली कार्रवाइयों के आउटपुट के तौर पर वापस नहीं मिलता. ये फ़्लैग डिफ़ॉल्ट को ओवरराइड करते हैं और कवरेज डेटा पाते हैं. ज़्यादा जानकारी के लिए, यह समस्या देखें.
भाषा के हिसाब से कॉन्फ़िगरेशन
Java
Java को डिफ़ॉल्ट कॉन्फ़िगरेशन के साथ सबसे बेहतर काम करना चाहिए. baज़ल टूलचेन में, रिमोट तौर पर एक्ज़ीक्यूट करने के लिए ज़रूरी सभी चीज़ें मौजूद होती हैं. इनमें JUnit भी शामिल है.
Python
Python में कवरेज से जुड़ी सहायता पाने की सुविधा चालू करने के लिए ज़रूरी अतिरिक्त चरणों के बारे में जानने के लिए, rules_python
कवरेज के दस्तावेज़ देखें.