App下載

Java中的TestNG與JUnit測試框架:哪個(gè)更好?

流年絮語 2021-09-13 09:58:17 瀏覽數(shù) (3707)
反饋

介紹

軟件開發(fā)經(jīng)歷了許多階段,如需求收集和分析、溝通、設(shè)計(jì)、代碼構(gòu)建、測試和發(fā)布。企業(yè)必須確保他們交付的產(chǎn)品符合標(biāo)準(zhǔn),當(dāng)產(chǎn)品通過多維質(zhì)量檢查時(shí),這是非常有必要的。測試是 SDLC 不可或缺的一部分,可以手動(dòng)或自動(dòng)完成。單元測試是一種可靠的測試形式,它涉及測試軟件的每個(gè)組件。像 ?JUnit? 和 ?TestNG? 這樣的單元測試框架呈現(xiàn)出相似的測試根源,因此關(guān)于 ?TestNG? 與 ?JUnit? 的爭論仍然存在。  

什么是單元測試?

測試不是單一的活動(dòng),而是涵蓋各種測試場景。它以不同的方式進(jìn)行分類,其中一種是基于測試級別,例如集成、單元和系統(tǒng)測試?;谀繕?biāo)的應(yīng)用程序測試涵蓋移動(dòng)測試、Web 和混合測試。

單元測試涉及測試軟件產(chǎn)品中最微小的代碼。目的是檢查代碼的每個(gè)組件的質(zhì)量是否按預(yù)期執(zhí)行。它在開發(fā)階段執(zhí)行。一段代碼被隔離以確保其有效性和準(zhǔn)確性。代碼的單個(gè)組件可以是函數(shù)、模塊、對象或方法??紤]任何軟件工程;單元測試總是在集成測試之前先執(zhí)行。它有助于在應(yīng)用程序開發(fā)生命周期的早期階段識(shí)別和解決錯(cuò)誤。開發(fā)人員使用不同的單元測試框架來創(chuàng)建單元測試的自動(dòng)化測試用例。市場上有不同的工具可以執(zhí)行單元測試,如 ?JUnit?、?NUnit?、?PHPUnit?、?JMockit ?等。

公司使用不同的單元測試框架來管理測試成本,提高速度、效率和準(zhǔn)確性。在?Selenium – Java? 中,?JUnit ?和 ?TestNG ?是最受歡迎的單元測試框架。 

 JUnit  于 1997 年作為基于 Java 的開源單元測試框架推出。它是 ?XUnit ?的一部分,?XUnit? 是單元測試框架系列的代表。它允許開發(fā)人員編寫和運(yùn)行可重復(fù)的測試。它與 Selenium 一起廣泛用于編寫 Web 自動(dòng)化測試。其最新的程序員友好版本是 ?JUnit 5?,它為 Java 虛擬機(jī)上基于開發(fā)人員的測試創(chuàng)建了一個(gè)強(qiáng)大的基礎(chǔ)。 

TestNG  也是一個(gè)基于 Java 的單元測試框架,于 2007 年在 ?JUnit ?的同一行上開發(fā),但具有新的和改進(jìn)的功能。這些新功能包括靈活的測試配置、參數(shù)支持、數(shù)據(jù)驅(qū)動(dòng)測試、注釋、各種集成等等。?TestNG? 執(zhí)行單元、端到端和集成測試。?TestNG? 生成報(bào)告,幫助開發(fā)人員了解所有測試用例的通過、失敗和跳過狀態(tài)。借助 Selenium 中的 ?TestNG?,您可以使用?estng-failed.xml? 文件單獨(dú)運(yùn)行失敗的測試,以僅運(yùn)行失敗的測試用例。根據(jù) ?mvnrepository.com?,截至 2021 年 2 月,?TestNG ?的最新版本是 ?7.4.0?。

必須了解 ?TestNG ?和 ?JUnit ?測試框架之間的區(qū)別,以確定這兩個(gè)自動(dòng)化測試框架中的哪一個(gè)最適合您的項(xiàng)目。

TestNG 和 JUnit 的區(qū)別 

?TestNG?和?JUnit?雖然沒有明顯區(qū)別,但都是最頂級的基于Java的自動(dòng)化框架,各有優(yōu)缺點(diǎn)。盡管如此,讓我們嘗試了解 ?Selenium WebDriver? 中 ?JUnit ?和 ?TestNG ?框架之間的主要區(qū)別:

1、測試套件

測試套件由一組 JUnit 和 TestNG 測試組成,允許您同時(shí)執(zhí)行測試。早期版本的 JUnit 中不允許使用測試套件功能,但它是在 JUnit 5 中引入的,而該功能始終存在于 TestNG 中。盡管兩者都有測試套件,但它們對每個(gè)套件執(zhí)行測試的方式存在關(guān)鍵差異。讓我們看一下展示測試套件如何在兩個(gè)框架中運(yùn)行的代碼片段。

TestNG中的測試套件從 XML 文件運(yùn)行:

<suite name=”TestSuite”>
    <test name=”Demo”>
        <classes>
            <class name=”com.fsecure.demo.testng.TestNGTest1″ />
            <class name=”com.fsecure.demo.testng.TestNGTest2″ />
        </classes>
    </test>
</suite>

而在 JUnit 中,使用了 ?@RunWith? 和 ?@Suite? 之類的注釋,如下面的代碼片段所示。兩個(gè)類 JUnit 1 和 2 是使用注解?@Suite? 編寫的。

@RunWith(Suite.class)
@Suite.SuiteClasses({
   JUnit1.class,
   JUnit2.class
})
public class JunitTest5 {
   //code
}

2、 注釋

對于測試人員來說,使用 TestNG 更容易,因?yàn)樗鼮樗麄兲峁┝硕鄠€(gè)選項(xiàng)來使用測試套件。例如,可以通過將類捆綁成組來執(zhí)行測試套件。

JUnit 和 TestNG 框架中使用的注釋的工作方式相似,只是名稱略有不同。下表顯示了 JUnit 和 TestNG 注釋的差異。

特征聯(lián)隊(duì) 5測試
將方法標(biāo)記為測試方法@Test@Test
它在類的第一個(gè)測試方法之前執(zhí)行@BeforeAll@BeforeClass
它在當(dāng)前類的所有測試方法都執(zhí)行完畢后執(zhí)行。@AfterAll@AfterClass
它在每個(gè)測試方法之前執(zhí)行@BeforeEach@BeforeMethod
在每個(gè)測試方法之后執(zhí)行@AfterEach@AfterMethod
它在套件中的所有測試運(yùn)行之前執(zhí)行。不適用@BeforeSuite
它在套件中的所有測試都運(yùn)行后執(zhí)行。不適用@AfterSuite
在測試之前執(zhí)行。不適用@BeforeTest
測試后執(zhí)行。不適用@AfterTest
在任何這些組的第一個(gè)測試方法之前執(zhí)行。不適用@BeforeGroups
在任何這些組的第一個(gè)測試方法之后執(zhí)行。不適用@AfterGroups
忽略測試@Disabled(在 JUnit4 中是 @ignore)@Test(Enable=false)
預(yù)期異常@Test(expected=ArithmeticException0.class )@Test( expectedException
=ArithmeticException.class )
暫停@TimeOut@Test(timeout = 1000)

在 JUnit 4 中,?@BeforeClass? 和 ?@AfterClass? 方法被認(rèn)為是靜態(tài)的,而在 TestNG 中沒有這樣的限制。

JUnit
TestNG

TestNG vs. JUnit——測試用例管理

測試執(zhí)行的管理是一項(xiàng)重要任務(wù);與 JUnit 相比,TestNG 使此任務(wù)更容易。TestNG 在以下方面的幫助下實(shí)現(xiàn)了這一點(diǎn):

  • 分組測試用例:這是一項(xiàng)僅適用于 TestNG 的功能。 它涉及通過創(chuàng)建多個(gè)組來執(zhí)行任務(wù)。每個(gè)都包含各種類,并且可以在單獨(dú)的組中運(yùn)行測試,而不是運(yùn)行孤立的測試。它使用?@Test? 注釋中的參數(shù)。
@Test(groups={"groupname1",<"group2">..,<"groupN">})

忽略測試:不需要執(zhí)行來自龐大測試套件的某些測試,尤其是當(dāng)您只想測試特定功能時(shí)。 此功能闡明是否應(yīng)忽略或考慮特定的單元測試。JUnit 和 TestNG 都配備了此功能,以及前面討論的所有注釋。在 JUnit 中,此功能使用 ?@ignore ?注解:在 TestNG 中,組包含在“groups”標(biāo)簽下的 XML 文件中,可以在 <test> 或 <suite> 標(biāo)簽下輕松識(shí)別。

@Ignore
public void method1()
{  
     //code
}

而在 TestNG 中,它使用 ?@Test( enabled = false )? 注釋運(yùn)行。

@Test(enabled=false)
public void TestWithException()
{ 
    //code
}
  • 參數(shù)化:這意味著在每次測試執(zhí)行時(shí)填充值/參數(shù)。結(jié)果,我們得到了改進(jìn)的代碼可重用性。它是數(shù)據(jù)驅(qū)動(dòng)的測試,可減少代碼長度并提高其可讀性。TestNG 與 JUnit 提供此功能的方式有所不同。TestNG 有一個(gè)簡單的方法來修復(fù)測試用例中的參數(shù)。它利用?@Parameter? 注釋并將參數(shù)添加到給定的測試方法?!盀g覽器”的值在 XML 文件(例如 testng.xml)中聲明,而 JUnit 使用 ?@ParameterizedTest ?注釋。
  • 依賴測試:此功能顯示一種測試方法何時(shí)依賴于另一種測試方法。JUnit 不支持此功能,而 TestNG 支持。由于 TestNG 是最新的,它支持多種類型的測試。在TestNG中,依賴方法使用?@DependsOnMethods?注解。
@Test(dependsOnMethods = {"LoginBrowser"})
//code
  • 異常測試:此功能驗(yàn)證在測試執(zhí)行期間遇到錯(cuò)誤時(shí)要使用的異常。TestNG 和 JUnit 都提供此功能,但處理異常的方式略有不同。TestNG在?@Test ?注釋中使用 ?expectedException ?參數(shù) 

在 JUnit 中,?assertThrows API? 用于異常處理

@Test(expectedExceptions = ArithmeticException.class)
public void DivideByZero() {
  int i = 10/0;
}
  • 超時(shí)測試:這允許測試執(zhí)行中的超時(shí)功能設(shè)置時(shí)間限制,當(dāng)超過時(shí),測試自動(dòng)失敗。TestNG 和 JUnit 都以相同的語法提供此功能。
@Test(expected = ArithmeticException.class)
public void DivideByZero() {
  int i = 10/0;
}

TestNG 與 JUnit – 并行測試執(zhí)行

最有效的測試方法之一是執(zhí)行并行測試。在基于云的 Selenium Grid 上同時(shí)而不按順序運(yùn)行測試比在本地 Selenium Grid 上執(zhí)行它支持更多的并行性。TestNG 和 JUnit 5 都支持并行測試。

TestNG 與 JUnit – 報(bào)告

報(bào)告是測試中分析測試結(jié)果的重要要求。TestNG 默認(rèn)生成 HTML 和索引報(bào)告。JUnit 不會(huì)為測試執(zhí)行創(chuàng)建任何此類報(bào)告,而是以 XML 文件格式提供數(shù)據(jù)。你必須使用帶有 JUnit 的附加外部插件來創(chuàng)建報(bào)告。

TestNG 與 JUnit – 社區(qū)支持

TestNG 和 JUnit 都是各自社區(qū)中的流行框架。JUnit 是在 TestNG 之前引入的,這就是為什么它具有相對更廣泛和更強(qiáng)大的社區(qū)支持。TestNG 正在逐漸迎頭趕上,其用戶群也每天以更快的速度增長。

結(jié)論

許多測試框架都支持自動(dòng)化測試,具體取決于你的測試目標(biāo)是什么。TestNG 和 JUnit 是自動(dòng)化單元測試領(lǐng)域最受信任的框架之一。TestNG克服了JUnit的異常,減輕了測試人員的任務(wù)。使用 TestNG,可以執(zhí)行單元測試、集成測試和端到端測試,而 JUnit 僅涵蓋單元測試。TestNG 和 JUnit 之間有很多不同之處,但它們有很多共同之處。因此,迫切需要在單元測試上下文中討論 TestNG 與 JUnit。我們希望這項(xiàng)比較研究可以幫助您了解框架在單元測試中的作用,并幫助你選擇適合你的測試需求和業(yè)務(wù)需求的框架。


0 人點(diǎn)贊