ניתוח תוכנה דינמי, ניתוח קוד דינמי או בקצרה ניתוח דינמי, הוא ניתוח של תוכנת מחשב (code\program analysis) הכולל הרצת התוכנה המדוברת (בניגוד לניתוח תוכנה סטטי, שאינו עושה זאת). ניתוח דינמי כולל טכניקות מוכרות מהנדסת תוכנה כגון בדיקת יחידה, ניפוי שגיאות ומדידה של כיסוי קוד, אך כולל גם טכניקות פחות מוכרות כמו חיתוך תוכניות (program slicing) והסקת מסקנות אינווריאנטית. ניתוח דינמי מיושם באופן נרחב בדיקות אבטחת תוכנה בצורה של זיהוי שגיאות זיכרון בזמן ריצה, טשטוש (fuzzing), ביצוע סימבולי דינמי (dumanic symbolic execution) ומעקב אחר "כתמים" (taint tracking).
כדי שניתוח דינמי יהיה אפקטיבי, תוכנית היעד חייבת להתבצע עם מספיק כניסות בדיקה[1] כדי לתת מענה לטווחי הקלט והפלטים האפשריים. אמצעי בדיקת תוכנה, כגון כיסוי קוד, וכלים כגון בדיקת מוטציות, משמשים כדי לנסות לזהות מקרים שבהם הבדיקה אינה מספקת.
לצורך ניתוח דינמי, יש להקפיד למזער את ההשפעה שיש למכשור על הביצוע (כולל מאפיינים זמניים) של תוכנית היעד. בדיקות יחידה, בדיקות אינטגרציה, בדיקות מערכת ובדיקות קבלה הם צורות של בדיקות דינמיות.[2]
סוגי ניתוח דינמי
כיסוי קוד
חישוב כיסוי הקוד לפי חבילת בדיקה או עומס עבודה הוא טכניקת ניתוח דינמית סטנדרטית. הוא מזהה מקרים שבהם קוד לא הופעל במהלך בדיקות - מבחין בין קוד ש"מכוסה" לקוד שאינו מכוסה.
צורת ניתוח זו מזהה שליליות (קוד שאינו נבדק), אך אינה מזהה חיוביות (היא אינה יכולה לזהות אם הקוד נבדק כראוי - אפילו עבור קוד עם "100% כיסוי"). קוד יכול להיות מורץ על ידי מערכת בדיקה אוטומטית, וכתוצאה יהיה "כיסוי קוד", גם אם ה"בדיקות" לא באמת בודקות דבר גבי מה שהקוד עושה.
VB Watch מחדיר קוד ניתוח דינמי לתוכניות Visual Basic כדי לפקח על כיסוי קוד, מחסנית, מעקב אחר ביצוע, אובייקטים ומשתנים מופעלים.
בדיקה דינמית
בדיקה דינמית כוללת ביצוע תוכנית על קבוצה של מקרי בדיקה (test cases).
זיהוי שגיאות זיכרון
דוגמאות:
AddressSanitizer : זיהוי שגיאות זיכרון עבור Linux, macOS, Windows ועוד. חלק מ־LLVM .
BoundsChecker : זיהוי שגיאות זיכרון עבור יישומים מבוססי Windows. חלק מ- Micro Focus DevPartner .
Dmalloc : ספריה לבדיקת הקצאת זיכרון ודליפות. יש לבצע קומפילציה מחדש של התוכנה, וכל הקבצים חייבים לכלול את קובץ הכותרת C המיוחד dmalloc.h.
Intel Inspector : מאתר שגיאות זיכרון דינמי עבור יישומי C, C++ ו-Fortran הפועלים על Windows ו- Linux .
PurifyPlus : בעיקר איתור בזיכרון מושחת וזיהוי דליפות זיכרון.
Valgrind : מריץ תוכניות על מעבד וירטואלי ויכול לזהות שגיאות זיכרון (למשל, שימוש שגוי ב־malloc ו־free ) ותנאי מרוץ תהליכים בתוכנות ריבוי תהליכונים.
טשטוש
Fuzzing היא טכניקת בדיקה הכוללת ביצוע תוכנית על מגוון רחב של קלט; לעיתים קרובות, קלטים אלו נוצרות באופן אקראי (לפחות בחלקן). Gray-box fuzzers משתמשים בכיסוי קוד כדי להנחות את יצירת הקלט.
ביצוע סמלי דינמי
ביצוע סימבולי דינמי (הידוע גם כ- DSE או ביצוע קונקולי) כולל ביצוע תוכנית בדיקה על קלט קונקרטי, איסוף אילוצי הנתיב הקשורים לביצוע, ושימוש בפותר אילוצים (בדרך כלל, פותר SMT ) כדי ליצור תשומות חדשות שיגרום התוכנית לקחת נתיב זרימת בקרה אחר, ובכך להגדיל את כיסוי הקוד של חבילת הבדיקה. [3] DSE יכול להתייחס לסוג של טשטוש ("קופסה לבנה").
ניתוח זרימת נתונים דינמי
ניתוח זרימת נתונים דינמי עוקב אחר זרימת המידע מ"מקורות" ל"שקעים". צורות של ניתוח זרימת נתונים דינמי כוללות ניתוח כתמים דינמי ואפילו ביצוע סימבולי דינמי.[4][5]
הסקת מסקנות אינווריאנטית
Daikon הוא יישום של זיהוי דינמי של אינוריאנטים. Daikon מריץ תוכנית, צופה בערכים שהתוכנית מחשבת, ולאחר מכן מדווח על מאפיינים שהיו נכונים ביחס לביצועים שנצפו, ולכן כנראה נכונים בכל הביצועים.
ניתוחי אבטחה
ניתן להשתמש בניתוח דינמי כדי לזהות בעיות אבטחת מחשבים או רשת.
IBM Rational AppScan היא חבילה של פתרונות אבטחת יישומים המיועדים לשלבים שונים של מחזור חיי הפיתוח. החבילה כוללת שני מוצרי ניתוח דינמיים עיקריים: IBM Rational AppScan Standard Edition, ו-IBM Rational AppScan Enterprise Edition. בנוסף, החבילה כוללת את IBM Rational AppScan Source Edition - כלי ניתוח סטטי.
שגיאות במקבול
Parasoft Jtest משתמשת בזיהוי שגיאות בזמן ריצה כדי לחשוף פגמים כגון תנאי מרוץ, exceptions, דליפות משאבים וזיכרון ופגיעויות להתקפות אבטחה.
Intel Inspector מבצע שרשור בזמן ריצה וניתוח שגיאות זיכרון ב-Windows.
Parasoft Insure++ הוא כלי לניתוח זיכרון וזיהוי שגיאות בזמן ריצה. רכיב ה-Inuse שלו מספק תצוגה גרפית של הקצאות זיכרון לאורך זמן, עם נראות ספציפית של השימוש הכולל בערימה, הקצאות בלוקים, דליפות אפשריות יוצאות דופן וכו'.
ה-Thread Sanitizer (של גוגל) הוא כלי לזיהוי מרוץ נתונים. הוא מכשיר את LLVM IR כדי ללכוד גישה מהירה לזיכרון.
חיתוך תוכנית
עבור תת-קבוצה נתונה של התנהגות של תוכנית, חיתוך התוכנית מורכב מ"הקטנת" התוכנית לצורה המינימלית שעדיין מייצרת את ההתנהגות שנבחרה. התוכנית המוקטנת נקראת "פרוסה" והיא ייצוג נאמן של התוכנית המקורית בתחום של תת-קבוצת ההתנהגות שצוינה. בדרך כלל, מציאת פרוסה היא בעיה בלתי פתירה, אך על ידי ציון תת-קבוצת התנהגות היעד על ידי הערכים של קבוצת משתנים, ניתן לקבל פרוסות משוערות באמצעות אלגוריתם זרימת נתונים. פרוסות אלה משמשות בדרך כלל מפתחים במהלך איתור באגים כדי לאתר את מקור השגיאות.
ניתוח ביצועים
רוב כלי ניתוח הביצועים משתמשים בטכניקות ניתוח תוכניות דינמיות.