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作者意愿了;

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

          主站蜘蛛池模板: 慈利县| 徐州市| 方城县| 纳雍县| 沂源县| 文昌市| 龙海市| 赤城县| 通城县| 启东市| 扎鲁特旗| 乌兰察布市| 平遥县| 图片| 长泰县| 成都市| 应用必备| 射阳县| 隆昌县| 平顺县| 许昌县| 米易县| 荔波县| 宁强县| 富裕县| 彩票| 孙吴县| 三门峡市| 庐江县| 无棣县| 商都县| 肇源县| 井陉县| 水城县| 德保县| 岫岩| 沙湾县| 漯河市| 措美县| 长兴县| 四川省|