欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django單元測試工具test client使用詳解

 更新時間:2019年08月02日 09:09:32   作者:再見紫羅蘭  
這篇文章主要介紹了Django單元測試工具test client使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

The test client
test client是一個python類,來模擬一個簡單的“啞”瀏覽器,允許你來測試你的view函數(shù).你可以使用test client完成下列事情:

1.模擬"Get"和"Post"請求,觀察響應結(jié)果--從HTTP(headers,status codes)到頁面內(nèi)容.
2.檢查重定向鏈(如果有的話),在每一步檢查URL和status code。
3.用一個包括特定值的模板context來測試一個request被Django模板渲染。

>>> from django.test.client import Client
>>> c = Client()
>>> response = c.post('/login/', {'username': 'john', 'password': 'smith'})
>>> response.status_code
200
>>> response = c.get('/customer/details/')
>>> response.content
'<!DOCTYPE html...'

使用django.test.client.Client的實例來使用test client。

注意:請求網(wǎng)頁時,使用path而不是整個domain。

>>> c.get('/login/')

是正確的。

>>> c.get('http://www.example.com/login/')

是錯誤的。

test client不適合操作不是由Django建立的網(wǎng)站.所以,請求其它網(wǎng)頁時,請使用python的標準庫--urllib或者urllib2.

為了解析URl,test client使用由ROOT_URLCONF(settings.py)指定的URLconf。

默認情況下,test client會忽略CSRF檢查,如果要強制進行CSRF檢查,可以

csrf_client = Client(enforce_csrf_checks=True)

Making Requests

使用django.test.client.Client()來執(zhí)行請求。

class Client(enforce_csrf_checks=False, **defaults)

可以使用關(guān)鍵字參數(shù)來指定默認的請求報頭:

c = Client(HTTP_USER_AGENT='Mozilla/5.0')

記得在USER_AGENT前加HTTP_。

Client實例具有以下方法:

get(path, data={}, follow=False, **extra)

執(zhí)行一個GET請求并返回Response對象。

>>> c = Client()
>>> c.get('/customers/details/', {'name': 'fred', 'age': 7})

相當于向以下url執(zhí)行GET:

/customers/details/?name=fred&age=7

extra關(guān)鍵字參數(shù)可用作請求報頭:

>>> c = Client()
>>> c.get('/customers/details/', {'name': 'fred', 'age': 7},
...    HTTP_X_REQUESTED_WITH='XMLHttpRequest')

當然也可以將查詢字符對編碼后加入url:

>>> c = Client()
>>> c.get('/customers/details/?name=fred&age=7')

data參數(shù)的優(yōu)先級在編碼后的url之上。

如果將follow設(shè)置為True,client會追蹤任何重定向,返回的response有redirect_chain屬性,包括所有重定向過程中的url和狀態(tài)碼組成的元祖列表。

如果有個URL /redirect_me/ 重定向向 /next/, 再重定向向 /final/:

>>> response = c.get('/redirect_me/', follow=True)
>>> response.redirect_chain
[(u'http://testserver/next/', 302), (u'http://testserver/final/', 302)]

post(path, data={}, content_type=MULTIPART_CONTENT, follow=False, **extra)

執(zhí)行一個POST請求并返回response對象,data參數(shù)為POST數(shù)據(jù)。

如果提供content_type參數(shù)(例如 text/xml),數(shù)據(jù)會被作為報頭中Content-Type的類型進行POST上傳。

如果不提供content_type參數(shù),數(shù)據(jù)會被作為multipart/form-data類型上傳。

為一個參數(shù)提交多個多個值時--比如選住<select multiple>域的多個值--這些值可以是列表或者元組.舉例來說,提交choice域的三個被選中的值:

{'choices': ('a', 'b', 'd')}

上傳文件:

>>> c = Client()
>>> with open('wishlist.doc') as fp:
...   c.post('/customers/wishes/', {'name': 'fred', 'attachment': fp})

文件的名字'attachment'是不相關(guān)的,取決于你處理文件的代碼。

如果同一個文件要post多次,注意每次post都要恢復文件的指針,最簡單的方法就是將文件關(guān)閉再重新打開。

注意文件要以正確的方式被打開以便于讀取,如果文件是binary data,例如讀取img時,要將打開模式設(shè)為rb。

post的路徑中也可以包含查詢字符對:

>>> c.post('/login/?visitor=true', {'name': 'fred', 'passwd': 'secret'})

這樣既會通過post上傳data數(shù)據(jù),也向GET確定visitor=True。

options(path, data='', content_type='application/octet-stream', follow=False, **extra)

做OPTIONS請求,對測試REST接口很有用。data被用作請求的主體。

put(path, data='', content_type='application/octet-stream', follow=False, **extra)

做PUT請求,測試RESTful接口。

patch(path, data='', content_type='application/octet-stream', follow=False, **extra)

做PATCH請求,測試RESTful接口。

delete(path, data='', content_type='application/octet-stream', follow=False, **extra)

做DELETE請求,測試RESTful接口。

login(**credentials)

如果使用django的用戶驗證系統(tǒng),可用login方法進行測試。

>>> c = Client()
>>> c.login(username='fred', password='secret')

登陸成功的話,返回True。

使用之前,當然要創(chuàng)建一個用戶。由于測試數(shù)據(jù)庫使用的是單獨的數(shù)據(jù)庫,原先數(shù)據(jù)庫中的用戶是不能用于測試的。

設(shè)置密碼時,不能用user的密碼屬性進行設(shè)置,而是用set_password()方法設(shè)置正確的哈希密碼,或者使用create_user()方法創(chuàng)建一個帶哈希密碼的用戶。

logout()

登出。

Testing Responses

client的get和post方法都返回response對象,和HttpResponse對象是不同的。

class Response具有以下屬性:

client:the test client

content:response的主體,string類型,是view render后的頁面的最終內(nèi)容,或者是錯誤信息。

context:用來渲染模板的context實例。如果頁面使用了多個模板,那context就會是Context Object列表.它們的排序方式就是它們被渲染的順序。

>>> response = client.get('/foo/')
>>> response.context['name']
'Arthur'

request:用于請求的數(shù)據(jù)。

status_code:狀態(tài)碼。

templates:被用來渲染最終的content的Template實例列表.template.name可以得到template的文件名,如果template是由文件載入的話(如 'admin/index.html')。那template就會是Template列表,它們的排序方式就是它們被渲染的順序.

response也可以當做字典來查詢Http header:

response['Content-Type']

Exceptions

如果你將TestClient指向了由view函數(shù)raise的異常,那這個異常在test case里是可見的.你可以使用標準的try...except塊或者assertRaises()來測試它們.對test client唯一不可見的異常是Http404,PermissionDenied和SystemExit。django會在內(nèi)部捕捉這些異常并返回合適的response.這種情況下,你可以查看下你的response.status_code.

Persistent state

如果一個response返回了一個cookie,那么這個cookie就會被存儲在test client里,并被其后的所有g(shù)et()和post()傳送.如果你想要終止這個cookie,你可以新建一個Client實例,或者手動刪除它。

一個test client具有兩個存儲持久化狀態(tài)信息的屬性:

Client.cookies

一個python SimpleCookie對象,存儲cilent的所有cookie。

Client.sessions

包含session信息的類字典對象。

如果要修改一個session并且存儲,首先將session存儲在變量中:

def test_something(self):
  session = self.client.session
  session['somekey'] = 'test'
  session.save()

一個使用client進行測試的實例:

from django.utils import unittest
from django.test.client import Client
 
class SimpleTest(unittest.TestCase):
  def setUp(self):
    # Every test needs a client.
    self.client = Client()
 
  def test_details(self):
    # Issue a GET request.
    response = self.client.get('/customer/details/')
 
    # Check that the response is 200 OK.
    self.assertEqual(response.status_code, 200)
 
    # Check that the rendered context contains 5 customers.
    self.assertEqual(len(response.context['customers']), 5)

Test cases的一些功能

默認的test client

每個django.test.*TestCase的test case實例都會訪問django test client,所以Client可以不用實例化,而直接用self.client訪問:

from django.test import TestCase 
class SimpleTest(TestCase):
  def test_details(self):
    response = self.client.get('/customer/details/')
    self.assertEqual(response.status_code, 200)
 
  def test_index(self):
    response = self.client.get('/customer/index/')
    self.assertEqual(response.status_code, 200)

Fixture loading

如果數(shù)據(jù)庫里沒有數(shù)據(jù),那么對于一個基于數(shù)據(jù)庫的網(wǎng)站來說,test case并無多大的用處.為了給測試數(shù)據(jù)庫加入測試數(shù)據(jù)更方便,django提供了載入fixtures的方法.

fixture是一系列的數(shù)據(jù)集合,django知道如何將它導入數(shù)據(jù)庫。

創(chuàng)建fixture最直接的方法就是使用manage.py dumpdata.當然,這假設(shè)你的實際數(shù)據(jù)庫里已經(jīng)有數(shù)據(jù)了.

注意:

如果你運行過manage.py syncdb命令,那么你已經(jīng)使用過fixture了--只是你不知道而已。當你使用syncdb去創(chuàng)建數(shù)據(jù)庫時,會創(chuàng)建一個叫initial_data的fixture。

其他名字的Fixture可以通過manage.py loaddata命令手動安裝.

一旦建立了一個fixture,并將它放在了某個django app的fixtures目錄中,你就可以在你的測試類里使用它了:

from django.test import TestCase
from myapp.models import Animal 
class AnimalTestCase(TestCase):
  fixtures = ['mammals.json', 'birds'] 
  def setUp(self):
    # Test definitions as before.
    call_setup_methods() 
  def testFluffyAnimals(self):
    # A test that uses the fixtures.
    call_some_test_code()

這是具體發(fā)生的過程:

1. 在setup()運行前,django會清空數(shù)據(jù)庫,相當于你執(zhí)行了syncdb。

2.然后,所有的fixture會被安裝.在例子中,django會安裝任何一個名字為mammals的JSON格式的fixture和名為birds的fixture數(shù)據(jù)。

Assertions

除了python中的assertEqual()和assertTrue()外,django的TestCase還提供了幾個額外的assert方法。

assertContains(response, text, count=None, status_code=200, msg_prefix='', html=False)

斷言response是否與status_code和text內(nèi)容相應。將html設(shè)為True會將text作為html處理。

assertJSONEqual(raw, expected_data, msg=None)

斷言Json片段raw和expected_data是否相當。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • windows安裝python超詳細圖文教程

    windows安裝python超詳細圖文教程

    今天帶各位小伙伴學習怎么在windows上安裝python,文中有非常詳細的圖文介紹,對初步學習python的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-05-05
  • Python中sorted()函數(shù)之排序的利器詳解

    Python中sorted()函數(shù)之排序的利器詳解

    sorted()函數(shù)是Python中的內(nèi)置函數(shù),用于對可迭代對象進行排序,下面這篇文章主要給大家介紹了關(guān)于Python中sorted()函數(shù)之排序的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-08-08
  • python 實現(xiàn)體質(zhì)指數(shù)BMI計算

    python 實現(xiàn)體質(zhì)指數(shù)BMI計算

    這篇文章主要介紹了python 實現(xiàn)體質(zhì)指數(shù)BMI計算操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python如何使用ElementTree解析xml

    Python如何使用ElementTree解析xml

    這篇文章主要介紹了Python如何使用ElementTree解析xml,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • Python開發(fā)的十個小貼士和技巧及長常犯錯誤

    Python開發(fā)的十個小貼士和技巧及長常犯錯誤

    這篇文章主要介紹了Python開發(fā)的十個小貼士和技巧,其中一些是初學這門語言常常會犯的錯誤,小編給大家一一列舉出來了,需要的朋友可以參考下
    2018-09-09
  • Python機器學習入門(二)之Python數(shù)據(jù)理解

    Python機器學習入門(二)之Python數(shù)據(jù)理解

    這篇文章主要介紹了Python機器學習入門知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • python處理DICOM并計算三維模型體積

    python處理DICOM并計算三維模型體積

    這篇文章主要為大家詳細介紹了python處理DICOM,并計算三維模型體積,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • 在Python 中同一個類兩個函數(shù)間變量的調(diào)用方法

    在Python 中同一個類兩個函數(shù)間變量的調(diào)用方法

    今天小編就為大家分享一篇在Python 中同一個類兩個函數(shù)間變量的調(diào)用方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • python爬蟲之驗證碼篇3-滑動驗證碼識別技術(shù)

    python爬蟲之驗證碼篇3-滑動驗證碼識別技術(shù)

    本篇涉及到的驗證碼為滑動驗證碼,不同于極驗證,本驗證碼難度略低,需要的將滑塊拖動到矩形區(qū)域右側(cè)即可完成。對python爬蟲滑動驗證碼識別技術(shù)感興趣的朋友跟隨小編一起看看吧
    2019-04-04
  • 利用Python實現(xiàn)生成并識別圖片驗證碼

    利用Python實現(xiàn)生成并識別圖片驗證碼

    這篇文章主要為大家的詳細介紹了如何利用Python實現(xiàn)生成并識別圖片驗證碼,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-02-02

最新評論