1. 程式人生 > >Ruby on rails開發從頭來(windows)(三十六)- 除錯技巧

Ruby on rails開發從頭來(windows)(三十六)- 除錯技巧

這次我們來看看一些關於除錯的小提示。

首先,而且也是最重要的就是,編寫測試程式碼,在Rails裡編寫單元測試和功能測試都很簡單,使用它們,可以減低bug發生率,也可以避免在你從前的程式碼中突然出現bug。
測試程式碼告訴你哪些東西能夠工作,哪些不能,並且,測試程式碼幫助你隔離那些有問題的程式碼,因為有時候bug並非很快地表現出來。
如果問題發生在一個Model中,我們可以使用指令碼script/console來模擬一個irb對話,在其中進行跟蹤,例如下面這樣:

Z:\study\ruby\InstantRails\rails_apps\depot>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專案的命令列中使用ruby script/console來啟動irb會話,藍色的部分是我在irb會話中輸入的命令。

另外,在複雜的程式中使用Log也是一個好辦法,你可以在log檔案中找到大量有價值的資訊,當一些意外情況發生,Log檔案應該是你第一個要檢查的地方。還有,檢查伺服器的log檔案也是很有用的,如果你使用WEBrick作為web伺服器,也可以使用指令碼script/server來啟動一個會話。

我們可以使用Logger物件來輸出我們想檢視的資訊,有時候log檔案非常繁忙,以至於很難找到你所新增的log,如果你使用WEBrick,你可以使用STDERR來將你的log輸出到控制檯上(InstantRails使用的Mongrel不能進入命令列)。

如果一個頁面顯示了錯誤的內容,我們也許想匯出控制器中的物件,方法debug()能幫助我們,該方法很好的格式化物件的內容,並且判斷物件的內容是不是合法的HTML,例如:

<h3>Your Order</h3>

<%= debug(@order) %>

<div id="ordersummary">

. . .

</div>

最後,在上面的方法都不能排除bug的時候,我們來嘗試跟蹤除錯程式,但是隻限於環境配置為development的程式,下面是使用斷點(breakpoint)的步驟:

1.       在你需要程式停下來的地方新增breakpoint()方法的呼叫。

2.       在專案的根目錄鍵入命令:depot>ruby script/breakpointer。

開啟瀏覽器,使你的程式能夠命中呼叫breakpoint方法的程式碼,這時候瀏覽器會停止響應,在命令列視窗會開啟irb會話,在這裡,你可以檢視變數的值,或者新增斷點,當你推出irb會話,在瀏覽器裡,程式就會繼續執行。