دانلود پایان نامه : ارائه یک روش تولید خودکار داده های ورودی برای تست جهش

دانلود متن کامل پایان نامه مقطع کارشناسی ارشد رشته مهندسی فناوری اطلاعات

عنوان : ارائه یک روش تولید خودکار داده های ورودی برای تست جهش

وزارت علوم و تحقیقات و فناوری

دانشگاه علوم فنون مازندران

موضوع : ارائه یک روش تولید خودکار داده های ورودی برای تست جهش

رشته : مهندسی فناوری اطلاعات

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

زمستان 92

برای رعایت حریم خصوصی نام نگارنده پایان نامه درج نمی شود(در فایل دانلودی نام نویسنده موجود است)تکه هایی از متن پایان نامه به عنوان نمونه :(ممکن است هنگام انتقال از فایل اصلی به داخل سایت بعضی متون به هم بریزد یا بعضی نمادها و اشکال درج نشود ولی در فایل دانلودی همه چیز مرتب و کامل است)چکیدهایده ی اصلی تست جهش بر­اساس  استفاده از نقص­ها (faults) برای شبیه سازی خطاهایی است که برنامه نویسان انجام می­دهند. بروز نقص­ها ممکن است در دو سطح یکپارچگی و در سطح واحد اتفاق بیافتد که در بعضی موارد ممکن است جستجو و یافتن محل نقص دشوار باشد با تزریق نقص­ها به صورت مجازی می­توان داده­ها ورودی مناسب که می­تواند وجود آن­ها را آشکار کند پیدا کرد.انجام فرآیند تست جهش هزینه بر است این هزینه­ها به طور کلی از چهار منبع نشات می­گیرند که عبارتند از :1- تولید ورودی­های تست 2- زمان کامپایل کد جهش یافته و کد اصلی 3- اجرا کد جهش یافته و اصلی 4- مقایسه­ی نتایج خروجی برنامه­ی اصلی با برنامه­ی جهش یافته. در این پایان نامه برای کاهش هزینه­ی اول با استفاده از الگوریتم کلونی زنبور تولید داده­های تست را به صورت خودکار انجام دادیم از طرف دیگر از طریق تکنیک­های تزریق بایت کد جاوا هزینه کامپایل را نیز به صفر رساندیم و برای بالا بردن عملکرد سیستم اجرای تست را به صورت موازی انجام داده­ایم.کلید واژه: تست ­جهش، خودکارسازی، ورودی­های تست، موارد تست، الگوریتم کلونی زنبور.   فهرست مطالبعنوان                                                                                                                  صفحه1                 فصل اول      مقدمه و کلیات تحقیق.. 11-1           مروری بر دغدغه­های تست نرم­افزار.. 21-1-1     مقدمه.. 21-1-2     بهره گیری از طبیعت..... 41-1-3     هدف از انجام.. 62                 فصل دوم     ادبیات و پیشینه تحقیق.. 82-1           تست جهش...... 92-1-1     تئوری و نظریات..... 92-1-2     متدلوژی.... 122-1-3     عملگرها. 142-1-4     تکینکهای کاهش هزینه.. 202-1-5      تولید جهش کمتر  212-1-6     تکنیک­های کاهش هزینه در زمان اجرای برنامه.. 292-1-7     جهشهای برابر.. 382-1-8     خودکار سازی تست..... 432-2            نتیجه­گیری.... 473                 فصل سوم     روش تحقیق.. 503-1           شرح روش­های مشابه.. 513-1-1      روش مبتنی بر CBT  513-1-2     روش اجرای سمبلیک...... 523-1-3     ترکیب روش اجرای پویای سمبلیک (DSE) با اسکیما. 573-1-4     روشهای مبتنی بر جستجو.. 593-2           شرح ابزار ارائه شده. 603-2-1     ابزارهای ارائه شدهی مبتنی بر جاوا 603-2-2     تولید کنندهی جهش­ها. 633-2-3     تولید کنندهی ورودیهای تست..... 663-2-4     الگوریتم کلونی زنبور.. 673-2-5     کلاس تولید کننده­ی موارد تست..... 693-2-6     اجرا کننده­ی تست..... 773-2-7     دستیاران... 783-3           نتیجه­گیری.... 824                 فصل چهارم. 84محاسبات و یافته های تحقیق.. 844-1           تاثیر تعداد نخها در از بین رفتن جهشها. 854-2           بررسی اثر تعداد نخها در معیار پوشش...... 864-3           نتایج بدست آمده از تست سه برنامه.. 885                 فصل پنجم     نتیجه گیری و پیشنهادات... 916                 پیوست... 946-1           الگوریتم کلونی مورچه.. 946-2           K-means.. 986-3           Agglomerative.. 986-4           منابع... 99            فهرست جداولجدول(‏2‑1): 22 عملگر مُدرا [9] 14جدول(‏2‑2): عملگرهای جهش ارائه شده در سطح بین کلاس [10] 18جدول(‏2‑3): سه جهش  و  [15] 24جدول (‏2‑4): : فاصلهی همینگ سه جهش  و  [15] 24جدول(‏2‑5): خلاصهی نتایج بدست آمده حاصل از اجرای روش دستهبندی بر روی پنج برنامه [15] 25جدول(‏2‑6): تاثیر حاصل ترکیب جهش های برابر و نابرابر با یکدیگر. 28جدول(‏2‑7): محدودیتهای تولید شدهی متناظر با جهشها  [29] 41جدول(‏2‑8): مقایسه بین روشهای مختلف... 47جدول(‏3‑1): نمونهای از مسیرها و محدودیتهای انها در اجرای سمبلیک... 54جدول(‏3‑2): بررسی حالات مختلف برای محاسبهی شایستگی.. 72جدول(4‑1): نتایج بدست آمده از تست سه برنامه. 88جدول(‏4‑2):مقایسهی روش ارائه شده با سایر ابزارها 89    فهرست تصاویر و نمودارهاشکل(‏2‑1): چارت فرآیند تست جهش... 13شکل(‏2‑2): درصد استفاده­ی مقالات از تکنیکهای کاهش هزینه [2] 21شکل(‏2‑3): چهار متغییر مقایسهی جهش ضعیف [23] 32شکل (‏2‑4):گراف کنترل جریان برنامه­ی MID [30] 36شکل (‏2‑5): نمایش دامنه قبل و بعد از تقسیم [30] 36شکل (‏2‑6): فرآیند MSG [31] 38شکل (‏2‑7): ارتباط دامنه­ی ورودی سه شرط کفایت، ضرورت و دسترسی [29] [34] 43شکل (‏3‑1): ساختار Godzilla. 51شکل(‏3‑2): نمونهای از اجرای سمبلیک... 54شکل(‏3‑3): چهارچوب ارائه شده در مقاله­ی [40] 58شکل(‏3‑4): کلونی مورچه و تست جهش... 59شکل(‏3‑5): ماژول تولید کننده­ی جهش... 66شکل (‏3‑6): ماژول تولید کننده­ی ورودی­های تست... 76شکل(‏3‑7): گراف کنترل جریان برنامه تشخیص نوع مثلث... 81شکل(‏3‑8): مدل روش ارائه شده 83شکل(4‑1): اثر تعداد نخها در از بین بردن جهش... 86شکل (4‑2) پوشش مسیرهای تست در گراف CFG. 87شکل(4‑3): اثر تعداد نخها بر پوشش مسیرهای تست در گراف CFG. 87شکل(‏6‑1):  شیوه حرکت مورچهگان در هنگام برخورد با مانع. 95شکل (‏6‑2) : گراف شهرها و مسیرها 96  

    

1    فصل اول

مقدمه و کلیات تحقیق

    

1-1     مروری بر دغدغه­های تست نرم­افزار

1-1-1 مقدمه

یکی از چالش­های امروز پروژه­های نرم­افزار، تست است زیرا برخلاف محصولات تولید شده توسط سایر علوم مهندسی، نرم­افزار محصولی غیرقابل لمس است از این جهت برای اطمینان از کیفیت، نیاز به صرف هزینه و وقت بیشتر برای تست آن است. تست در حقیقت یکی از اساسی­ترین روش­ها برای ارزیابی نرم­افزار تحت توسعه است. روش­های سنتی تست نرم­افزار، تنها به یافتن بعضی از خطاها [1]بعد از فاز پیاده­سازی محدود می­شد و از این جهت ریسک وجود خطا در نرم­افزار، بعد از تحویل، افزایش می یافت و حتی وجود خطاها در نرم­افزار گاهی موجب شکست [2]نرم­افزار می­شود اما منشاء بخشی از این خطاها در کجاست؟ منشاء بخشی از این خطاها در نقص­هایی[3] است که برنامه نویسان به طور غیر عمدی و بر اثر بی دقتی وارد کد برنامه می­کنند مانند: کوچکتر از حد نیاز در نظر گرفتن طول یک آرایه، اشتباه در پرانتز گذاری عبارت­ها، استفاده­ی نادرست از عملگرهای دودویی و یکانی و ...  که در صورت شناسایی محل آن در بسیاری از موارد با ایجاد یک تغییر کوچک در کد برنامه قابل اصلاح است اما در صورت عدم اصلاح وجود یک یا چند نقص در برنامه سبب ایجاد یک وضعیت درونی اشتباه در برنامه ­شود که در برخی از موارد با وارد کردن یک ورودی خاص تحریک شده و ممکن است این وضعیت درونی به یک رفتار بیرونی اشتباه تبدیل شود و حتی در برخی از موارد موجب شکست برنامه شود به عنوان مثال اگر بدن انسان را به یک برنامه­ی کامپیوتری تشبیه کنیم نقص­ها در حقیقت عوامل بیماری زا هستند که در یک بدن سالم وارد می­شوند و آن­ را تحت تصرف خود درمی­آورند، خطاها مانند یک وضعیت درونی غیر عادی در بدن مانند فشار خون بالا، وجود یک نوع باکتری در خون، بی نظمی در نبض بیمار که پزشکان با کنارهم قرار دادن این علائم تلاش می­کنند به علت بیماری پی ببرند، از کار افتادگی­ها در حقیقت علائم درونی هستند که از حالت نهان و درونی خود خارج شده به طوری که توسط بیمار نیز قابل تشخیص و بیان هستند.حال که توانستیم مفهوم نقص، خطا و شکست را شرح دهیم، می­توانیم میان سه مفهوم تست، تست شکست و اشکال زدایی، تمایز قائل شویم وآن عبارت است از:
  • تست: ارزیابی نرم­افزار با استفاده از مشاهده و بررسی آن در هنگام اجرا.
  • تست شکست: اجرای برنامه که منجر به شکست آن می­شود.
  • اشکال زدایی: فرآیندی که با توجه به شکست­ها محل نقص­های مربوطه را پیدا می­کند.
یکی از چالش­های عمده در این بخش یافتن نقص­های برنامه است زیرا به ازای هر نقص تعداد محدودی از ورودی­ها خروجی برنامه را تغییر می­دهند بنابراین پیدا کردن محل نقص همواره کار ساده­ای نیست با در نظر گرفتن این ایده به سه شرط اساسی می­رسیم که وجود آن­ها برای تبدیل یک نقص به یک شکست ضروری است:1.Errors2.Failure[3] Faultsتعداد صفحه : 114قیمت : 14000تومان

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

و در ضمن فایل خریداری شده به ایمیل شما ارسال می شود.

پشتیبانی سایت :        09309714541 (فقط پیامک)        info@arshadha.ir

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

--  -- --

مطالب مشابه را هم ببینید

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