您的位置:軟件測(cè)試 > 開(kāi)源軟件測(cè)試 > 開(kāi)源單元測(cè)試工具 > junit
JUnit擴(kuò)展:引入新注解Annotation
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時(shí)間:[ 2015/4/17 10:48:13 ] 推薦標(biāo)簽:Junit 單元測(cè)試 Annotation

  這樣可以通過(guò)BlockJunit4ClassRunner直接調(diào)用:
public class EntryToRunCases
{
public static void main(String... args)
{
if(args != null)
{
System.out.println("Parameters: " + args[0]);
Filter customeFilter = new FilterCollections(args[0]);
EntryToRunCases instance = new EntryToRunCases();
instance.runTestCases(customeFilter);
}
else
{
System.out.println("No parameters were input!");
}
}
protected void runTestCases(Filter aFilter)
{
BlockJUnit4ClassRunner aRunner = null;
try
{
try
{
aRunner = new BlockJUnit4ClassRunner(JunitTest.class);
}
catch(InitializationError e)
{
System.out.print(e.getMessage());
}
aRunner.filter(aFilter);
aRunner.run(new RunNotifier());
}
catch(NoTestsRemainException e)
{
System.out.print(e.getMessage());
}
}
}
  這種方法要比上面IBM的實(shí)現(xiàn),簡(jiǎn)單很多,不需要包裝一些不必要的類(lèi)了。
  但是我們?nèi)匀话l(fā)現(xiàn)它還有兩個(gè)不方便的地方:
  要想跑哪些測(cè)試文件,必須把相應(yīng)的測(cè)試Class,一條條加進(jìn)來(lái),這是JUnit固有的缺陷,Categories是解決這個(gè)問(wèn)題,但是它不識(shí)別我們自定義的注解
  Case是通過(guò)Java Application Main方法來(lái)發(fā)起運(yùn)行的,Eclipse IDE 的Junit 插件并不識(shí)別這種用法,所有我們沒(méi)法在Eclipse的Junit窗口查看結(jié)果,只能通過(guò)Console打印出書(shū)出結(jié)果,這樣可讀性差了很多
  優(yōu)化,更佳的解決方法
  第一個(gè)問(wèn)題很好解決,我們只要自己寫(xiě)方法來(lái)查找項(xiàng)目下的所有.java文件,匹配包含org.junit.Test.class注解的測(cè)試類(lèi)可以了,那第二個(gè)問(wèn)題呢?
  仔細(xì)思考我們的需求,我們會(huì)發(fā)現(xiàn),我們并不想改變JUnit的Case執(zhí)行能力,我們期望的只是希望JUnit能夠只運(yùn)行我們希望讓它跑的Case. 而JUnit的Categories實(shí)現(xiàn)的是這種功能。Categories繼承自Suite類(lèi),我們看他的構(gòu)造函數(shù):
  public Categories(Class<?> klass, RunnerBuilder builder)
  throws InitializationError {
  super(klass, builder);
  try {
  filter(new CategoryFilter(getIncludedCategory(klass),
  getExcludedCategory(klass)));
  } catch (NoTestsRemainException e) {
  throw new InitializationError(e);
  }
  assertNoCategorizedDescendentsOfUncategorizeableParents(getDescription());
  }
  實(shí)際上是把自定義的CategoryFilter傳遞給ParentRunner的filter方法,跟上面的方式,異曲同工。
  Categories不識(shí)別我們的注解,那么我們是不是可以仿照它,做自己的Categories類(lèi)呢?如下:
  1。 首先定義使用自定義Categories的參數(shù):
  @Retention(RetentionPolicy.RUNTIME)
  public @interface IncludeSprint
  {
  String value();
  /*
  * This annotation will determine whether we want to run case without Sprint annotation or not
  * If not set, it is false by default
  */
  boolean isOnly() default false;
  }
  @Retention(RetentionPolicy.RUNTIME)
  public @interface IncludeUserStory
  {
  String value();
  }
  @Retention(RetentionPolicy.RUNTIME)
  public @interface IncludeDefect
  {
  String value();
  }
  2。然后可以在構(gòu)造函數(shù)里針對(duì)它做處理:
  /**
  * Used by JUnit
  */
  public AnnotationClasspathSuite(Class<?> suiteClass, RunnerBuilder builder) throws InitializationError
  {
  super(builder, suiteClass, getTestclasses(new ClasspathClassesFinder(getClasspathProperty(suiteClass), new ClassChecker(
  getSuiteType(suiteClass))).find()));
  try
  {
  filter(new AnnotationsFilter(getIncludedSprint(suiteClass), getIncludedUserStory(suiteClass), getIncludedDefect(suiteClass),
  IsOnlyRunCaseWithSprintAnnotation(suiteClass)));
  }
  catch(NoTestsRemainException e)
  {
  throw new InitializationError(e);
  }
  assertNoCategorizedDescendentsOfUncategorizeableParents(getDescription());
  }
  這樣做出的自定義Suite Runner在使用上非常方便了,比如:
  @RunWith(AnnotationClasspathSuite.class)
  @IncludeSprint(value = "15.3", isOnly = true)
  public class TestRunner
  {
  }
  這樣可以明確的表明,我們只想跑Spring15.3的Case。并且結(jié)果也能在Eclipse IDE里完美展示:
  總結(jié)
  通過(guò)上面的實(shí)現(xiàn),我們能更細(xì)粒度的規(guī)劃我們的case,也能按需靈活的運(yùn)行自動(dòng)化測(cè)試用例。

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