stone2083

          單元測試下簡易性能測試工具

          背景:
          1.團隊成員對質量意識逐漸提升;單元測試意識提升;
          2.性能意識不足,往往到最后提交性能測試的時候,才發現性能問題;在開發階段忽視對性能的考慮.
          尤其在做對外服務的需求中,危害特別明顯.

          基于這兩個原因,希望有一個在單元測試下的性能測試工具.提供最簡單的性能指標報表.在開發階段讓開發對性能情況有個感性的認識.

          設計思路:


          概念說明:
           類名 方法
          說明
          Statistics 
          說明:性能統計信息
          tps() 提供tps
            average() 提供平均響應時間,單位毫秒
            total() 提供總耗時,單位毫秒
          Job 
          說明:測試單元邏輯
          execute() 性能測試邏輯
          Warn 
          說明:性能未達標警告


          PerformanceTester (核心)
          說明:性能測試工具,根據制定的并發數和單個并發循環次數,進行性能測試;根據提供的平均響應時間,分析是否達標
          test(Job job) 性能測試,打印性能報表,分析是否達標
          JTesterxPerformance 
          說明:基于JTester的性能測試基類,統一執行性能測試計劃
          備注:
          JTester是我們公司同事編寫的一套單元測試框架.我們同樣可以提供基于JUnit的實現,比如JUnitPerformance
          performance() 根據提供的性能策略,指標 和 測試邏輯,進行性能測試

          job() 需要子類覆寫,提供測試邏輯

          testers() 需要子類覆寫,提供性能測試策略和指標要求


          User Guide:
          • Step1:
              創建一個性能測試類,繼承com.alibaba.tpsc.common.test.jtesterx.JTesterxPerformance
              在類名標注@Test (org.testng.annotations.Test),表明需要進行TestNG的單元測試
              備注:如果是在其他單元測試框架下,請自行擴展類似JUnitPerformacne實現
          • Step2:
              覆寫public Job job()方法.提供 性能測試名 和 性能測試邏輯
               

          @Override
          public Job job() {
              
          return new Job("SampleService.hello") {
                  @Override
                  
          public void execute() {
                      SampleService.hello();
                  }
              };
          }
          • Step3:
              覆寫public Collection<PerformanceTester> testers().提供一組性能測試策略(并發數,單個并發循環次數) 和 性  能測試指標(平均響應時間)
              性能測試工具會根據提供策略和指標,依次進行性能測試.
          public Collection<PerformanceTester> testers() {
              Collection
          <PerformanceTester> testers = new ArrayList<PerformanceTester>();
              
          // 20個并發,單個并發循環1000次,平均響應時間閥值10ms
              testers.add(new PerformanceTester(20100010));
              
          // 10個并發,單個并發循環1000次,平均響應時間閥值5ms
              testers.add(new PerformanceTester(1010005));
              
          return testers;
          }
          • Step4:
              右鍵點擊Eclipse->Run As->TestNG Test.
              如果測試通過,則顯示Green Bar
              如果測試未通過,則在Red Bar中顯示:java.lang.AssertionError: performance expected is 1ms,but actual is 2.938ms.


          工具代碼和演示代碼如下:
          Demo下載

          posted on 2010-06-10 09:13 stone2083 閱讀(2498) 評論(4)  編輯  收藏 所屬分類: java

          Feedback

          # re: 單元測試下簡易性能測試工具 2010-06-10 09:51 BeanSoft

          支持下 大規模應用的性能就是從微秒開始奠定的  回復  更多評論   

          # re: 單元測試下簡易性能測試工具 2010-06-11 08:51 stone2083

          @BeanSoft
          接受觀點.
          之所以考慮使用毫秒,是因為不同的開發機性能參差不齊,對性能的影響遠遠大于本身計算的精確性.
          而這個簡易工具,本意只是提供感性的性能數據.所以提供的數據并不精確(當然,之后會隨著項目開發中提出的需求做完善),而是相對于程序員更友好的單位.  回復  更多評論   

          # re: 單元測試下簡易性能測試工具[未登錄] 2010-06-21 16:06 TestThug

          不知道JTester可否開源??  回復  更多評論   

          # re: 單元測試下簡易性能測試工具 2010-06-21 19:10 stone2083

          @TestThug
          1.要看公司政策了;
          2.要看JTester作者意愿了;

          從目前看,開源的可能并不大 :(  回復  更多評論   

          主站蜘蛛池模板: 阿合奇县| 建水县| 宁晋县| 千阳县| 尖扎县| 靖远县| 固阳县| 酉阳| 青川县| 大兴区| 汝州市| 富川| 海门市| 祁东县| 五峰| 通榆县| 庆云县| 兖州市| 来凤县| 乌兰县| 高雄市| 资讯 | 台州市| 安泽县| 开化县| 阿拉善右旗| 奉节县| 德安县| 松江区| 宣城市| 南京市| 外汇| 平和县| 武山县| 天长市| 辽中县| 茌平县| 玛沁县| 绍兴县| 会理县| 高阳县|