m_35696791
m_35696791
خواندن ۳ دقیقه·۲ سال پیش

اصول تست نرم‌افزار

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

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

تست واحد (Unit testing) :

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

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

تست سطح یکپارچگی (Integration Testing):

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

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

تست سیستم (System Testing):

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

تست پذیرش (Acceptance Testing):

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

تست پذیرش دارای انواع مختلفی است که می‌توان به موارد زیراشاره کرد:

۱-تست آلفا: تست آلفا در سایت توسعه دهنده نرم‌افزار و در اغلب موارد توسط کارمندان داخلی و در بعضی از موارد توسط مشتری انجام می‌گیرد.

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

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


گردآورنده:زهره نبی زاده

دانشگاه آزاد اسلامی،کلاس اصول طراحی نرم افزار

استاد:دکتر مریم حاجی اسمعیلی. دکترای علوم کامپیوتر از دانشگاه کینگستون لندن

‏Dr.Maryam Hajiesmaeili

‏PhD of computer science from Kingston university of London

‏https://ir.linkedin.com/in/dr-maryam-hajiesmaeili-90930743

تستتست نرم‌افزار
شاید از این پست‌ها خوشتان بیاید