Ruby on Rails調(diào)試經(jīng)驗(yàn)分享
Ruby on Rails作為一款非常實(shí)用的WEB開(kāi)發(fā)框架幫助我們實(shí)現(xiàn)了快速方便的編寫代碼的需求。下面就為大家介紹一下關(guān)于Ruby on Rails調(diào)試的一些經(jīng)驗(yàn)之談。#t#
首先,而且也是最重要的就是,編寫測(cè)試代碼,在Rails里編寫單元測(cè)試和功能測(cè)試都很簡(jiǎn)單,使用它們,可以減低bug發(fā)生率,也可以避免在你從前的代碼中突然出現(xiàn)bug。
測(cè)試代碼告訴你哪些東西能夠工作,哪些不能,并且,測(cè)試代碼幫助你隔離那些有問(wèn)題的代碼,因?yàn)橛袝r(shí)候bug并非很快地表現(xiàn)出來(lái)。
如果Ruby on Rails調(diào)試問(wèn)題發(fā)生在一個(gè)Model中,我們可以使用腳本script/console來(lái)模擬一個(gè)irb對(duì)話,在其中進(jìn)行跟蹤,例如下面這樣:
- Z:studyrubyInstantRailsrails_appsdepot>
ruby script/console- Loading development environment.
- >> pr = Product.find(:first)
- => #<Product:0x4b969ec @attributes=
{"image_url"=>"http://www.dearbook.com.- >> pr.price
- => #<BigDecimal:4b913d4,'0.12351E3',8(12)>
- >> pr.image_url
- => "http://www.dearbook.com.cn/book/
BookImage/67/lastTS00168921__.jpg"- >> pr.save
- => true
- >>
我們先在depot項(xiàng)目的命令行中使用ruby script/console來(lái)啟動(dòng)irb會(huì)話,藍(lán)色的部分是我在irb會(huì)話中輸入的命令。
另外,在復(fù)雜的程序中使用Log也是一個(gè)好辦法,你可以在log文件中找到大量有價(jià)值的信息,當(dāng)一些意外情況發(fā)生,Log文件應(yīng)該是你第一個(gè)要檢查的地方。還有,檢查服務(wù)器的log文件也是很有用的,如果你使用WEBrick作為web服務(wù)器,也可以使用腳本script/server來(lái)啟動(dòng)一個(gè)會(huì)話。
我們可以使用Logger對(duì)象來(lái)輸出我們想查看的信息,有時(shí)候log文件非常繁忙,以至于很難找到你所添加的log,如果你使用WEBrick,你可以使用STDERR來(lái)將你的log輸出到控制臺(tái)上(InstantRails使用的Mongrel不能進(jìn)入命令行)。
如果一個(gè)頁(yè)面顯示了錯(cuò)誤的內(nèi)容,我們也許想導(dǎo)出控制器中的對(duì)象,方法debug()能幫助我們,該Ruby on Rails調(diào)試方法很好的格式化對(duì)象的內(nèi)容,并且判斷對(duì)象的內(nèi)容是不是合法的HTML,例如:
- <h3>Your Order</h3>
- <%= debug(@order) %>
- <div id="ordersummary">
- . . .
- </div>
最后,在上面的Ruby on Rails調(diào)試方法都不能排除bug的時(shí)候,我們來(lái)嘗試跟蹤調(diào)試程序,但是只限于環(huán)境配置為development的程序,下面是使用斷點(diǎn)(breakpoint)的步驟:
1. 在你需要程序停下來(lái)的地方添加breakpoint()方法的調(diào)用。
2. 在項(xiàng)目的根目錄鍵入命令:depot>ruby script/breakpointer。
打開(kāi)瀏覽器,使你的程序能夠命中調(diào)用breakpoint方法的代碼,這時(shí)候?yàn)g覽器會(huì)停止響應(yīng),在命令行窗口會(huì)打開(kāi)irb會(huì)話,在這里,你可以查看變量的值,或者添加斷點(diǎn),當(dāng)你推出irb會(huì)話,在瀏覽器里,程序就會(huì)繼續(xù)運(yùn)行。