成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

全方位解讀Ruby on Rails性能測(cè)試技巧

開發(fā) 開發(fā)工具
Ruby on Rails性能測(cè)試首先需要模仿大量的數(shù)據(jù),才能真正掌握測(cè)試數(shù)據(jù)的真實(shí)性。在這篇文章中我們會(huì)對(duì)此做一個(gè)詳細(xì)的介紹。

Ruby on Rails是一個(gè)非常實(shí)用WEB開發(fā)框架。不過(guò)它的性能到底如何呢?這需要我們進(jìn)行詳細(xì)的測(cè)試。那么如何進(jìn)行Ruby on Rails性能測(cè)試呢?#t#

Ruby on Rails性能測(cè)試1.  要進(jìn)行Ruby on Rails性能測(cè)試,我們首先要模仿大量的數(shù)據(jù),我們現(xiàn)在知道,在test/fixtures/目錄下的yml文件里添加我們的測(cè)試數(shù)據(jù),在運(yùn)行測(cè)試時(shí),這些數(shù)據(jù)會(huì)被加載到數(shù)據(jù)庫(kù)。但是一條兩條數(shù)據(jù)還可以,數(shù)據(jù)多的情況下,一條一條在yml文件里寫可不行,所以,我們先看看怎樣在yml文件里造大量的數(shù)據(jù)。在fixtrue目錄下創(chuàng)建一個(gè)子目錄performance,在里面新建order.yml文件,把內(nèi)容改成下面的樣子:

 

  1. # Read about fixtures at 
    http://ar.rubyonrails.org/
    classes/Fixtures.html  
  2. <% for i in 1..100 %> 
  3. order_<%= i %>:  
  4. id: <%= i %> 
  5. name: Fred  
  6. email: fred@flintstones.com  
  7. address: 123 Rockpile Circle  
  8. pay_type: check  
  9. <% end %> 

 

然后再運(yùn)行我們一個(gè)空測(cè)試,order_test.rb

depot>ruby test/unit/order_test.rb

到數(shù)據(jù)庫(kù)里查看下表order,里面已經(jīng)初始化了100條記錄了。我們之所以要新建一個(gè)performance目錄,是因?yàn)槲覀儾幌脒\(yùn)行每個(gè)測(cè)試都要初始化100條記錄,我們之前在測(cè)試model和controller的時(shí)候用的那個(gè)order.yml文件中的記錄就夠了。

Ruby on Rails性能測(cè)試2.  在test目錄下也創(chuàng)建一個(gè)performance目錄,然后創(chuàng)建一個(gè)order_test.rb文件,內(nèi)容如下:

 

  1. require File.dirname(__FILE__)
     + '/../test_helper'  
  2. require 'store_controller'  
  3. class OrderTest < Test::Unit::TestCase 
  4. fixtures :products  
  5. HOW_MANY = 100 
  6. def setup  
  7. @controller = StoreController.new  
  8. @request = ActionController:
    :TestRequest.new  
  9. @response = ActionController
    ::TestResponse.new  
  10. get :add_to_cart, :id => 1  
  11. end  
  12. def teardown  
  13. Order.delete_all  
  14. end  
  15. def test_save_bulk_orders  
  16. elapsedSeconds = Benchmark::realtime do  
  17. Fixtures.create_fixtures
    (File.dirname(__FILE__) +  
  18. "/../fixtures/performance", "orders")  
  19. assert_equal(HOW_MANY, Order.find_all.size)  
  20. 1.upto(HOW_MANY) do |id|  
  21. order = Order.find(id)  
  22. get :save_order, :order => order.attributes  
  23. assert_redirected_to :action => 'index'  
  24. assert_equal("Thank you for your
     order.", flash[:notice])  
  25. end  
  26. end  
  27. assert elapsedSeconds < 3.0
    "Actually took #{elapsedSeconds} seconds"  
  28. end  
  29. end 

在這里,我們沒(méi)有直接加載100個(gè)order,而是在test_save_bulk_orders方法中,先使用elapsedSeconds = Benchmark::realtime來(lái)計(jì)算測(cè)試花費(fèi)的時(shí)間,再通過(guò)調(diào)用create_fixtures方法指定我們要加載order的yml文件,然后對(duì)每條加載的order,進(jìn)行保存,在通過(guò)斷言判斷是否調(diào)用了index的Action,和Flash中的內(nèi)容。***再判斷elapsedSeconds是否小于3秒。

還有一點(diǎn)要注意,這里實(shí)際上對(duì)每個(gè)order進(jìn)行了兩次Save操作,一次是在加載yml文件的時(shí)候,一次是我們調(diào)用save_order的時(shí)候。

Ruby on Rails性能測(cè)試3.  如果我們不想在每個(gè)測(cè)試運(yùn)行的時(shí)候都從yml文件里加載數(shù)據(jù),那么我們可以通過(guò)self.use_transactional_fixtures來(lái)控制。例如:

 

  1. class OrderTest 

    < Test::Unit::TestCase 
  2.  fixtures :products  
  3.  self.use_transactional
    _fixtures = true  
  4.  HOW_MANY = 100 
  5.  ……  
  6. end  

 

Ruby on Rails性能測(cè)試4.  如果我們想知道某個(gè)方法或某句代碼所花費(fèi)的時(shí)間,可以通過(guò)rails的腳本script/profiler and script/benchmarker來(lái)查看,例如,我們注意到Product這個(gè)Model的search方法比較慢,為了避免盲目地進(jìn)行優(yōu)化,我們使用Profiler來(lái)告訴我們每句代碼使用了多少時(shí)間,例如:

depot>ruby script/performance/profiler "Product.salable_items"

注意這里的script的路徑,我在instantrails里的和書上的不一致,如果提示腳本找不到,那就在自己的本地目錄找找看profiler文件放在什么地方。

Ruby on Rails性能測(cè)試5.  我們還可以使用benchmarker來(lái)比較兩個(gè)方法所消耗的時(shí)間,例如:

ruby script/performance/benchmarker 10 "Product.salable_items" "Order.count_pending"

輸出結(jié)果是:

user system totalreal
#1 0.078000  0.000000  0.078000 ( 0.078000)
#2 0.000000  0.000000  0.000000 ( 0.016000)

在這里,書上寫的是兩個(gè)方法之間用“”來(lái)分割,在我的機(jī)器上是使用一個(gè)空格來(lái)分割。

責(zé)任編輯:曹凱 來(lái)源: 新客網(wǎng)
相關(guān)推薦

2009-12-15 10:10:42

Ruby過(guò)程對(duì)象

2009-12-15 10:48:54

Ruby局部變量

2009-12-14 17:04:13

Ruby讀寫UNIX命

2009-12-14 15:30:43

安裝Ruby on R

2010-09-25 14:39:29

Bruce Tate

2010-01-04 14:06:35

Silverlight

2015-10-14 17:27:18

性能

2015-10-10 11:00:05

RubyRails性能

2009-12-16 09:29:26

Ruby布爾表達(dá)式

2009-12-17 17:37:42

Ruby on Rai

2024-04-08 11:52:08

PromQL技術(shù)監(jiān)控

2009-12-09 13:32:08

PHP zend安裝

2014-06-26 17:25:22

車聯(lián)網(wǎng) ECU

2011-10-26 09:28:28

紅帽大數(shù)據(jù)Gluster

2010-01-27 13:52:15

Android多媒體框

2009-12-21 13:06:05

WCF Address

2009-12-15 17:28:11

Ruby自動(dòng)化腳本框架

2009-12-16 15:23:33

Ruby on rai

2010-07-12 09:22:05

RubyRuby on rai

2010-03-17 09:22:06

FlashSilverlight
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲福利网 | 男女羞羞免费视频 | 99精品视频一区二区三区 | 欧美性区 | 成人在线视频免费看 | 午夜精品久久久久久久久久久久久 | 成人久久久 | 狠狠干av| 天天干狠狠干 | 婷婷色综合| 精品成人在线 | 亚洲精品2区 | 国产伦精品一区二区三毛 | 国内自拍偷拍视频 | 日韩精品免费视频 | 亚洲狠狠 | 国产精品成人一区二区三区夜夜夜 | 欧美一区二区在线 | 久久1区| 精品久久久久久亚洲精品 | a级免费黄色片 | 亚洲成人免费av | 亚洲每日更新 | 中文字幕国产视频 | 成人午夜激情 | 精彩视频一区二区三区 | 欧美日韩中文国产一区发布 | 激情六月丁香 | 九九久久精品 | 免费a国产 | 在线观看亚洲精品视频 | 成年无码av片在线 | 久久久精品一区二区三区 | 亚洲国产激情 | 欧美男人天堂 | 91精品国产91久久久久游泳池 | 欧美一区二区大片 | 久久久女| 欧美性一级 | 欧美精品久久久久 | 国产激情免费视频 |