NUnit הוא כלי פיתוח חופשי לבדיקות יחידה בשפת התכנות C# בסביבת הפיתוח .Net.
מטרתו דומה לזה של JUnit בתכנות ב-Java. וגם הוא אחד מרבים השייכים למשפחת xUnit.
דוגמה לבדיקת יחידה
על מנת להריץ את הבדיקה יש ליצור תחילה מחלקה חדשה שבה נבצע את הבדיקות, בתוך מחלקה אחת ניתן לבצע בדיקות למספר מחלקות. בנוסף יש להוסיף את ה-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 |
לפני הפונקציה נגדיר את סוג הפונקציה על ידי [ ] |
לפני הפונקציה נגדיר את סוג הפונקציה על ידי @
|
לקריאה נוספת
קישורים חיצוניים