यह Bazel के ओपन सोर्स प्रोजेक्ट के रखरखाव करने वालों के लिए एक गाइड है.
अगर आपको Bazel में योगदान देना है, तो कृपया इसके बजाय Contributing to Bazel लेख पढ़ें.
इस पेज के मकसद ये हैं:
- प्रोजेक्ट में योगदान देने की प्रोसेस के बारे में, रखरखाव करने वालों के लिए सोर्स ऑफ़ ट्रुथ के तौर पर काम करना.
- कम्यूनिटी के योगदान देने वाले लोगों और प्रोजेक्ट के रखरखाव करने वालों के बीच, लोगों की उम्मीदों को पूरा करना.
Bazel के योगदान देने वाले मुख्य ग्रुप में, ओपन सोर्स प्रोजेक्ट के अलग-अलग पहलुओं को मैनेज करने के लिए, खास सबटीम होती हैं. ये सबटीम ये हैं:
- रिलीज़ प्रोसेस: Bazel की रिलीज़ प्रोसेस को मैनेज करना.
- ग्रीन टीम: नियमों और टूल का एक बेहतर इकोसिस्टम बनाना.
- डेवलपर एक्सपीरिएंस गार्डनर: बाहरी योगदान को बढ़ावा देना, समस्याओं और पुल के अनुरोधों की समीक्षा करना, और हमारे डेवलपमेंट वर्कफ़्लो को ज़्यादा ओपन बनाना.
रिलीज़
लगातार इंटिग्रेशन करना
Bazel के सीआई इन्फ़्रास्ट्रक्चर के बारे में जानने के लिए, ग्रीन टीम की गाइड पढ़ें. यह गाइड, bazelbuild/continuous-integration रिपॉज़िटरी पर उपलब्ध है.
किसी समस्या की लाइफ़साइकल
- कोई उपयोगकर्ता, समस्या के टेंप्लेट में से किसी एक को चुनकर समस्या बनाता है. इसके बाद, यह समस्या, समीक्षा नहीं की गई ओपन समस्याओं के पूल में शामिल हो जाती है.
- डेवलपर एक्सपीरिएंस (DevEx) सबटीम के रोटेशन पर मौजूद कोई सदस्य, समस्या की समीक्षा करता है.
- अगर समस्या बग नहीं है या सुविधा का अनुरोध नहीं है, तो DevEx का सदस्य आम तौर पर समस्या को बंद कर देगा. साथ ही, सवाल को ज़्यादा लोगों तक पहुंचाने के लिए, उपयोगकर्ता को StackOverflow और bazel-discuss पर रीडायरेक्ट कर देगा.
- अगर समस्या, कम्यूनिटी के मालिकाना हक वाली किसी नियम रिपॉज़िटरी में शामिल है, जैसे कि rules_apple, तो DevEx का सदस्य इस समस्या को सही रिपॉज़िटरी में ट्रांसफ़र कर देगा.
- अगर समस्या अस्पष्ट है या उसमें जानकारी मौजूद नहीं है, तो DevEx का सदस्य, आगे बढ़ने से पहले ज़्यादा जानकारी के लिए, समस्या को उपयोगकर्ता को वापस असाइन कर देगा. आम तौर पर, ऐसा तब होता है, जब उपयोगकर्ता सही समस्या टेंप्लेट {: .external} को नहीं चुनता या अधूरी जानकारी देता है.
- समस्या की समीक्षा करने के बाद, DevEx का सदस्य यह तय करता है कि समस्या पर तुरंत ध्यान देने की ज़रूरत है या नहीं. अगर समस्या पर तुरंत ध्यान देने की ज़रूरत है, तो वह P0 प्राथमिकता वाला लेबल असाइन करेगा. साथ ही, टीम के लीड की सूची में से किसी एक को समस्या का मालिकाना हक देगा.
- DevEx का सदस्य, राउटिंग के लिए
untriagedलेबल और टीम का सिर्फ़ एक लेबल असाइन करता है. - समस्या के टाइप के हिसाब से, DevEx का सदस्य ठीक एक
type:लेबल असाइन करता है, जैसेtype: bugयाtype: feature request. - प्लेटफ़ॉर्म से जुड़ी समस्याओं के लिए, DevEx का सदस्य एक
platform:लेबल असाइन करता है, जैसे Mac से जुड़ी समस्याओं के लिएplatform:appleलेबल असाइन किया जाता है. - अगर समस्या की प्राथमिकता कम है और कम्यूनिटी का कोई नया सदस्य इस पर काम कर सकता है, तो DevEx का सदस्य,
good first issueलेबल असाइन करता है. इस चरण में, समस्या, समीक्षा नहीं की गई ओपन समस्याओं के पूल में शामिल हो जाती है.
Bazel की हर सबटीम, अपने मालिकाना हक वाले लेबल के तहत आने वाली सभी समस्याओं की समीक्षा करेगी. कोशिश करें कि यह काम हर हफ़्ते किया जाए. सबटीम, समस्या की समीक्षा और उसका आकलन करेगी. साथ ही, अगर मुमकिन हो, तो उसका समाधान भी उपलब्ध कराएगी. अगर आपके पास टीम के किसी लेबल का मालिकाना हक है, तो ज़्यादा जानकारी के लिए यह सेक्शन देखें.
समस्या का समाधान होने के बाद, उसे बंद किया जा सकता है.
पुल के अनुरोध की लाइफ़साइकल
- कोई उपयोगकर्ता, पुल का अनुरोध करता है.
- अगर आप Bazel की किसी टीम के सदस्य हैं और अपने इलाके के लिए पीआर भेज रहे हैं, तो आपको अपनी टीम का लेबल असाइन करना होगा. साथ ही, समीक्षा करने के लिए सबसे सही व्यक्ति को ढूंढना होगा.
- अन्य मामलों में, हर दिन की समीक्षा के दौरान, DevEx का सदस्य, राउटिंग के लिए टीम का एक
लेबल और टीम का तकनीकी लीड (टीएल) असाइन करता है.
- टीएल के पास, पीआर की समीक्षा करने के लिए किसी और व्यक्ति को असाइन करने का विकल्प होता है.
- समीक्षा करने के लिए असाइन किया गया व्यक्ति, पीआर की समीक्षा करता है. साथ ही, जब तक पीआर को मंज़ूरी नहीं मिल जाती या उसे ड्रॉप नहीं कर दिया जाता, तब तक वह पीआर बनाने वाले व्यक्ति के साथ मिलकर काम करता है.
- मंज़ूरी मिलने पर, समीक्षा करने वाला व्यक्ति, आगे के टेस्ट के लिए, Google के इंटरनल वर्शन कंट्रोल सिस्टम में पीआर के कमिट इंपोर्ट करता है. Bazel, Google में इंटरनल तौर पर इस्तेमाल किया जाने वाला वही बिल्ड सिस्टम है. इसलिए, हमें इंटरनल टेस्ट सुइट के ख़िलाफ़, पीआर के सभी कमिट की जांच करनी होती है. इसी वजह से, हम पीआर को सीधे तौर पर मर्ज नहीं करते.
- अगर इंपोर्ट किया गया कमिट, इंटरनल तौर पर किए जाने वाले सभी टेस्ट पास कर लेता है, तो कमिट को स्क्वैश किया जाएगा. इसके बाद, उसे वापस GitHub पर एक्सपोर्ट कर दिया जाएगा.
- जब कमिट, मास्टर में मर्ज हो जाता है, तो GitHub, पीआर को अपने-आप बंद कर देता है.
मेरी टीम के पास किसी लेबल का मालिकाना हक है. मुझे क्या करना चाहिए?
सबटीम को, अपने मालिकाना हक वाले लेबल में मौजूद सभी समस्याओं की समीक्षा करनी होगी. कोशिश करें कि यह काम हर हफ़्ते किया जाए.
समस्याएं
- अपनी टीम के लेबल और
untriagedलेबल के हिसाब से, समस्याओं की सूची को फ़िल्टर करें. - समस्या की समीक्षा करें.
- प्राथमिकता का लेवल तय करें और लेबल असाइन करें.
- अगर समस्या P0 है, तो हो सकता है कि DevEx सबटीम ने पहले ही उसकी प्राथमिकता तय कर दी हो. ज़रूरत पड़ने पर, प्राथमिकता फिर से तय करें.
- हर समस्या के लिए, प्राथमिकता का सिर्फ़ एक लेबल होना चाहिए. अगर कोई समस्या P0 या P1 है, तो हम मान लेते हैं कि उस पर काम किया जा रहा है.
untriagedलेबल हटाएं.
ध्यान दें कि लेबल जोड़ने या हटाने के लिए, आपको bazelbuild संगठन में शामिल होना होगा.
पुल के अनुरोध
- अपनी टीम के लेबल के हिसाब से, पुल के अनुरोधों की सूची को फ़िल्टर करें.
- ओपन पुल के अनुरोधों की समीक्षा करें.
- ज़रूरी नहीं: अगर आपको समीक्षा के लिए असाइन किया गया है, लेकिन आप इसके लिए सही व्यक्ति नहीं हैं तो कोड की समीक्षा करने के लिए, सही व्यक्ति को फिर से असाइन करें.
- कोड की समीक्षा पूरी करने के लिए, पुल का अनुरोध करने वाले व्यक्ति के साथ मिलकर काम करें.
- पीआर को मंज़ूरी दें.
- पक्का करें कि सभी टेस्ट पास हो जाएं.
- पैच को इंटरनल वर्शन कंट्रोल सिस्टम में इंपोर्ट करें और इंटरनल प्रीसबमिट चलाएं.
- इंटरनल पैच सबमिट करें. अगर पैच सबमिट और एक्सपोर्ट हो जाता है, तो GitHub, पीआर को अपने-आप बंद कर देगा.
प्राथमिकता
समस्याओं की समीक्षा करने के लिए, रखरखाव करने वाले लोग, प्राथमिकता की इन परिभाषाओं का इस्तेमाल करेंगे.
- P0 - ऐसी समस्या जिसकी वजह से, Bazel की रिलीज़ (रिलीज़ कैंडिडेट को छोड़कर) का इस्तेमाल नहीं किया जा सकता. इसके अलावा, ऐसी सेवा जो बंद हो गई है और जिसकी वजह से, Bazel प्रोजेक्ट के डेवलपमेंट पर बुरा असर पड़ रहा है. इसमें, नई रिलीज़ में हुई गड़बड़ियां शामिल हैं. इनकी वजह से, बड़ी संख्या में उपयोगकर्ता प्रभावित होते हैं. इसके अलावा, ऐसा इनकंपैटिबल ब्रेकिंग बदलाव भी शामिल है जो ब्रेकिंग बदलाव की नीति के मुताबिक नहीं था. इसका कोई व्यावहारिक समाधान मौजूद नहीं है.
- P1 - ऐसी गंभीर गड़बड़ी या सुविधा जिसे अगली रिलीज़ में ठीक किया जाना चाहिए. इसके अलावा, ऐसी गंभीर समस्या जिसकी वजह से, कई उपयोगकर्ता प्रभावित होते हैं. इसमें Bazel प्रोजेक्ट का डेवलपमेंट भी शामिल है. हालांकि, इसका व्यावहारिक समाधान मौजूद है. आम तौर पर, इसके लिए तुरंत कार्रवाई की ज़रूरत नहीं होती. इसकी काफ़ी मांग है और इसे मौजूदा तिमाही के रोडमैप में शामिल किया गया है.
- P2 - ऐसी गड़बड़ी या सुविधा जिसे ठीक किया जाना चाहिए, लेकिन फ़िलहाल हम इस पर काम नहीं कर रहे हैं. Bazel के रिलीज़ किए गए वर्शन में, ऐसी समस्या जो लाइव है और जिसकी वजह से, उपयोगकर्ता को परेशानी हो रही है. इसे आने वाली रिलीज़ में ठीक किया जाना चाहिए. इसके अलावा, इसका आसान समाधान मौजूद है.
- P3 - ऐसा मामूली बग फ़िक्स या सुधार जिसकी वजह से, कम असर पड़ता है. इसे Bazel के रोडमैप या आने वाली किसी रिलीज़ में प्राथमिकता नहीं दी जाती. हालांकि, कम्यूनिटी के योगदान को बढ़ावा दिया जाता है.
- P4 - कम प्राथमिकता वाली गड़बड़ी या सुविधा का अनुरोध, जिसे ठीक किए जाने की संभावना कम है. अगर ज़्यादा उपयोगकर्ता प्रभावित होते हैं, तो इसे फिर से प्राथमिकता देने के लिए, ओपन भी रखा जा सकता है.
- ice-box
- ऐसी समस्याएं जिन पर फ़िलहाल काम करने के लिए हमारे पास समय नहीं है. साथ ही, योगदान स्वीकार करने के लिए भी हमारे पास समय नहीं है. हम इन समस्याओं को बंद कर देंगे, ताकि यह पता चल सके कि इन पर कोई काम नहीं कर रहा है. हालांकि, हम समय-समय पर इनकी पुष्टि करते रहेंगे. अगर ज़्यादा लोग प्रभावित होते हैं और हमारे पास इन समस्याओं को ठीक करने के लिए संसाधन मौजूद होते हैं, तो हम इन समस्याओं को फिर से चालू कर देंगे. हमेशा की तरह, इन समस्याओं पर टिप्पणी करें या रिएक्शन जोड़ें. भले ही, ये समस्याएं बंद कर दी गई हों.
टीम के लेबल
team-Android: Android टीम के लिए समस्याएं- संपर्क करें: ahumesky
team-Bazel: Bazel प्रॉडक्ट/रणनीति से जुड़ी सामान्य समस्याएं- संपर्क करें: meisterT
team-CLI: कंसोल यूज़र इंटरफ़ेस (यूआई)- संपर्क करें: meisterT
team-Configurability: कॉन्फ़िगर करने की सुविधा देने वाली टीम के लिए समस्याएं. इसमें ये शामिल हैं: कोर बिल्ड कॉन्फ़िगरेशन और ट्रांज़िशन सिस्टम. इसमें ये शामिल नहीं हैं: नए या मौजूदा फ़्लैग में किए गए बदलाव- संपर्क करें: gregestren
team-Core: Skyframe, bazel query, BEP, विकल्पों को पार्स करना, bazelrc- संपर्क करें: haxorz
team-Documentation: दस्तावेज़ बनाने वाली टीम के लिए समस्याएंteam-ExternalDeps: बाहरी डिपेंडेंसी को मैनेज करना, Bzlmod, रिमोट रिपॉज़िटरी, WORKSPACE फ़ाइल- संपर्क करें: meteorcloudy
team-Loading-API: BUILD फ़ाइल और मैक्रो प्रोसेसिंग: लेबल, package(), visibility, glob- संपर्क करें: brandjon
team-Local-Exec: एक्ज़ीक्यूशन (लोकल) टीम के लिए समस्याएं- संपर्क करें: meisterT
team-OSS: Bazel OSS टीम के लिए समस्याएं: इंस्टॉलेशन, रिलीज़ प्रोसेस, Bazel पैकेजिंग, वेबसाइट, दस्तावेज़ों का इन्फ़्रास्ट्रक्चर- संपर्क करें: meteorcloudy
team-Performance: Bazel की परफ़ॉर्मेंस टीम के लिए समस्याएं- संपर्क करें: meisterT
team-Remote-Exec: एक्ज़ीक्यूशन (रिमोट) टीम के लिए समस्याएं- संपर्क करें: coeuvre
team-Rules-API: नियम/पहलू लिखने के लिए एपीआई: प्रोवाइडर, रनफ़ाइल, ऐक्शन, आर्टफ़ैक्ट- संपर्क करें: comius
team-Rules-CPP/team-Rules-ObjC: C++/Objective-C के नियमों के लिए समस्याएं. इनमें Apple के नेटिव नियम लॉजिक भी शामिल हैं- संपर्क करें: buildbreaker2021
team-Rules-Java: Java के नियमों के लिए समस्याएं- संपर्क करें: hvadehra
team-Rules-Python: Python के नेटिव नियमों के लिए समस्याएं- संपर्क करें: rickeylev
team-Rules-Server: Bazel के साथ शामिल, सर्वर-साइड के नियमों के लिए समस्याएं- संपर्क करें: comius
team-Starlark-Integration: नॉन-एपीआई Bazel + Starlark इंटिग्रेशन. इसमें ये शामिल हैं: Bazel, Starlark इंटरप्रेटर को कैसे ट्रिगर करता है, Stardoc, बिल्ट-इन इंजेक्शन, वर्ण एन्कोडिंग. इसमें ये शामिल नहीं हैं: BUILD या .bzl भाषा से जुड़ी समस्याएं.- संपर्क करें: brandjon
team-Starlark-Interpreter: Starlark इंटरप्रेटर के लिए समस्याएं (java.net.starlark में मौजूद कोई भी समस्या). BUILD और .bzl एपीआई से जुड़ी समस्याएं (जो Starlark के साथ Bazel के इंटिग्रेशन को दिखाती हैं)team-Build-Languageमें शामिल होती हैं.- संपर्क करें: brandjon
नई समस्याओं के लिए, हमने category: * लेबल को बंद कर दिया है. अब टीम के लेबल का इस्तेमाल किया जाता है.
लेबल की पूरी सूची यहां देखें.