NUnit

כלי פיתוח חופשי לבדיקות יחידה

NUnit הוא כלי פיתוח חופשי לבדיקות יחידה בשפת התכנות C#‎ בסביבת הפיתוח ‎.Net. מטרתו דומה לזה של JUnit בתכנות ב-Java. וגם הוא אחד מרבים השייכים למשפחת xUnit.

NUnit
צילום מסך של ממשק NUnit 2.4.6 בסביבת חלונות
צילום מסך של ממשק NUnit 2.4.6 בסביבת חלונות
מפתח קוד פתוח
גרסה אחרונה 4.2.2 (31 באוגוסט 2024) עריכת הנתון בוויקינתונים
מערכת הפעלה Net, Mono.
נכתבה בשפות סי שארפ עריכת הנתון בוויקינתונים
סוג רישיון BSD-style (modified zlib license)
קוד מקור https://github.com/nunit/nunit עריכת הנתון בוויקינתונים
קטגוריה בדיקות תוכנה
http://www.nunit.org
לעריכה בוויקינתונים שמשמש מקור לחלק מהמידע בתבנית

דוגמה לבדיקת יחידה

עריכה

על מנת להריץ את הבדיקה יש ליצור תחילה מחלקה חדשה שבה נבצע את הבדיקות, בתוך מחלקה אחת ניתן לבצע בדיקות למספר מחלקות. בנוסף יש להוסיף את ה-DLL של NUnit לפרויקט. הדוגמה הבאה מציגה דוגמה פשוטה בשפת C#‎. מטרת הבדיקה היא לבדוק נכונות של ביטוי אריתמטי פשוט.

using NUnit.Framework;
 
 [TestFixture]
 public class ExampleTestOfNUnit
 {
   [Test]
   public void TestMultiplication()
   {
     Assert.AreEqual(4, 2*2, "Multiplication");
     
     // Equivalently, since version 2.4 NUnit offers a new and
     // more intuitive assertion syntax based on constraint objects
     // [http://www.nunit.org/index.php?p=constraintModel&r=2.4.7]:
     Assert.That(2*2, Is.EqualTo(4), "Multiplication constraint-based");
   }
 }

שיטות ביאור

עריכה


משמעות מטרה פונקציית ביאור
מחלקה שהיא בדיקת יחידה למחלקה אחרת מחלקה TestFixture
פונקציה שתרוץ לפני כל בדיקה פונקציה SetUp
פונקציה שתרוץ לאחר כל בדיקה פונקציה TearDown
מסמן פונקציה כפונקציית בדיקה פונקציה Test
מסמל שצריכה להתקבל שגיאה על ידי הבדיקה פונקציית בדיקה ExpectedException
מסמל שבדיקה צריכה לרוץ אבל לא מתחשב שהבדיקה נכשלה פונקציית בדיקה Ignore
פונקציה זו מתבצעת פעם אחת, לפני תחילת כל הבדיקות. פונקציה TestFixtureSetUp
פונקציה זו מתבצעת פעם אחת, לאחר שכל הבדיקות הסתיימו. פונקציה TestFixtureTearDown

בדיקה אם הפונקציה עברה את הבדיקה

עריכה

על מנת לבדוק אם התוצאות שקיבלנו בפונקציית הבדיקה תואמות את התוצאות שציפינו לקבל נשתמש במחלקת Assert. זוהי מחלקה סטטית הקובעת את תוצאת הבדיקה על ידי השוואה של תוצאת הפונקציה לתוצאה הרצויה. המחלקה קיימת גם ב-JUnit וגם ב-NUnit, השוני הוא בצורת הכתיבה. מאפשר לאמת את הקוד:

  • על ידי בדיקת ביטויים בוליאניים.
  • על ידי השוואת סוגים בסיסיים.
  • על ידי השוואת משתנים (by reference).
  • על ידי השוואת מערכים (by reference).


סוגים של Assert שניתנים לשימוש:

  • Assert.AreEqual(Type expected, Type actual);
  • Assert.AreEqual(Type expected, Type actual, Type delta);
  • Assert.AreEqual(Type expected, Type actual, string message);
  • Assert.AreEqual(Type expected, Type actual, Type delta, string message);
  • Assert.IsFalse(bool condition);
  • Assert.IsFalse(bool condition, string message);
  • Assert.IsNotNull(object object);
  • Assert.IsNotNull(object object, string message);
  • Assert.AreNotSame(object expected, object actual);
  • Assert.AreNotSame(object expected, object actual, string message);
  • Assert.IsNull(object object);
  • Assert.IsNull(object object, string message);
  • Assert.AreSame(object expected, object actual);
  • Assert.AreSame(object expected, object actual, string message);
  • Assert.IsTrue(bool condition);
  • Assert.IsTrue(bool condition, string message);
  • Assert.Fail();
  • Assert.Fail(string message);

אופן הרצת הבדיקות

עריכה

הרצת הבדיקות ב-NUnit מתבצעת על ידי תוכנה חיצונית שמותקנת במחשב. במידת הצורך ניתן להוסיף תוספים לוויז'ואל סטודיו שמאפשרים את הרצת הבדיקות ללא תוכנה חיצונית.

השוואה בין JUnit ל-NUnit

עריכה

NUnit היא שיטת בדיקה הדומה ל-JUnit, כאשר השוני העיקרי ביניהן הוא שפת הפיתוח שבה משתמשים. עם זאת, קיימים עוד כמה הבדלים מזעריים ביניהן מבחינת תחביר ואופן הרצת הבדיקות.

מאפיין NUnit JUnit
שפת פיתוח C#‎ Java
מערכת הפעלה .NET, Mono רב פלטפורמי
תחילת שימוש שימוש חיצוני – בפעם הראשונה דורש התקנה של NUnit, ויש צורך בהוספת קובץ DLL לפרויקט שימוש פנימי – על ידי הוספת JAR של JUnit לפרויקט
יצירת test class יצירת מחלקת בדיקות באופן ידני. אין תלות במחלקה ספציפית יצירת מחלקת בדיקות באופן אוטומטי על ידי Junit Test Case
הרצת הבדיקות דרך תוכנה חיצונית של NUnit (ניתן להריץ מתוך Visual studio על ידי התקנת תוספים) מתוך eclipse על ידי run As JunitTest
סימון פונקציות בדיקה לפני הפונקציה תגים מותאמים שם הפונקציה מתחילה במילה test
Assertion class יש לקרוא לפונקציית Assert באמצעות פונקציה סטטית קריאה לפונקציית Assert ישירות
פונקציות ביאור Annotations לפני הפונקציה נגדיר את סוג הפונקציה על ידי [ ] לפני הפונקציה נגדיר את סוג הפונקציה על ידי @

לקריאה נוספת

עריכה

קישורים חיצוניים

עריכה