इसलिए, हम Bazel में अचानक कुछ बदलाव करने वाले हैं. हमें अपने डिज़ाइन को बदलना होगा और उन चीज़ों को ठीक करना होगा जो ठीक से काम नहीं करतीं. हालांकि, हमें यह पक्का करना होगा कि समुदाय और Bazel नेटवर्क साथ मिलकर काम कर सके. इसे ध्यान में रखते हुए, Bazel प्रोजेक्ट ने पुराने सिस्टम के साथ काम करने की नीति अपनाई है. इस दस्तावेज़ में, Bazel में योगदान देने वाले लोगों के लिए, इस नीति का पालन करने की प्रोसेस बताई गई है.
दस्तावेज़ डिज़ाइन करने के लिए बनी नीति का पालन करें.
GitHub से जुड़ी समस्या
Bazel रिपॉज़िटरी में GitHub से जुड़ी समस्या दर्ज करें. उदाहरण देखें.
हमारा सुझाव है कि:
टाइटल में फ़्लैग का नाम शुरू होगा. फ़्लैग का नाम
incompatible_
से शुरू होगा.आपने लेबल जोड़ा
incompatible-change
.ब्यौरे में बदलाव का ब्यौरा और डिज़ाइन से जुड़े ज़रूरी दस्तावेज़ों का लिंक होता है.
ब्यौरे में माइग्रेशन की रेसिपी शामिल है. इससे उपयोगकर्ताओं को यह समझने में मदद मिलेगी कि उन्हें अपना कोड कैसे अपडेट करना चाहिए. आम तौर पर, अगर बदलाव मैकेनिकल है, तो माइग्रेशन टूल का लिंक शामिल करें.
इस ब्यौरे में गड़बड़ी के मैसेज का एक उदाहरण दिया गया है, जो उपयोगकर्ताओं को माइग्रेट नहीं करने पर मिलेगा. इससे GitHub की समस्या, सर्च इंजन पर ज़्यादा आसानी से खोजी जा सकेगी. पक्का करें कि गड़बड़ी का मैसेज, मददगार हो और कार्रवाई करने लायक हो. संभव होने पर, गड़बड़ी के मैसेज में उस फ़्लैग का नाम शामिल होना चाहिए जो काम नहीं करता.
माइग्रेशन टूल के लिए, Buildifier में योगदान दें.
यह BUILD
, WORKSPACE
, और .bzl
फ़ाइलों में अपने-आप होने वाले सुधार लागू कर सकता है.
इसमें चेतावनियां भी शामिल हो सकती हैं.
लागू करने का तरीका
Bazel में एक नया फ़्लैग बनाएं. डिफ़ॉल्ट वैल्यू गलत होनी चाहिए. सहायता टेक्स्ट में
GitHub समस्या का यूआरएल शामिल होना चाहिए. फ़्लैग का नाम incompatible_
से शुरू होता है, इसलिए इसे मेटाडेटा टैग की ज़रूरत होती है:
metadataTags = {
OptionMetadataTag.INCOMPATIBLE_CHANGE,
},
तय किए गए ब्यौरे में, फ़्लैग की खास जानकारी जोड़ें.
इस फ़ॉर्म में RELNOTES:
को भी जोड़ें:
RELNOTES: --incompatible_name_of_flag has been added. See #xyz for details
कमिट को सही दस्तावेज़ भी अपडेट करना चाहिए, ताकि कमिट की ऐसी कोई विंडो न हो जिसमें कोड, दस्तावेज़ के जैसा हो. हमारे दस्तावेज़ को नए वर्शन में अपडेट किया गया है. इसलिए, दस्तावेज़ में किए गए बदलाव अनजाने में समय से पहले रिलीज़ नहीं होंगे.
लेबल
लाइसेंस को मर्ज करने और उसके साथ काम न करने वाले बदलाव लागू करने के लिए, GitHub की समस्या में migration-ready
लेबल जोड़ें.
अगर फ़्लैग में कोई समस्या मिलती है और उपयोगकर्ताओं के अब तक माइग्रेट नहीं होने की उम्मीद है, तो:
फ़्लैग migration-ready
हटाएं.
अगर आपको अगली बड़ी रिलीज़ में फ़्लैग को बदलना है, तो समस्या में `breaking-change-X.0" लेबल जोड़ें.
डेटा स्टोर करने की जगहें अपडेट करना
Bazel CI, Bazel@HEAD + डाउनस्ट्रीम पर अहम प्रोजेक्ट की एक सूची टेस्ट करता है. इनमें से ज़्यादातर, आम तौर पर दूसरे Bazel प्रोजेक्ट पर निर्भर होती हैं. इसलिए, यह ज़रूरी है कि आप उन्हें माइग्रेट करें, ताकि ज़्यादा से ज़्यादा समुदाय के लिए, इस माइग्रेशन को अनब्लॉक किया जा सके.
उन प्रोजेक्ट के माइग्रेशन की स्थिति पर नज़र रखने के लिए,
bazelisk-plus-incompatible-flags
पाइपलाइन का इस्तेमाल किया जा सकता है.
यहां देखें कि यह पाइपलाइन कैसे काम करती है.
डाउनस्ट्रीम पाइपलाइन में प्रोजेक्ट माइग्रेट करना, पूरी तरह से काम न करने वाले बदलाव के लेखक की ज़िम्मेदारी नहीं है. हालांकि, माइग्रेशन में तेज़ी लाने के लिए ये काम किए जा सकते हैं. इससे Bazel के उपयोगकर्ताओं और Bazel Green Team, दोनों का काम आसानी से किया जा सकता है.
- आपके काम न करने वाले बदलाव की वजह से जो डाउनस्ट्रीम प्रोजेक्ट नहीं हुए उनके मालिकों को सूचना देने के लिए GitHub से जुड़ी समस्याओं को हल करें.
- डाउनस्ट्रीम प्रोजेक्ट ठीक करने के लिए पीआर भेजें.
- माइग्रेशन में मदद पाने के लिए, Bazel कम्यूनिटी से संपर्क करें. उदाहरण के लिए, Bazel नियम लेखक एसआईजी.
झंडे को उछालना
फ़्लैग की डिफ़ॉल्ट वैल्यू को सही पर फ़्लिप करने से पहले, कृपया पक्का करें कि:
नेटवर्क में मौजूद मुख्य डेटा स्टोर करने की जगहों को माइग्रेट किया जाता है.
bazelisk-plus-incompatible-flags
पाइपलाइन पर, फ़्लैगThe following flags didn't break any passing Bazel team owned/co-owned projects
के नीचे दिखना चाहिए.उपयोगकर्ता की चिंताओं और उनके सवालों का समाधान कर दिया गया है.
जब फ़्लैग Bazel में फ़्लिप होने के लिए तैयार हो, लेकिन Google में आंतरिक माइग्रेशन के लिए ब्लॉक हो, तो फ़्लैग फ़्लिप को अनब्लॉक करने के लिए, कृपया अंदरूनी blazerc
फ़ाइल में फ़्लैग की वैल्यू को 'गलत' पर सेट करें. ऐसा करके, हम यह पक्का कर सकते हैं कि Bazel उपयोगकर्ता जल्द से जल्द नए व्यवहार पर डिफ़ॉल्ट रूप से निर्भर हों.
फ़्लैग को डिफ़ॉल्ट 'सही' पर सेट करते समय, कृपया:
- तय किए गए ब्यौरे में
RELNOTES[INC]
का इस्तेमाल, इस फ़ॉर्मैट में करें:RELNOTES[INC]: --incompatible_name_of_flag is flipped to true. See #xyz for details
आपके पास, तय किए गए बाकी के ब्यौरे में अतिरिक्त जानकारी शामिल करने का विकल्प है. - ब्यौरे में
Fixes #xyz
का इस्तेमाल करें, ताकि प्रतिबद्धता मर्ज हो जाने पर GitHub की समस्या बंद हो जाए. - अगर ज़रूरी हो, तो दस्तावेज़ पढ़ें और उसे अपडेट करें.
- फ़्लैग हटाए जाने को ट्रैक करने के लिए नई समस्या
#abc
दर्ज करें.
फ़्लैग हटाया जा रहा है
फ़्लैग को HEAD पर फ़्लिप करने के बाद, उसे Bazel से हटा दिया जाना चाहिए. जब आपको उस फ़्लैग को हटाना हो जो काम नहीं करता:
- अगर यह कोई ऐसा बड़ा बदलाव है जो काम नहीं करता, तो उपयोगकर्ताओं को माइग्रेट करने के लिए ज़्यादा समय दें. आम तौर पर, फ़्लैग कम से कम एक मुख्य रिलीज़ में उपलब्ध होना चाहिए.
- फ़्लैग को हटाने वाली कमिट के लिए, ब्यौरे में
Fixes #abc
का इस्तेमाल करें, ताकि कमिट किए जाने पर GitHub से जुड़ी समस्या बंद हो जाए.