testng源码阅读之二

本文介绍了TestNG执行的核心类及其工作机制。主要关注xxxWorker和xxxRunner,它们分别负责执行上下文和实际执行。TestNG的执行分为suite和@Test两个层次。在单线程执行中,通过获取freenodes并递归执行testMethods来完成任务。此外,文章提到了动态节点图的构建以及group-by-instance和dependency的区别,并预告了对privateRun()详细流程的后续探讨。
摘要由CSDN通过智能技术生成

最近一直没有时间写博客。在做一个相当于外包的项目。因为项目终于卖出去了,忽悠到人用了。而且最近释放了一个资源。
最近一直忙于测试。

testng执行核心的几个类:
这里写图片描述

xxxWorker、xxxRunner是配套的。runner的类,定义执行的上下文。Worker就是实际的执行器。

testng定义了两个层次的执行。一层是suite这个层面的。一层是每个@Test层面的。从图中可以看到。其中,testRunner,实际是跟testMethodWorker配套使用的。

我们来看一下最底层的testRunner的privateRun()

private void privateRun(XmlTest xmlTest) {
    String parallelMode = xmlTest.getParallel();
    boolean parallel = XmlSuite.PARALLEL_METHODS.equals(parallelMode)
        || "true".equalsIgnoreCase(parallelMode)
        || XmlSuite.PARALLEL_CLASSES.equals(parallelMode)
        || XmlSuite.PARALLEL_INSTANCES.equals(parallelMode);

    {
      // parallel
      int threadCount = parallel ? xmlTest.getThreadCount() : 1;
      // Make sure we create a graph based on the intercepted methods, otherwise an interceptor
      // removing methods would cause the graph never to terminate (because it would expect
      // termination from methods that never get invoked).
      DynamicGraph<ITestNGMethod> graph = createDynamicGraph(intercept(m_allTestMethods));
      if (parallel) {
        if (graph.getNodeCount() > 0) {
          GraphThreadPoolExecutor<ITestNGMethod> executor =
              new GraphThreadPoolExecutor<ITestNGMethod>(graph, this,
                  threadCount, threadCount, 0, TimeUnit.MILLISECONDS,
                  new LinkedBlockingQueue<Runnable>());
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值