وبلاگ علی حسین زاده

صفحه شخصی علی حسین زاده در برگیرنده یادداشت‌هایی در رابطه با سیستم‌عامل لینوکس، مدیریت، و...
alihzadeh.blog.ir Weblog Logo

وبلاگ علی حسین زاده

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

وبلاگ علی حسین زاده

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

آخرین نظرات

چگونه باگ‌ها را گزارش دهیم؟

چهارشنبه, ۱۲ آذر ۱۳۹۳

باگ چیست؟

یکی از مفاهیم جالب و در عین حال پیچیده در دنیای نرم‌افزار (گرچه در سایر علوم هم کاربرد دارد)، مفهوم باگ (Bug) یا به طور ساده نقص نرم‌افزاری است. احتمالا می‌دانید به اشکالات نرم‌افزاری اصطلاحا باگ اطلاق می‌شود ولی واقعا چرا نرم‌افزارها باگ دارند؟ و چرا هیچ وقت شر این باگ‌ها حتی با ارائه انواع و اقسام آپدیت‌ها از سر ما کم نمی‌شود؟ مفهوم باگ، این واقعیت مهم را برای انسان روشن کرده است که هیچ فرمول و قانون مخلوق دست انسان، بی اشکال و کمبود نیست و در هر طرح و برنامه‌ای بدون تردید نقصان‌ها و لغزش‌هایی وجود دارد که در نگاه اول به نظر نرسیده‌اند. رفع باگ‌ها تقریبا مثل حل کردن معماست و برای بسیاری از برنامه‌نویسان یکی از قسمت‌های چالش برانگیز و لذت‌بخش کار است.

تعریف واژه باگ

تصویر: باگ چیست؟

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

باگ اشکالی است که در یک برنامه رخ داده و باعث از کار انداختن کلی آن یا اجرا نکردن دستور یا دستورات بعدی به صورت ناقص یا کامل می‌گردد. اغلب این مشکلات در هنگامی رخ می‌دهد که داده‌های دریافتی از سوی کاربر فیلتر نشده و برنامه سعی به اجرا کردن آن می‌کند برای نمونه می‌توان انجام عمل تقسیم را بیان کرد. فکر کنید برنامه دو متغیر را دریافت می‌کند به طوری که متغیر اول عدد صورت و متفیر دوم عدد مخرج می‌باشد اگر کاربر ابتدا عدد ۶ و سپس عدد ۳ را وارد کند برنامه در خروجی خود عدد ۲ را نمایش خواهد داد حال اگر کاربر در صورت یک عدد (مثلا ۶) و در مخرج یک حرف الفبا یا عدد صفر را وارد کند به نظر شما عکس‌العمل برنامه چه خواهد بود؟
همانطور که می‌دانیم در ریاضیات تقسیم عدد بر حروف الفبا و صفر تعریف نشده است پس برنامه با حالتی از پیش تعریف نشده برخورد می‌کند و چون قابلیت اجرا کردن آنها را ندارد هنگ می‌کند و خروجی منطقی را تحویل نمی‌دهد.

چرا باگ را گزارش دهیم؟

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

در ادامه با مجموعه اصولی که توسعه‌دهندگان توزیع لینوکسی elementary OS برای گزارش‌های باگ‌ها وضع کرده‌اند آشنا می‌شویم.

نکاتی که در هنگم گزارش یک باگ باید در نظر داشت:

۱- یکتا بودن گزارش باگ

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

۲- دقیق بودن عنوان

برای باگ خود عنوان دقیقی انتخاب نمائید. این کار باعث تسهیل کار توسعه‌دهندگان نرم‌افزار در جستجو و مرور لیست باگ‌ها می‌شود. عنوانی مانند «نرم‌افزار X کرش می‌کند» به دلیل ابهام موجود در آن مناسب نیست. عبارتی مانند «عملکرد را بهبود دهید» نیز دردی دوا نخواهد کرد. یک عنوان خوب می‌تواند چیزی شبیه این باشد: «زمانی که فرآیند X به پایان می‌رسد پیامی نمایش داده نمی‌شود».

۳- خودداری از بیان عبارات و ارزش‌های ذهنی، غیرقابل اندازه‌گیری و مبهم

شاید این توصیه شبیه توصیه شماره ۲ باشد، اما اگر تمایل دارید که مشکل یا باگی را گزارش دهید مهم است که بدانید باید حتی‌الامکان کمّی صحبت کنید. اگر نمی‌توانید برای گزارش باگ خود از اعداد و ارقام مقایسه‌ای استفاده کنید، سعی نمائید آنچه با آن مواجه شده و مشاهده کرده‌اید را دقیقا توضیح دهید. برای مثال نگوئید «X خوب کار نمی‌کند» یا «X عملکرد مناسبی ندارد». به جای آن تلاش کنید که توضیح دهید چه اتفاقی رخ داده است و در مقابل شما انتظار چه رخدادی را داشته‌اید. برای مثال: «پنل به جای اینکه به نرمی و با اجرای افکت باز شود، ناگهان ظاهر می‌شود». سخن آخر اینکه مشکل را به گونه‌ای گزارش دهید که ملموس و کاربردی باشد.

۴- گزارش باگ باید جامع و در عین حال مختصر باشد

یکی از مهمترین جنبه‌های یک گزارش باگ یا اشکال این است که توسعه‌دهنده باید بتواند از روی آن گزارش، موقعیت و مشکل مورد نظر را بازسازی نماید. بدین منظور شما باید اطلاعات مرتبط نظیر نسخه سیستم‌عامل (یا نرم‌افزار) خود، نسخه کتابخانه‌های مرتبط نظیر Gtk یا WebKit و هرگونه تغییر و دخل و تصرف در سیستم مثل تغییر در مدیر پنجره یا کرنل را ضمیمه گزارش خود نمائید. اگر می‌خواهید یک کرش (Crash) را گزارش دهید لازم است که backtrace را نیز به گزارش خود اضافه نمائید.

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

۵- خود را برای ارائه اطلاعات بیشتر آماده کنید

اگر گزارش شما دارای اطلاعات کافی برای بازتولید اشکال از سوی توسعه‌دهندگان نباشد، معمولا برچسب ناقص (Incomplete)* بر آن می‌خورد. در اغلب موارد یک توسعه‌دهنده از طریق یک نظر درخواست اطلاعات اضافی خاصی را خواهد کرد. اگر چنین اطلاعاتی از سوی شما ارائه نگردد، گزارش شما نهایتا بدون حصول نتیجه منقضی خواهد شد.

اگر شما گزارش باگ خود را به اشتباه در صفحه نرم‌افزار دیگری گزارش دهید، گزارش شما برچسبی مانند (Invalid) خواهد خورد. در چنین مواردی گاهی توسعه‌دهندگان در صورت شناسایی نرم‌افزار مورد نظر شما، خود راسا اقدام به انتقال گزارش مربوطه در صفحه نرم‌افزار مرتبط خواهند کرد در غیر این صورت شما خود باید نرم‌افزار مورد نظر خود را یافته و گزارش باگ خود را ارسال نمائید.

اگر هدف شما از گزارش درخواست یک امکان یا ویژگی جدید باشد توسعه‌دهنده گزارش شما را با برچسب Opinion یا Won't Fix مشخص خواهد کرد. توسعه‌دهندگان معمولا برای صحبت در مورد چنین مسائلی در دسترس و پاسخگو هستند اما بهتر است آنها را به خاطر برچسب‌هایی که به گزارش شما می‌زنند مورد شماتت قرار ندهید.

۶- گزارش دیگران را تائید نکنید

تمام گزارش باگ‌ها، گزارش باگ نیستند! گاهی کاربر به اشتباه تصور می‌کند که باگی را در نرم‌افزار کشف کرده در حالی که در بسیاری از موارد مشکل ناشی از عدم آشنایی کاربر با نرم‌افزار بوده است و نه وجود باگ در آن. تشخیص اینکه گزارش باگ ناشی از وجود یک باگ واقعیست یا نه بر عهده توسعه‌دهندگان است؛ بنابراین اگر اشکالی که دیگران گزارش کرده‌اند برای شما نیز وجود دارد می‌توانید آن را نشان‌دار کنید. اما در هر حال شما نباید به جای توسعه‌دهندگان گزارش باگ دیگران را مورد تائید قرار دهید. این گزاره در رابطه با گزارش باگ‌های خودتان نیز صحیح است یعنی حتی اگر ۱۰۰٪ نسبت به درستی گزارش خود اطمینان دارید، درست نیست که خودتان گزارش خود را تائید کنید. توسعه‌دهندگان در فرصت مناسب، خود گزارش باگ‌ها را بررسی و در صورت صحت، آنها را تائید خواهند کرد.

۷- از نوشتن نظراتی مثل «من هم همین مشکل را دارم» خودداری کنید

قبل از این هم تا حدودی به این نکته اشاره شد اما خوب است دوباره تذکر داده شود که باید از نوشتن نظراتی با مضامینی نظیر «این مشکل برای من هم پیش آمده» خودداری کرد. این کار روند رهگیری حل مشکل را بر هم ریخته و دنبال کردن منطقی مطالب و سوال و جواب‌ها را برای همه با مشکل مواجه می‌کند. تنها زمانی به اظهار نظر بپردازید که بخواهید اطلاعات مرتبطی که در فرآیند حل مساله و پیدا کردن ریشه آن ارزشمند هستند را ارائه کنید. اگر قصد دارید به توسعه‌دهندگان بفهمانید که این مشکل برای شما نیز رخ داده است از لینک‌ها یا دکمه‌هایی که با مضمون «این مشکل برای من نیز رخ داده است» استفاده کنید.

* توجه داشته باشید که اصل این راهنمایی برای کاربران لینوکس elementary OS نگارش شده است بنابراین ممکن است این برچسب‌ها در سایر نرم‌افزارها یا پروژه‌ها متفاوت بوده و یا با واژه‌های دیگری نام‌گذاری شده باشند. اما در هر صورت اصول کار یکسان است.

منابع: + + +

نویسنده: علی حسین‌زاده

لینک ثابت و کوتاه به این مطلب: http://alihzadeh.blog.ir/post/218

باز نشر مطالب با ذکر «وبلاگ علی حسین زاده» و درج لینک به همان مطلب، آزاد است.


خبرخوان (RSS) وبلاگ    

سایر مطالب

اگر از کاربران خبرخوان آنلاین Inoreader هستید می‌توانید با عضویت در کانال
Ali H Zadeh مطالب این وبلاگ را به همراه سایر مطالب برگزیده در وب، دنبال نمائید.

لینکستان در خبرخوان inoreader

  • ۹۳/۰۹/۱۲
  • علی حسین زاده

IT

باگ

توسعه

سیستم‌عامل

لینوکس

نرم‌افزار

نظرات  (۳)

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

با احترام فراوان
آسان نشر
تسهیلات نشر جهانی آثار ارزشمند ایرانی

  • بلاگ اندروید
  • جالب بود. فرهنگ معرفی باگ رو هم یادگرفتیم :)


  • صابر راستی کردار
  • از سایت لیبره آفیس به اینجا هدایت شدم. مطلب خوب و مفیدی بود. دست شما درد نکنه.
    ارسال نظر آزاد است، اما اگر قبلا در بیان ثبت نام کرده اید می توانید ابتدا وارد شوید.
    شما میتوانید از این تگهای html استفاده کنید:
    <b> یا <strong>، <em> یا <i>، <u>، <strike> یا <s>، <sup>، <sub>، <blockquote>، <code>، <pre>، <hr>، <br>، <p>، <a href="" title="">، <span style="">، <div align="">
    تجدید کد امنیتی