راهنمای کامل یکپارچه‌سازی نرم افزارهای Jira و Bitbucket

یکپارچه سازی جیرا و بیت باکت

یکپارچه‌سازی جیرا و بیت باکت

یک محصول نرم‌افزاری، مراحل مختلفی چون برنامه‌ریزی، توسعه، تست و انتشار را طی می‌کند تا به دست مشتریان خود برسد. در این بین، فرآیندها، ابزارها، استاندارد‌ها و متدولوژی‌های مختلفی برای ایجاد یک محصول هر چه بهتر مورد استفاده قرار میگیرد.

جیرا به عنوان یکی از پرکاربرترین ابزار‌های مدیریت پروژه‌های نرم‌افزاری است که قابلیت‌های بسیار خوبی در این زمینه فراهم کرده است. شرکت‌های بسیار زیادی در سراسر دنیا از نرم‌افزار جیرا برای مدیریت و پیگیری کارهاو پروژه‌ها خود استفاده می‌کنند. این‌شرکت‌ها از نرم‌افزار جیرا برای برنامه‌ریزی، پیگیری، ثبت زمان کارها و برنامه‌ریزی کارهای پیش‌رو استفاده می‌کنند. این امر باعث شده ابزارهای زیادی قابلیت یکپارچه‌شدن با نرم‌افزار جیرا را فراهم کنند.

توسعه‌دهندگان نرم‌افزار از ابزارهای مختلفی برای نگه‌داری و مدیریت کدهای خود استفاه می‌کنند. یکی از بهترین ابزار در این زمینه بیت‌باکت (Bitbucket) است. نرم‌افزار بیت‌باکت (Bitbucket) که یک نرم‌افزار بسیار کاربری در زمینه Source Controlling بر پایه Git است به صورت گسترده‌ای در شرکت‌های سرتاسر دنیا مورد استفاده قرار میگیرد.

ارتباط تنگاتنگ مراحل برنامه‌ریزی و توسعه یک محصول، لزوم وجود بستری مناسب و یکپارچه برای این امور را می‌طلبد. نرم‌افزارهای جیرا و بیت‌باکت که از برترین نرم‌افزارهای این دو حوزه هستند، قابلیت یکپارچه‌سازی کامل را فراهم کرده اند و با یکپارچه‌سازی نرم افزار جیرا و بیت باکت امکان ترکیب فرآیندهای مدیریت و فرآیندهای توسعه نرم‌افزار فراهم خواهد شد.

نرم‌افزارهای بیت باکت و جیرا هر دو محصول شرکت Atlassian هستند و این امر فرآیند یکپارچه‌سازی این دو نر‌م افزار را بسیار ساده کرده است. هر دو نرم‌افزار کاملا بالغ هستند و برای کمک به توسعه‌دهندگان نرم‌افزار تمرکز کرده اند.

در این مقاله قصد داریم نحوه یکپارچه‌سازی این دو نرم‌افزار پرکاربرد را شرح‌ دهیم و نحوه کمک کردن این دو نرم‌افزار به تیم‌های مدرن توسعه نرم افزار توضیح داده شود.

انواع نسخه‌های بیت باکت

پیش از شروع یکپارچه‌سازی این دو نرم‌افزار یک نکته لازم به ذکر است. برای نرم‌افزار Bitbucket دو نسخه توسط شرکت Atlassian ارائه می‌گردد. نسخه سرور (Bitbucket Server) و نسخه ابری (Bitbucket Cloud). در این دو نسخه تفاوت‌هایی وجود دارد.

در نسخه ابری نرم افزار بیت باکت، همه کارها توسط شرکت Atlassian انجام می‌شود و شما تنها لازم است بر روی کدها و repository ها کار کنید و آن‌ها را مدیریت کنید. برای تیم‌هایی که نیاز به کنترل بیشتری داشته باشند نسخه سرور بیت‌باکت مناسب تر خواهد بود. زیرا که در نسخه سرور، تیم ها تمامی تنظیمات این سرویس را در دست خواهند داشت. در این نسخه شما نرم‌افزار را بر روی سرور‌های خود نصب و مدیریت خواهید کرد. در صورتی که برای نصب نرم‌افزار به کمک نیاز دارید به صفحه تماس با ما مراجعه و با کارشناسان ما در تماس باشید.

با توجه به این توضیحات، در این مقاله سعی شده تمامی مطالب در دو نسخه سرور و ابری قابل استفاده باشد. اما تمرکز بیشتر ما در این مقاله بر روی نسخه‌های سرور هر دو محصول بیت باکت و جیرا می‌باشد. برای نصب و راه‌اندازی سامانه‌های جیرا و بیت‌باکت به صورت سرور با ما در تماس باشید.

چرا باید جیرا و بیت‌باکت را با یکدیگر یکپارجه‌سازی کنیم؟

اولین سوالی که لازم است در اینجا از خود بپرسیم این است که چه نیازی است که این دو سامانه را با یکدیگر یکپارچه کنیم و این کار چه مزیتی خواهد داشت؟

یکپارچه‌سازی این دو سامانه دلایل زیادی دارد. در وهله اول یکپارچه‌سازی این دو سامانه ویژگی‌های مفیدی را پس از یکپارچه‌سازی در اختیار ما قرار خواهند داد. همان‌طور که خواهیم دید، با یکپارچه کردن این دو سامانه ویژگی‌های جدید بسیار خوبی فعال خواهد شد.

تیم‌های زیادی از نرم افزار جیرا برای مدیریت فرآیندهای توسعه نرم‌افزار خود بهره‌ می‌برند. با یکپارچه سازی نرم افزار جیرا و بیت باکت دید و تصویر کاملی از محیط و روال توسعه نرم‌افزار به افراد تیم ارائه خواهد شد.

شروع یکپارچه‌سازی جیرا و بیت‌باکت

زمانی که شما تصمیم به لینک کردن بیت باکت و جیرا گرفتید به راحتی می‌توانید این کار را انجام دهید. برای این‌کار وارد یکی از نرم افزار های بیت باکت یا جیرا شوید. از بخش Administration گزینه Application Link را انتخاب کنید.

برای مثال در نرم‌افزار جیرا از قسمت Administration به قسمت Application مراجعه کرده و وارد Application Link شوید.

پس از وارد کردن آدرس URL سامانه بیت‌باکت بر روی Create new link کلیک کنید.

بخش Application link در جیرا

در صورتی که سامانه جیرا دسترسی لازم برای اتصال به سرویس بیت‌باکت را داشته باشد پنجره زیر نمایش داده خواهد شد و سامانه جیرا، اطلاعات سامانه بیت‌باکت را دریافت و نمایش خواهد داد.

اطلاعات یکپارچه سازی جیرا و بیت باکت

در صورتی‌که نام کابری و رمز عبور کاربر Administrator در هر دو سامانه یکسان باشد، گزینه The servers have the same set of users and usernames را انتخاب کنید در غیر این صورت پس از زدن گزینه Continue لازم است نام کاربری و رمز عبور کاربر Administrator سامانه بیت‌باکت را وارد نمایید.

در صورت موفقیت آمیز بودن یکپارچه‌سازی صفحه زیر برای ذخیره تنظیمات مربوط به Smart Commits نمایش داده خواهد شد.

تنظیم گزینه smart commit در جیرا

پس از اتمام فرآیند یکپارچه‌سازی دو نرم‌افزار، بخش development در ایشو‌های جیرا نمایش داده خواهد شد.

بهینه‌سازی بیت‌باکت برای کار با جیرا

تا اینجای کار شما یکپارچه‌سازی اولیه دو نرم‌افزار را انجام داده اید. برای عملکرد بهتر دو نرم افزار با یکدیگر، تغییرات کوچکی لازم است در نرم‌افزار بیت‌باکت انجام دهید تا مناسب با نیاز شما کار کند.

برای شروع، به بخش Branching model در نرم ‌افزار بیت باکت رفته تا تنظیمات مربوط به آن را انجام دهید. در این بخش نحوه انجام Branch ها در نرم افزار بیت باکت را تنظیم می‌کنید. این ویژگی به شما این امکان را می‌دهد تا نحوه نام‌گذاری Branch ها را مشخص کنید. هم‌چنین مشخص کنید که سیاست merging به چه شکل باشد.

برای مثال در تنظیمات این بخش شما می‌توانید انواع branch هایی که امکان ایجاد آن وجود دارد و نام هر کدام از branch ها را تنظیم کنید. هم‌چنین در این بخش سیاست‌های merge نیز تعیین می‌شود.

تنظیمات branching mode

چرا این تنظیمات اهمیت دارند؟ زیرا با یکپارچه‌سازی نرم‌افزار جیرا و بیت‌باکت شما امکان ایجاد و مدیریت branch ها را در نرم‌افزار جیرا به همان آسانی بیت‌باکت خواهید داشت. بنابراین اگر در جیرا اقدام به ایجاد یک branch به طور مستقیم از یک issue کنید مطابق با تنظیمات این صفحه خواهد بود.

زمانیکه در نرم‌افزار جیرا یک User Story جهت پیاده‌سازی نیازمندی جدیدی در نرم افزار به یک توسعه‌دهنده تخصیص داده می‌شود، کاربر در صفحه مربوط به همان issue با زدن گزینه create a branch این امکان را دارد تا branch مد نظر خود برای توسعه کد‌های مرتبط با User Story را ایجاد کند. با زدن این گزینه، پنجره‌ای برای کاربر باز خواهد شد که تنظیمات لازم برای ایجاد branch در آن قابل مشاهده خواهد بود. این تنظیمات مطابق با سیاست‌هایی است که در بخش Branching mode انجام داده‌‌اید.

ایجاد یک branch از ایشو در جیرا

قابلیت Smart Commit

یک ویژگی بسیار کاربری که نمی‌توان از آن چشم‌پوشی کرد، ویژگی Smart Commit است که با یکپارچه‌سازی نرم‌افزار های جیرا و بیت‌باکت فعال می‌شود. این ویژگی که از نسخه ۴.۲ بیت‌باکت و ۷.۱ جیرا راه‌اندازی شد، به کاربر این امکان را می‌دهد تا با وارد کردن دستورات خاصی در هنگام commit کردن کد‌ها در بخش Comment، دستوراتی برای نرم‌افزار جیرا ارسال گردد.

برای مثال زمانی‌که یک توسعه‌دهنده قصد Commit کردن کد‌های خود را دارد می‌تواند با وارد کردن Key مربوط به یک (یا چند Issue) و سپس وارد کردن #close در Comment یک Commit اقدام به بستن issue نماید.
یک ویژگی بهتر این است که در توسعه‌دهنده به صورت مستقیم می‌تواند زمانی که بر روی توسعه این بخش از کد صرف کرده است را با وارد کردن مقدار #time و سپس وارد کردن مقدار زمان (با فرمتی شبیه به ۱w 2d 3h 15m به معنی یک هفته و دو روز و سه ساعت و ۱۵ دقیقه)، در جیرا وارد کند. این کار به صورت دستی نیز با log work در جیرا قابل انجام خواهد بود.

موارد بیشتری از این دستورات در نرم‌افزار بیت‌باکت قابل استفاده هستند. مواردی که می‌توان از این دستورات استفاده کرد شامل:
• ارسال یک نظر (comment) بر روی یک issue در جیرا
• ثبت زمان‌های صرف شده بر روی یک issue (قابلیت Time Tracking جیرا)
• انتقال Issue از یک وضعیت به وضعیت دیگر بر اساس جریان کاری تعریف شده در جیرا
دستورات smart commit ساختاری شبیه زیر دارند:

<ignored text> <ISSUE_KEY> <ignored text> #<COMMAND> <optional COMMAND_ARGUMENTS>

این ساختار لازم است در هنگام Commit کردن کد‌ها توسط توسعه‌دهنده در قسمت Comment یک Commit وارد شود. در این ساختار از بخش‌های ignored text دستور صرف نظر خواهد شد و تاثیری در جیرا نخواهد داشت و صرفا برای شرح توضیحات مربوط به این Commit وارد می‌شود. در ادامه مثال‌های استفاده از ویژگی smart commit نشان داده شده است.

وارد کردن کامنت در یک ایشو:

Some text JRA-34 #comment corrected indent issue

در این دستور کامنتی با مقدار corrected indent issue در ایشو‌ی JRA-34 در نرم افزار جیرا وارد خواهد شد.

‌وارد کردن Work log در یک ایشو:

JRA-34 #time 4h 30m Total work logged

در این دستور Work log با زمان ۴ ساعت و ۳۰ دقیقه با توضیح Total work logged در لاگ ورک برای ایشوی JRA-34 وارد می‌شود.

انتقال ایشو در workflow:

JRA-090 #close Fixed this today

در این دستور ایشوی JRA-090 با انتقال (Transition) به نام close و با توضیح Fixed this today به وضعیت دیگری منتقل شده است.

استفاده از ویژگی smart commit محدود به این سه حالت نیست و شما می‌توانید با نصب افزونه‌های مرتبط، استفاده از این قابلیت‌ را توسعه دهید. یکی از افزونه‌های کاربردی در این زمینه Smart Commits for Bitbucket است.

بیت‌باکت را به workflow های جیرا اضافه کنید

پس از اینکه که تمامی تنظیمات مربوط به یکپارچه‌سازی را در بیت‌باکت انجام دادید، تنظیماتی نیز در نرم‌افزار جیرا قابل پیاده‌سازی و استفاده هستند.

قابلیت دیگری که قصد داریم در اینجا بررسی کنیم، امکان تغییر وضعیت یک ایشو در جیرا بر اساس رخدادهایی که در repository های بیت باکت انجام می‌شود است.

برای مثال اگر یک pull request بر روی یک branch در بیت‌باکت انجام شده است، ایشوهای مربوطه از وضعیت In Development به Code Review منتقل خواهد شد.

این کار با انجام تنظیمات در بخش Trigger یک workflow در جیرا انجام خواهد شد.

تنظیم trigger در workflow جیرا

ویژگی Trigger در workflow های جیرا، ابزار قدرتمندی است که این امکان را به شما می‌دهد تا وضعیت ایشو‌ها در یک پروژه جیرا را با اطلاعات ابزارهای توسعه نرم‌افزار خود (مانند بیت‌باکت) به صورت خودکار هماهنگ (Sync) کنید.

در حقیقت به جای اینکه توسعه‌دهنده نرم‌افزار بعد از کارهایی مانند commit کردن کد‌ها، بازبینی کد‌، ایجاد یک branch و … به صورت دستی وضعیت ایشو‌های مرتبط با آن را نیز در جیرا بروزرسانی کند، شما می‌توانید با انجام تنظیمات در Trigger های یک workflow ، این فعالیت‌ها را به صورت خودکار در آورید.

پس از انجام تنظیمات مربوط به Trigger در workflow جیرا، توسعه‌دهنده نرم افزار کافی است Key مربوط به ایشو را در Commit خود وارد کند تا Trigger مربوط به آن ایشو اجرا شود. افزونه‌هایی نیز وجود دارد که توسعه‌دهندگان را ملزم به وارد کردن key ایشو‌ها در هنگام کامیت کردن کدها‌ی خود می‌کند. با کمک این افزونه‌ها که در بخش Hooks نرم‌افزار بیت‌باکت فعال و تنظیم می‌شود، لازم نیست مدام به توسعه‌دهندگان گوشزد کنید که Key مربوط به ایشو‌ها را در Comment کامیت خود وارد کنند. با ملزوم کردن کاربران، پس از مدتی این کار یک عادت برای آن‌ها خواهد شد.

استفاده از Hooks در بیت‌باکت

قابلیت Hooks در بیت‌باکت (نسخه سرور) روش خوبی برای خودکار سازی فعالیت‌های متداول مربوط به مدیریت کد است. استفاده از Hooks روش خوبی برای مدیریت پیچیدگی‌های توسعه نرم‌افزار فراهم می‌آورد. برای مشاهده قابلیت‌هایی که بخش Hooks در بیت‌باکت فراهم شده است از بخش تنظیمات و قسمت workflow، گزینه Hooks را انتخاب کنید. موارد پیش‌فرضی در این قسمت وجود دارد.

Hooks در بیت باکت

با یکپارچه‌سازی نرم‌افزار جیرا و بیت‌باکت گزینه‌های خوبی برای استفاده از Hooks فراهم خواهد شد. Hooks هایی برای اسکن کردن کامنت‌ها در repository وجود دارد تا تمامی کامنت‌های TODO را به صورت خودکار به یک ایشو در جیرا تبدیل کند.

برای گسترش موارد استفاده از Hooks ها می‌توان از افزونه‌های مرتبط استفاده کرد. برای مثال با نصب افزونه Better Commit Policy for Bitbucket این امکان برای شما فراهم خواهد شد تا سیاست‌های مناسبی جهت کامیت کردن کد توسط توسعه‌دهندگان قرار دهید.

افزونه سیاست گذاری در بیت باکت

این سیاست‌ها و قوانین در نرم‌افزار جیرا وضع می‌شوند و زمانی که توسعه‌دهنده قصد انجام فعالیت‌هایی مثل commit, branch, tag , pull request داشته باشد، بیت‌باکت سیاست‌ها را با جیرا تطابق خواهد داد و در صورتی که تمامی موارد پذیرفته شود اجازه انجام این فعالیت به توسعه‌دهنده داده خواهد شد. این سیاست‌ها کمک خواهد کرد تا به مرور روال‌های مناسبی بین توسعه‌دهندگان شکل گیرد.

ارتباط جیرا و بیت باکت در سیاست گذاری

برای مثال در صورتی که توسعه‌دهنده‌ای از سیاست‌های تگ‌گذاری صحیح استفاده نکند، خطا دریافت خواهد کرد و لازم است تگ‌ها را مطابق با سیاست‌ها وضع شده اصلاح کند.

نمونه سیاست گذاری در بیت باکت

ساخت ایشو‌های جیرا از محیط بازبینی کدها در بیت‌باکت

یکی از مواردی که یکپارچه‌سازی بین جیرا و بیت‌باکت بسیار مفید و کابردی می‌کند، کار در pull request هاست.

بیت باکت یک محیط عالی جهت مشاهده و بازبینی pull request ها در اختیار کاربران قرار می‌دهد. زمانی که جیرا و بیت باکت با یکدیگر یکپارچه شده باشند، این امکان به وجود خواهد آمد که در هنگامی که کاربر در حال بازبینی کد‌ها است، در صورت نیاز به تغییرات در کد، تسک ما‌به‌ازای آن را به صورت مستقیم و بدون نیاز به خارج شدن از محیط بازبینی کد ایجاد نماید و به توسعه‌دهنده مربوطه در جیرا تخصیص دهد.

محیط بازبینی کد در بیت باکت و ارتباط با جیرا

استفاده از Release Hub

یکی دیگر از ابزارهای عالی در پروژه‌های جیرا، استفاده از بخش مدیریت release ها در این نرم‌افزار است که اصطلاحات Release Hub نیز گفته می‌شود و با یکپارچه‌سازی با نرم‌افزار بیت ‌باکت فعال می‌شود.
بخش Release Hub به شما اجازه می‌دهد تا وضعیت ایشو‌های مرتبط با release های برنامه‌ریزی شده را به صورت بصری مشاهده کنید.

این بخش نمودارهای بصری عالی برای مشاهده وضعیت تیکت‌ها و کارها، تا زمان سررسید release فراهم می کند.

نمودار release burndown در جیرا

هم چنین بخش Release Hub به شما این امکان را می‌دهد وضعیت ایشو‌هایی که برای یک Release انتخاب کرده‌اید را نیز مشاهده کنید. در این بخش هر ایشو شامل دو وضعیت خواهد بود. وضعیت آن در workflow جیرا و وضعیت آن در repository مرتبط با آن در نرم‌افزار بیت باکت.

وضعیت ایشوها در release hub

نتیجه

نرم‌افزارهای جیرا و بیت‌باکت از پرکاربردترین نرم‌افزارها در حوزه مدیریت پروژه‌های نرم‌افزاری و مدیریت کد است که هر دو محصول شرکت Atlassian است. امکان یکپارچه‌سازی این دو نرم‌افزار با یکدیگر و ویژگی‌هایی که فراهم می‌سازد باعث می‌شود فرایند توسعه‌ نرم‌افزار هر چه بیشتر به صورت خودکار طراحی شود و تا حد ممکن از انجام ‌کارها و فعالیت‌های متداول به صورت دستی توسط کاربران جلوگیری شود. این امر موجب می‌شود توسعه‌دهندگان بیشتر بر روی کار خود متمرکز شوند.

کارشناسی ارشد مهندسی صنایع و علاقه مند به مباحث لینوکس، مدیریت پروژه چابک (Agile) و مدیریت سرویس (ITSM) در حوزه‌های فناوری اطلاعات

    نظرتان را بنویسید

    آدرس ایمیل شما منتشر نخواهد شد.*