日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
GolangWeb開發(fā)之Revel測試

Revel提供了一個(gè)測試框架,這使得在應(yīng)用程序中寫和運(yùn)行測試函數(shù)變得很容易.

專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)臨滄免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了數(shù)千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

skeleton應(yīng)用程序帶有一個(gè)簡單的測試來幫助我們測試.

概要

測試保存在tests目錄

 
 
 
 
  1. corp/myapp  
  2.     app/  
  3.     conf/  
  4.     public/  
  5.     tests/    <---- 

一個(gè)簡單的測試看起來像下面這樣:

 
 
 
 
  1. type ApplicationTest struct {  
  2.   rev.TestSuite  
  3. }  
  4.  
  5. func (t ApplicationTest) Before() {  
  6.     println("Set up")  
  7. }  
  8.  
  9. func (t ApplicationTest) TestThatIndexPageWorks() {  
  10.     t.Get("/")  
  11.     t.AssertOk()  
  12.     t.AssertContentType("text/html")  
  13. }  
  14.  
  15. func (t ApplicationTest) After() {  
  16.     println("Tear down")  

上面的示例代碼展示了幾件事:

  • 一個(gè)測試工具是任意嵌入rev.TestSuite的struct
  • 如果存在 Before() 和 After() 方法, 它們將在每一個(gè)測試方法的前后被調(diào)用
  • rev.TestSuite 為發(fā)布請求到應(yīng)用程序和斷言響應(yīng)信息提供幫助
  • 一個(gè)斷言失敗產(chǎn)生一個(gè)panic, 它將被harness捕獲

你可以已兩種方式運(yùn)行測試:

  • 交互式的, 從你的瀏覽器運(yùn)行在測試部署時(shí)很有幫助
  • 非交互式的, 從命令行運(yùn)行對結(jié)合一個(gè)持續(xù)集成很有幫助

開發(fā)一個(gè)測試工具

 創(chuàng)建一個(gè)你自己的測試工具, 定義一個(gè)嵌入 rev.Testsuite的struct, 它提供一個(gè)HTTP客戶端和許多幫助方法來發(fā)出請求到你的應(yīng)用程序.

 
 
 
 
  1. type TestSuite struct {  
  2.     Client       *http.Client  
  3.     Response     *http.Response  
  4.     ResponseBody []byte 
  5. }  
  6.  
  7. // Some request methods  
  8. func (t *TestSuite) Get(path string)  
  9. func (t *TestSuite) Post(path string, contentType string, reader io.Reader)   
  10. func (t *TestSuite) PostForm(path string, data url.Values)   
  11. func (t *TestSuite) MakeRequest(req *http.Request)  
  12.  
  13. // Some assertion methods  
  14. func (t *TestSuite) AssertOk()  
  15. func (t *TestSuite) AssertContentType(contentType string)  
  16. func (t *TestSuite) Assert(exp bool)  
  17. func (t *TestSuite) Assertf(exp bool, formatStr string, args ...interface{}) 

全部的請求方法表現(xiàn)相似:

  1. 它們接收一個(gè)路徑(例如: /users/)
  2. 它們發(fā)出請求到應(yīng)用程序服務(wù)器
  3. 它們把響應(yīng)存儲了Response屬性中
  4. 它們讀取全部的響應(yīng)body到ResponseBody屬性

如果開發(fā)人員希望使用自定義的HTTP Client代替默認(rèn)的 http.DefaultClient, 它們應(yīng)該在Before()方法里面替換它.

如果它們沒有滿足條件全部斷言都將產(chǎn)生一個(gè)panic. 全部的panic被測試harness捕獲并展示為錯(cuò)誤.

運(yùn)行一個(gè)測試工具

 為了運(yùn)行任何測試, testrunner模塊必須被激活. 添加下面一行代碼到 app.conf 以保證激活它

 
 
 
 
  1. module.testrunner = github.com/robfig/revel/modules/testrunner 

完成上面之后測試就被運(yùn)行了(交互式或非交互式)

運(yùn)行交互式的測試

利用Revel的熱編譯功能, 一個(gè)交互式的測試運(yùn)行器用來提供給快速編輯刷新的循環(huán)工作.

例如, 開發(fā)人員在他們的瀏覽器加載 /@tests

 然后他們添加一個(gè)測試方法

 
 
 
 
  1. func (t ApplicationTest) TestSomethingImportant() {  
  2.     t.Get("/")  
  3.     t.AssertOk()  
  4.     t.AssertContentType("text/xml")  
  5. }  
  6.  

刷新頁面將看到新的測試方法

運(yùn)行這個(gè)測試

它沒有正常工作. 我們來修復(fù)這個(gè)問題替換 “text/xml” 為 “text/html”, 刷新瀏覽器:

成功.

運(yùn)行非交互式的測試

Revel 命令行工具 提供了一個(gè) test 命令, 它運(yùn)行全部的應(yīng)用程序在命令行工具中運(yùn)行測試.

示例如下:

 
 
 
 
  1. $ revel test github.com/robfig/revel/samples/booking dev  
  2. ~  
  3. ~ revel! http://robfig.github.com/revel  
  4. ~  
  5. INFO  2012/11/09 19:21:02 revel.go:237: Loaded module testrunner  
  6. Open DB  
  7. Listening on port 9000...  
  8. INFO  2012/11/09 19:21:06 test.go:95: Testing Booking example (github.com/robfig/revel/samples/booking) in dev mode  
  9. Go to /@tests to run the tests.  
  10.  test suite to run.  
  11.  
  12. ApplicationTest         PASSED        0s  
  13.  
  14. All Tests Passed. 

在控制臺只有一個(gè)簡單的 PASSED/FAILED 概要通過測試工具來顯示. 這個(gè)工具寫入更多的結(jié)果到文件系統(tǒng):

 
 
 
 
  1. $ cd src/github.com/robfig/revel/samples/booking  
  2. $ find test-results  
  3. test-results  
  4. test-results/app.log  
  5. test-results/ApplicationTest.passed.html  
  6. test-results/result.passed 

它寫入了3個(gè)不同的東西:

  1. 應(yīng)用程序的stdout和stderr被重定向到 app.log
  2. 一個(gè)HTML文件每個(gè)測試工具都寫入描述測試的通過和失敗的信息
  3. 要么result.passed要么result.failed被寫入, 依賴于總體是否成功

這里有兩個(gè)集成這個(gè)到持續(xù)構(gòu)建的建議機(jī)制

  1. 檢查返回代碼, 0表示成功非0另外
  2. 運(yùn)行后需要result.success或者不允許result.failed.

實(shí)現(xiàn)說明

Revel做了什么:

  • 為嵌套TestSuite類型掃描測試源代碼
  • 在生成main.go時(shí)設(shè)置rev.TestSuites變量到那些類型的列表
  • 使用反射在TestSuite類型上查找全部的以Test開頭的方法并調(diào)用它們來運(yùn)行測試
  • 從bugs或失敗的斷言中捕獲panics并顯示有幫助的錯(cuò)誤信息

開發(fā)區(qū)域

可以使用以下方式改進(jìn)測試框架

  • Fixtures來填充測試數(shù)據(jù)
  • 記錄器寫入一個(gè)文件(替換 stderr / stdout )也應(yīng)該被重定向到 test-results/app.log

至此結(jié)束

原文鏈接:http://www.cnblogs.com/ztiandan/archive/2013/01/09/2846073.html


當(dāng)前文章:GolangWeb開發(fā)之Revel測試
標(biāo)題路徑:http://www.dlmjj.cn/article/cogojic.html