程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Ruby on rails開發從頭來(windows)(三十六)- 調試技巧

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

編輯:關於JAVA

這次我們來看看一些關於調試的小提示。

首先,而且也是最重要的就是,編寫測試代碼,在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會話,在浏覽器裡,程序就會繼續運行。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved