您的位置:軟件測(cè)試 > 開(kāi)源軟件測(cè)試 > 開(kāi)源單元測(cè)試工具 > Nunit
一步一步學(xué)NUnit(二)
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時(shí)間:[ 2014/1/8 16:21:09 ] 推薦標(biāo)簽:NUnit 單元測(cè)試 測(cè)試工具

  這里也許有人會(huì)問(wèn),如果我的項(xiàng)目很大,每個(gè)測(cè)試方法都需要連接數(shù)據(jù)庫(kù),在每個(gè)方法執(zhí)行的時(shí)候進(jìn)行連接再釋放,這樣是不是太耗資源太慢了,能不能在一個(gè)單元測(cè)試類(lèi)實(shí)例化的時(shí)候運(yùn)行一個(gè)指定的方法呢?

  這是可以的。在NUnit中,我們使用[TestFixtureSetUp]和[TestFixtureTearDown]可以實(shí)現(xiàn)這樣的功能。[TestFixtureSetUp]是指在這個(gè)測(cè)試類(lèi)的整個(gè)生命周期中,它在所有的測(cè)試方法之前運(yùn)行一次,而[TestFixtureTearDown]是在所有的測(cè)試方法都結(jié)束時(shí)運(yùn)行。

  這里要注意的,[TestFixtureSetUp]與構(gòu)造函數(shù)是不一樣的,它標(biāo)識(shí)的方法遲于構(gòu)造函數(shù)運(yùn)行。我們?cè)賹?duì)這個(gè)測(cè)試類(lèi)進(jìn)行重構(gòu):

[TestFixture]
public class CalculatorTest
...{
    private Calculator cal;
    private int a, b, expected, actual;

    public CalculatorTest()
    ...{
        Console.WriteLine("執(zhí)行構(gòu)造函數(shù)");
    }

    [TestFixtureSetUp]
    public void InitClass()
    ...{
        Console.WriteLine("執(zhí)行TestFixtureSetUp");
        cal = new Calculator();
        a = 10;
        b = 2;
    }
    [TestFixtureTearDown]
    public void FinalizeClass()
    ...{
        Console.WriteLine("執(zhí)行TestFixtureTearDown");
    }

    [SetUp]
    public void InitMethod()
    ...{
        Console.WriteLine("執(zhí)行SetUp");
    }

    [TearDown]
    public void FinalizeMethod()
    ...{
        Console.WriteLine("執(zhí)行TearDown");
        a = 10;
        b = 2;
    }

    [Test]
    public void TestAdd()
    ...{
        Console.WriteLine("TestAdd() Begin");
        expected = 12;
        actual = cal.Add(a, b);
        Assert.AreEqual(expected, actual);
        Console.WriteLine("TestAdd() End");
    }
    [Test]
    public void TestMinus()
    ...{
        Console.WriteLine("TestMinus() Begin");
        expected = 8;
        actual = cal.Minus(a, b);
        Assert.AreEqual(expected, actual);
        Console.WriteLine("TestMinus() End");
    }
    [Test]
    public void TestMultiply()
    ...{
        Console.WriteLine("TestMultiply() Begin");
        expected = 20;
        actual = cal.Multiply(a, b);
        Assert.AreEqual(expected, actual);
        Console.WriteLine("TestMultiply() End");
    }
    [Test]
    public void TestDivide()
    ...{
        Console.WriteLine("TestDivide() Begin");
        expected = 5;
        actual = cal.Divide(a, b);
        Assert.AreEqual(expected, actual);
        Console.WriteLine("TestDivide() End");
    }
}

  在NUnit中,我們可以很清楚地看到這個(gè)類(lèi)的執(zhí)行順序:

  假如我們的測(cè)試項(xiàng)目中有使用到數(shù)據(jù)庫(kù),可以把數(shù)據(jù)庫(kù)連接寫(xiě)在[TestFixtureSetUp]中,把釋放的代碼寫(xiě)在[TestFixtureTearDown]中。

  我相信現(xiàn)在大家對(duì)NUnit的這4個(gè)屬性都應(yīng)該有一個(gè)直觀的認(rèn)識(shí)了吧。都是4個(gè)很簡(jiǎn)單的屬性,但是在使用中用處卻是非常大的。

上一頁(yè)12345下一頁(yè)
軟件測(cè)試工具 | 聯(lián)系我們 | 投訴建議 | 誠(chéng)聘英才 | 申請(qǐng)使用列表 | 網(wǎng)站地圖
滬ICP備07036474 2003-2017 版權(quán)所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd