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

Ruby on rails開發從頭來(windows)(二十)-測試model(CRUD)

編輯:關於JAVA

上篇隨筆簡單了解了rails的測試和測試用數據的使用,這次來看看怎樣對一個model進行添刪查改的測試。

1.還是使用上次寫的products_test.rb,修改test_turth方法的名字為test_create,並且使其內容為:

 def test_create
  assert_kind_of Product, @product
  assert_equal 1, @product.id
  assert_equal "Pragmatic Version Control", @product.title
  assert_equal "How to use version control", @product.description
  assert_equal "http://.../sk_svn_small.jpg", @product.image_url
  assert_equal 29.95,@product.price
  assert_equal "2005-01-26 00:00:00",
  @product.date_available_before_type_cast
 end

然後運行測試命令:depot>ruby test/unit/product_test.rb,屏幕上會顯示信息:

Loaded suite test/unit/product_test
Started
F
Finished in 0.109 seconds.1) Failure:
test_create(ProductTest) [test/unit/product_test.rb:16]:
<29> expected but was
<#<BigDecimal:4aad7b0,'0.2995E2',8(8)>>.1 tests, 6 assertions, 1 failures, 0 errors

我們看到,是assert_equal 29.95,@product.price斷言失敗了。根據《Agile Web Development with Rails》裡的內容,這句斷言應該是正常通過的。但是不知道是不是版本或環境的問題,我自己寫的時候總是不行。為了能夠使斷言通過,我們修改一下,把

assert_equal 29.95,@product.price

改為:assert_equal "29.95",@product.price_before_type_cast

我們看到了,product對象的每個屬性都有對應的_before_type_cast版本,其內容是一個字符串。

現在再次運行測試命令,得到的結果如下:

Loaded suite test/unit/product_test
Started
.Finished in 0.078 seconds.

1 tests, 7 assertions, 0 failures, 0 errors

從上面的測試中看到,我們在setup方法中,從數據庫中查找了id為1的記錄,然後在test_create方法中對其的屬性逐個判斷測試。

2.對創建和讀取的測試完成了,我們來進行對Update的測試,添加方法test_update,在這個方法裡我們要對price字段進行更新,並通過斷言判斷是否成功更新:

 def test_update
  assert_equal "29.95", @product.price_before_type_cast
  @product.price = 99.99
  assert @product.save, @product.errors.full_messages.join("; ")
  @product.reload
  assert_equal "99.99", @product.price_before_type_cast
 end

基於上面的test_create方法中對price測試的時候出現的問題,這裡我們在斷言裡還是使用price的before_type_cast版本。

再次運行測試命令,屏幕上的輸出如下:

Loaded suite test/unit/product_test
Started
..Finished in 0.078 seconds.

2 tests, 10 assertions, 0 failures, 0 errors

證明所有的斷言都成功了,現在到數據庫裡看看,id為1的product的price字段已經更新為99.99了。

3.最後我們來測試刪除,添加test_destroy方法,內容如下:

def test_destroy
  @product.destroy
  assert_raise(ActiveRecord::RecordNotFound) { Product.find(@product.id) }
 end

運行測試命令,屏幕上輸出如下:

Loaded suite test/unit/product_test
Started
..E
Finished in 0.078 seconds.1) Error:
test_update(ProductTest):
ActiveRecord::RecordNotFound: Couldn't find Product with ID=1
……

3 tests, 8 assertions, 0 failures, 1 errors

上面的測試裡,先刪除掉id為1的記錄,然後使用斷言,如果失敗,就拋出一個ActiveRecord::RecordNotFound的錯誤。

寫到這裡,從上面的信息裡顯示是test_update方法中顯示了異常信息,按照直覺,應該是test_destroy方法才對,這個問題現在自己也還沒有搞明白,還請rails高人指點。

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