青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

不倦的候鳥成長日記

——候鳥,候補的菜鳥也
隨筆 - 6, 文章 - 0, 評論 - 5, 引用 - 0
數(shù)據(jù)加載中……

全面介紹單元測試 -轉(zhuǎn)貼

全面介紹單元測試 -轉(zhuǎn)貼

這是一篇全面介紹單元測試的經(jīng)典之作,對理解單元測試和Visual Unit很有幫助,作者老納,收錄時作了少量修改

一 單元測試概述
  工廠在組裝一臺電視機之前,會對每個元件都進行測試,這,就是單元測試。
  其實我們每天都在做單元測試。你寫了一個函數(shù),除了極簡單的外,總是要執(zhí)行一下,看看功能是否正常,有時還要想辦法輸出些數(shù)據(jù),如彈出信息窗口什么的,這,也是單元測試,老納把這種單元測試稱為臨時單元測試。只進行了臨時單元測試的軟件,針對代碼的測試很不完整,代碼覆蓋率要超過70%都很困難,未覆蓋的代碼可能遺留大量的細小的錯誤,這些錯誤還會互相影響,當BUG暴露出來的時候難于調(diào)試,大幅度提高后期測試和維護成本,也降低了開發(fā)商的競爭力。可以說,進行充分的單元測試,是提高軟件質(zhì)量,降低開發(fā)成本的必由之路。
  對于程序員來說,如果養(yǎng)成了對自己寫的代碼進行單元測試的習慣,不但可以寫出高質(zhì)量的代碼,而且還能提高編程水平。
  要進行充分的單元測試,應專門編寫測試代碼,并與產(chǎn)品代碼隔離。老納認為,比較簡單的辦法是為產(chǎn)品工程建立對應的測試工程,為每個類建立對應的測試類,為每個函數(shù)(很簡單的除外)建立測試函數(shù)。首先就幾個概念談談老納的看法。
  一般認為,在結(jié)構(gòu)化程序時代,單元測試所說的單元是指函數(shù),在當今的面向?qū)ο髸r代,單元測試所說的單元是指類。以老納的實踐來看,以類作為測試單位,復雜度高,可操作性較差,因此仍然主張以函數(shù)作為單元測試的測試單位,但可以用一個測試類來組織某個類的所有測試函數(shù)。單元測試不應過分強調(diào)面向?qū)ο?,因為局部代碼依然是結(jié)構(gòu)化的。單元測試的工作量較大,簡單實用高效才是硬道理。
  有一種看法是,只測試類的接口(公有函數(shù)),不測試其他函數(shù),從面向?qū)ο蠼嵌葋砜?,確實有其道理,但是,測試的目的是找錯并最終排錯,因此,只要是包含錯誤的可能性較大的函數(shù)都要測試,跟函數(shù)是否私有沒有關(guān)系。對于C++來說,可以用一種簡單的方法區(qū)隔需測試的函數(shù):簡單的函數(shù)如數(shù)據(jù)讀寫函數(shù)的實現(xiàn)在頭文件中編寫(inline函數(shù)),所有在源文件編寫實現(xiàn)的函數(shù)都要進行測試(構(gòu)造函數(shù)和析構(gòu)函數(shù)除外)。
  什么時候測試?單元測試越早越好,早到什么程度?XP開發(fā)理論講究TDD,即測試驅(qū)動開發(fā),先編寫測試代碼,再進行開發(fā)。在實際的工作中,可以不必過分強調(diào)先什么后什么,重要的是高效和感覺舒適。從老納的經(jīng)驗來看,先編寫產(chǎn)品函數(shù)的框架,然后編寫測試函數(shù),針對產(chǎn)品函數(shù)的功能編寫測試用例,然后編寫產(chǎn)品函數(shù)的代碼,每寫一個功能點都運行測試,隨時補充測試用例。所謂先編寫產(chǎn)品函數(shù)的框架,是指先編寫函數(shù)空的實現(xiàn),有返回值的隨便返回一個值,編譯通過后再編寫測試代碼,這時,函數(shù)名、參數(shù)表、返回類型都應該確定下來了,所編寫的測試代碼以后需修改的可能性比較小。
  由誰測試?單元測試與其他測試不同,單元測試可看作是編碼工作的一部分,應該由程序員完成,也就是說,經(jīng)過了單元測試的代碼才是已完成的代碼,提交產(chǎn)品代碼時也要同時提交測試代碼。測試部門可以作一定程度的審核。
  關(guān)于樁代碼,老納認為,單元測試應避免編寫樁代碼。樁代碼就是用來代替某些代碼的代碼,例如,產(chǎn)品函數(shù)或測試函數(shù)調(diào)用了一個未編寫的函數(shù),可以編寫樁函數(shù)來代替該被調(diào)用的函數(shù),樁代碼也用于實現(xiàn)測試隔離。采用由底向上的方式進行開發(fā),底層的代碼先開發(fā)并先測試,可以避免編寫樁代碼,這樣做的好處有:減少了工作量;測試上層函數(shù)時,也是對下層函數(shù)的間接測試;當下層函數(shù)修改時,通過回歸測試可以確認修改是否導致上層函數(shù)產(chǎn)生錯誤。

二 測試代碼編寫
  多數(shù)講述單元測試的文章都是以Java為例,本文以C++為例,后半部分所介紹的單元測試工具也只介紹C++單元測試工具。下面的示例代碼的開發(fā)環(huán)境是VC6.0。

產(chǎn)品類:
class CMyClass
{
public:
       int Add(int i, int j);
       CMyClass();
       virtual ~CMyClass();

private:
       int mAge;         //年齡
       CString mPhase; //年齡階段,如"少年","青年"
};

建立對應的測試類CMyClassTester,為了節(jié)約編幅,只列出源文件的代碼:
void CMyClassTester::CaseBegin()
{
       //pObj是CMyClassTester類的成員變量,是被測試類的對象的指針,
       //為求簡單,所有的測試類都可以用pObj命名被測試對象的指針。
       pObj = new CMyClass();
}

void CMyClassTester::CaseEnd()
{
       delete pObj;
}
測試類的函數(shù)CaseBegin()和CaseEnd()建立和銷毀被測試對象,每個測試用例的開頭都要調(diào)用CaseBegin(),結(jié)尾都要調(diào)用CaseEnd()。

接下來,我們建立示例的產(chǎn)品函數(shù):
int CMyClass::Add(int i, int j)
{
       return i+j;
}
和對應的測試函數(shù):
void CMyClassTester::Add_int_int()
{
}
把參數(shù)表作為函數(shù)名的一部分,這樣當出現(xiàn)重載的被測試函數(shù)時,測試函數(shù)不會產(chǎn)生命名沖突。下面添加測試用例:
void CMyClassTester::Add_int_int()
{
       //第一個測試用例
       CaseBegin();{                 //1
       int i = 0;                   //2
       int j = 0;                   //3
       int ret = pObj->Add(i, j); //4
       ASSERT(ret == 0);             //5
       }CaseEnd();                   //6
}
第1和第6行建立和銷毀被測試對象,所加的{}是為了讓每個測試用例的代碼有一個獨立的域,以便多個測試用例使用相同的變量名。
第2和第3行是定義輸入數(shù)據(jù),第4行是調(diào)用被測試函數(shù),這些容易理解,不作進一步解釋。第5行是預期輸出,它的特點是當實際輸出與預期輸出不同時自動報錯,ASSERT是VC的斷言宏,也可以使用其他類似功能的宏,使用測試工具進行單元測試時,可以使用該工具定義的斷言宏。

  示例中的格式顯得很不簡潔,2、3、4、5行可以合寫為一行:ASSERT(pObj->Add(0, 0) == 0);但這種不簡潔的格式卻是老納極力推薦的,因為它一目了然,易于建立多個測試用例,并且具有很好的適應性,同時,也是極佳的代碼文檔,總之,老納建議:輸入數(shù)據(jù)和預期輸出要自成一塊。
  建立了第一個測試用例后,應編譯并運行測試,以排除語法錯誤,然后,使用拷貝/修改的辦法建立其他測試用例。由于各個測試用例之間的差別往往很小,通常只需修改一兩個數(shù)據(jù),拷貝/修改是建立多個測試用例的最快捷辦法。

三 測試用例
  下面說說測試用例、輸入數(shù)據(jù)及預期輸出。輸入數(shù)據(jù)是測試用例的核心,老納對輸入數(shù)據(jù)的定義是:被測試函數(shù)所讀取的外部數(shù)據(jù)及這些數(shù)據(jù)的初始值。外部數(shù)據(jù)是對于被測試函數(shù)來說的,實際上就是除了局部變量以外的其他數(shù)據(jù),老納把這些數(shù)據(jù)分為幾類:參數(shù)、成員變量、全局變量、IO媒體。IO媒體是指文件、數(shù)據(jù)庫或其他儲存或傳輸數(shù)據(jù)的媒體,例如,被測試函數(shù)要從文件或數(shù)據(jù)庫讀取數(shù)據(jù),那么,文件或數(shù)據(jù)庫中的原始數(shù)據(jù)也屬于輸入數(shù)據(jù)。一個函數(shù)無論多復雜,都無非是對這幾類數(shù)據(jù)的讀取、計算和寫入。預期輸出是指:返回值及被測試函數(shù)所寫入的外部數(shù)據(jù)的結(jié)果值。返回值就不用說了,被測試函數(shù)進行了寫操作的參數(shù)(輸出參數(shù))、成員變量、全局變量、IO媒體,它們的預期的結(jié)果值都是預期輸出。一個測試用例,就是設(shè)定輸入數(shù)據(jù),運行被測試函數(shù),然后判斷實際輸出是否符合預期。下面舉一個與成員變量有關(guān)的例子:
產(chǎn)品函數(shù):
void CMyClass::Grow(int years)
{
       mAge += years;

       if(mAge < 10)
           mPhase = "兒童";
       else if(mAge <20)
           mPhase = "少年";
       else if(mAge <45)
           mPhase = "青年";
       else if(mAge <60)
           mPhase = "中年";
       else
           mPhase = "老年";
}

測試函數(shù)中的一個測試用例:
       CaseBegin();{
       int years = 1;
       pObj->mAge = 8;
       pObj->Grow(years);
       ASSERT( pObj->mAge == 9 );
       ASSERT( pObj->mPhase == "兒童" );
       }CaseEnd();
在輸入數(shù)據(jù)中對被測試類的成員變量mAge進行賦值,在預期輸出中斷言成員變量的值。現(xiàn)在可以看到老納所推薦的格式的好處了吧,這種格式可以適應很復雜的測試。在輸入數(shù)據(jù)部分還可以調(diào)用其他成員函數(shù),例如:執(zhí)行被測試函數(shù)前可能需要讀取文件中的數(shù)據(jù)保存到成員變量,或需要連接數(shù)據(jù)庫,老納把這些操作稱為初始化操作。例如,上例中 ASSERT( ...)之前可以加pObj->OpenFile();。為了訪問私有成員,可以將測試類定義為產(chǎn)品類的友元類。例如,定義一個宏:
#define UNIT_TEST(cls) friend class cls##Tester;
然后在產(chǎn)品類聲明中加一行代碼:UNIT_TEST(ClassName)。

  下面談談測試用例設(shè)計。前面已經(jīng)說了,測試用例的核心是輸入數(shù)據(jù)。預期輸出是依據(jù)輸入數(shù)據(jù)和程序功能來確定的,也就是說,對于某一程序,輸入數(shù)據(jù)確定了,預期輸出也就可以確定了,至于生成/銷毀被測試對象和運行測試的語句,是所有測試用例都大同小異的,因此,我們討論測試用例時,只討論輸入數(shù)據(jù)。
  前面說過,輸入數(shù)據(jù)包括四類:參數(shù)、成員變量、全局變量、IO媒體,這四類數(shù)據(jù)中,只要所測試的程序需要執(zhí)行讀操作的,就要設(shè)定其初始值,其中,前兩類比較常用,后兩類較少用。顯然,把輸入數(shù)據(jù)的所有可能取值都進行測試,是不可能也是無意義的,我們應該用一定的規(guī)則選擇有代表性的數(shù)據(jù)作為輸入數(shù)據(jù),主要有三種:正常輸入,邊界輸入,非法輸入,每種輸入還可以分類,也就是平常說的等價類法,每類取一個數(shù)據(jù)作為輸入數(shù)據(jù),如果測試通過,可以肯定同類的其他輸入也是可以通過的。下面舉例說明:
  正常輸入
  例如字符串的Trim函數(shù),功能是將字符串前后的空格去除,那么正常的輸入可以有四類:前面有空格;后面有空格;前后均有空格;前后均無空格。
  邊界輸入
  上例中空字符串可以看作是邊界輸入。
  再如一個表示年齡的參數(shù),它的有效范圍是0-100,那么邊界輸入有兩個:0和100。
  非法輸入
  非法輸入是正常取值范圍以外的數(shù)據(jù),或使代碼不能完成正常功能的輸入,如上例中表示年齡的參數(shù),小于0或大于100都是非法輸入,再如一個進行文件操作的函數(shù),非法輸入有這么幾類:文件不存在;目錄不存在;文件正在被其他程序打開;權(quán)限錯誤。
  如果函數(shù)使用了外部數(shù)據(jù),則正常輸入是肯定會有的,而邊界輸入和非法輸入不是所有函數(shù)都有。一般情況下,即使沒有設(shè)計文檔,考慮以上三種輸入也可以找出函數(shù)的基本功能點。實際上,單元測試與代碼編寫是“一體兩面”的關(guān)系,編碼時對上述三種輸入都是必須考慮的,否則代碼的健壯性就會成問題。

四 白盒覆蓋
  上面所說的測試數(shù)據(jù)都是針對程序的功能來設(shè)計的,就是所謂的黑盒測試。單元測試還需要從另一個角度來設(shè)計測試數(shù)據(jù),即針對程序的邏輯結(jié)構(gòu)來設(shè)計測試用例,就是所謂的白盒測試。在老納看來,如果黑盒測試是足夠充分的,那么白盒測試就沒有必要,可惜“足夠充分”只是一種理想狀態(tài),例如:真的是所有功能點都測試了嗎?程序的功能點是人為的定義,常常是不全面的;各個輸入數(shù)據(jù)之間,有些組合可能會產(chǎn)生問題,怎樣保證這些組合都經(jīng)過了測試?難于衡量測試的完整性是黑盒測試的主要缺陷,而白盒測試恰恰具有易于衡量測試完整性的優(yōu)點,兩者之間具有極好的互補性,例如:完成功能測試后統(tǒng)計語句覆蓋率,如果語句覆蓋未完成,很可能是未覆蓋的語句所對應的功能點未測試。
  白盒測試針對程序的邏輯結(jié)構(gòu)設(shè)計測試用例,用邏輯覆蓋率來衡量測試的完整性。邏輯單位主要有:語句、分支、條件、條件值、條件值組合,路徑。語句覆蓋就是覆蓋所有的語句,其他類推。另外還有一種判定條件覆蓋,其實是分支覆蓋與條件覆蓋的組合,在此不作討論。跟條件有關(guān)的覆蓋就有三種,解釋一下:條件覆蓋是指覆蓋所有的條件表達式,即所有的條件表達式都至少計算一次,不考慮計算結(jié)果;條件值覆蓋是指覆蓋條件的所有可能取值,即每個條件的取真值和取假值都要至少計算一次;條件值組合覆蓋是指覆蓋所有條件取值的所有可能組合。老納做過一些粗淺的研究,發(fā)現(xiàn)與條件直接有關(guān)的錯誤主要是邏輯操作符錯誤,例如:||寫成&&,漏了寫!什么的,采用分支覆蓋與條件覆蓋的組合,基本上可以發(fā)現(xiàn)這些錯誤,另一方面,條件值覆蓋與條件值組合覆蓋往往需要大量的測試用例,因此,在老納看來,條件值覆蓋和條件值組合覆蓋的效費比偏低。老納認為效費比較高且完整性也足夠的測試要求是這樣的:完成功能測試,完成語句覆蓋、條件覆蓋、分支覆蓋、路徑覆蓋。做過單元測試的朋友恐怕會對老納提出的測試要求給予一個字的評價:暈!或者兩個字的評價:狂暈!因為這似乎是不可能的要求,要達到這種測試完整性,其測試成本是不可想象的,不過,出家人不打逛語,老納之所以提出這種測試要求,是因為利用一些工具,可以在較低的成本下達到這種測試要求,后面將會作進一步介紹。
  關(guān)于白盒測試用例的設(shè)計,程序測試領(lǐng)域的書籍一般都有講述,普通方法是畫出程序的邏輯結(jié)構(gòu)圖如程序流程圖或控制流圖,根據(jù)邏輯結(jié)構(gòu)圖設(shè)計測試用例,這些是純粹的白盒測試,不是老納想推薦的方式。老納所推薦的方法是:先完成黑盒測試,然后統(tǒng)計白盒覆蓋率,針對未覆蓋的邏輯單位設(shè)計測試用例覆蓋它,例如,先檢查是否有語句未覆蓋,有的話設(shè)計測試用例覆蓋它,然后用同樣方法完成條件覆蓋、分支覆蓋和路徑覆蓋,這樣的話,既檢驗了黑盒測試的完整性,又避免了重復的工作,用較少的時間成本達到非常高的測試完整性。不過,這些工作可不是手工能完成的,必須借助于工具,后面會介紹可以完成這些工作的測試工具。

五 單元測試工具
  現(xiàn)在開始介紹單元測試工具,老納只介紹三種,都是用于C++語言的。
  首先是CppUnit,這是C++單元測試工具的鼻祖,免費的開源的單元測試框架。由于已有一眾高人寫了不少關(guān)于CppUnit的很好的文章,老納就不現(xiàn)丑了,想了解CppUnit的朋友,建議讀一下Cpluser 所作的《CppUnit測試框架入門》,網(wǎng)址是:
http://blog.csdn.net/cpluser/archive/2004/09/21/111522.aspx。該文也提供了CppUnit的下載地址。
  然后介紹C++Test,這是Parasoft公司的產(chǎn)品。[C++Test是一個功能強大的自動化C/C++單元級測試工具,可以自動測試任何C/C++函數(shù)、類,自動生成測試用例、測試驅(qū)動函數(shù)或樁函數(shù),在自動化的環(huán)境下極其容易快速的將單元級的測試覆蓋率達到100%。
這是華唐公司的網(wǎng)頁上的介紹。老納想寫些介紹C++Test的文字,但發(fā)現(xiàn)無法超越華唐公司的網(wǎng)頁上的介紹,所以也就省點事了,想了解C++Test的朋友,建議訪問該公司的網(wǎng)站。華唐公司代理C++Test,想要購買或索取報價、試用版都可以找他們。老納幫華唐公司做廣告,不知道會不會得點什么好處?
  最后介紹Visual Unit,簡稱VU,這是國產(chǎn)的單元測試工具,據(jù)說申請了多項專利,擁有一批創(chuàng)新的技術(shù),不過老納只關(guān)心是不是有用和好用。[自動生成測試代碼 快速建立功能測試用例 程序行為一目了然 極高的測試完整性 高效完成白盒覆蓋 快速排錯 高效調(diào)試 詳盡的測試報告]。[]內(nèi)的文字是VU開發(fā)商的網(wǎng)頁上摘錄的,網(wǎng)址是:
http://www.unitware.cn。前面所述測試要求:完成功能測試,完成語句覆蓋、條件覆蓋、分支覆蓋、路徑覆蓋,用VU可以輕松實現(xiàn),還有一點值得一提:使用VU還能提高編碼的效率,總體來說,在完成單元測試的同時,編碼調(diào)試的時間還能大幅度縮短。算了,不想再講了,老納顯擺理論、介紹經(jīng)驗還是有興趣的,因為可以滿足老納好為人師的虛榮心,但介紹工具就覺得索然無味了,畢竟工具好不好用,合不合用,要試過才知道,還是自己去開發(fā)商的網(wǎng)站看吧,可以下載演示版,還有演示課件。

轉(zhuǎn)自:http://www.cnblogs.com/tester2test/archive/2006/08/04/467764.html

posted on 2007-08-26 14:33 不倦 閱讀(797) 評論(0)  編輯 收藏 引用 所屬分類: C++單元測試框架

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产日韩一区二区| 欧美激情第10页| 久久综合久久综合这里只有精品| 欧美日韩精品一区二区天天拍小说| 红桃视频一区| 久久久久久日产精品| 亚洲欧美激情一区二区| 欧美性片在线观看| 久久国产精品一区二区| 亚洲欧美日产图| 黄色成人av| 亚洲在线第一页| 欧美在线观看视频| 一本色道久久综合| 亚洲欧美日本另类| 亚洲国产精品va在看黑人| 国产精品丝袜白浆摸在线| 久久人人爽人人爽| 欧美日本一区二区视频在线观看| 欧美一区二区三区在线观看视频 | 国产精品一区免费视频| 亚洲综合导航| 欧美不卡高清| 美女久久一区| 国产欧美精品一区| 在线亚洲精品| 亚洲私人影院在线观看| 久久久www成人免费无遮挡大片| 9久草视频在线视频精品| 久久婷婷综合激情| 久久中文精品| 精品av久久707| 久久精品在线观看| 久久久国产精品一区二区中文| 欧美午夜片在线观看| 亚洲最新合集| 久久av二区| 激情综合网址| 欧美成人自拍视频| 日韩午夜av电影| 亚洲一二三级电影| 亚洲二区视频| 激情亚洲网站| 欧美精品性视频| 亚洲免费综合| 另类图片综合电影| 亚洲人成77777在线观看网| 麻豆久久婷婷| 日韩午夜一区| 欧美主播一区二区三区美女 久久精品人| 欧美日韩一二三区| 亚洲夜晚福利在线观看| 国产精品国产三级欧美二区| 午夜精品在线看| 亚洲夫妻自拍| 亚洲小说欧美另类社区| 国产一区二区成人| 久久精品中文字幕一区二区三区 | 亚洲欧美日韩一区二区三区在线| 亚洲欧美国产77777| 国产自产精品| 欧美日韩国产黄| 久久久999国产| 亚洲一级电影| 亚洲精品国偷自产在线99热| 久久久久久电影| 亚洲一级二级在线| 亚洲第一在线综合网站| 国产精品一区三区| 欧美精品日韩一本| 女仆av观看一区| 久久精品欧美日韩精品| 亚洲一区二区在线观看视频| 亚洲欧洲日产国产网站| 男同欧美伦乱| 欧美成年人视频网站欧美| 久久亚洲国产成人| 裸体一区二区| 亚洲电影毛片| 亚洲国产高潮在线观看| 亚洲国产成人久久综合一区| 欧美国产日韩视频| 最新国产拍偷乱拍精品| 亚洲精品乱码久久久久| 亚洲视频一区在线| 欧美亚洲一区在线| 久热精品在线| 欧美日韩精品一区| 国产一区二区三区电影在线观看 | 欧美视频二区| 国产精品素人视频| 精品999在线观看| 亚洲看片一区| 久久精品在线观看| 欧美国产精品日韩| 亚洲一本视频| 欧美激情亚洲自拍| 国产精品99一区二区| 亚洲第一伊人| 久久久高清一区二区三区| 亚洲国产精品一区二区久| 亚洲午夜一区二区| 欧美高清影院| 伊人激情综合| 亚洲在线观看视频| 欧美成人免费播放| 欧美亚洲视频| 国产精品一二一区| 一区二区日韩欧美| 亚洲国产经典视频| 麻豆av福利av久久av| 国产伦精品一区二区三区视频黑人| 亚洲第一主播视频| 久久久之久亚州精品露出| 亚洲综合欧美日韩| 国产精品每日更新| 亚洲一区日韩| 在线一区二区三区四区五区| 欧美/亚洲一区| 亚洲精品欧美一区二区三区| 久久在线91| 美乳少妇欧美精品| 亚洲茄子视频| 一二美女精品欧洲| 国产精品麻豆va在线播放| 欧美一区二区三区视频在线 | 午夜亚洲福利在线老司机| 日韩香蕉视频| 欧美午夜电影一区| 免费的成人av| 亚洲电影成人| 亚洲精一区二区三区| 欧美日韩一级黄| 久久精品国产99精品国产亚洲性色| 亚洲欧美日本国产有色| 好吊色欧美一区二区三区四区| 在线观看亚洲精品| 亚洲人成亚洲人成在线观看图片 | 亚洲卡通欧美制服中文| 国产精品久久久久久亚洲调教 | 亚洲九九九在线观看| 欧美日韩一卡| 久久久www成人免费精品| 欧美精品激情在线| 亚洲综合导航| 欧美国产激情二区三区| 久久精品国产免费观看| 欧美日韩精品二区| 蜜桃久久av| 国产精品久久久久久模特 | 亚洲一区二区三区精品视频| 久久av一区二区三区漫画| 中文亚洲欧美| 免费看的黄色欧美网站| 欧美一级淫片aaaaaaa视频| 欧美日韩精品福利| 亚洲精品一品区二品区三品区| 红桃视频国产精品| 欧美一级午夜免费电影| 亚洲一区在线播放| 欧美精品免费看| 一区二区免费在线视频| 99国产一区| 欧美日韩三区四区| 亚洲毛片在线看| 亚洲视频日本| 国产精品免费一区豆花| 一区二区激情| 国产日韩精品在线| 亚洲无线一线二线三线区别av| 亚洲在线中文字幕| 国产精品一区二区视频| 欧美在线高清| 亚洲日韩欧美视频一区| 亚洲午夜女主播在线直播| 国产精品美女久久久久久2018| 亚洲在线播放电影| 久久精品在线观看| 日韩午夜精品| 国产日韩综合一区二区性色av| 久久精品人人做人人爽| 亚洲欧洲日本mm| 亚洲欧美美女| 亚洲人精品午夜在线观看| 国产精品国产福利国产秒拍| 欧美在线地址| 99视频热这里只有精品免费| 久久精品天堂| 久久九九精品99国产精品| 亚洲精品免费一二三区| 久久免费视频网站| 欧美在线视频不卡| 亚洲精品亚洲人成人网| 国产日韩av高清| 欧美日韩一级大片网址| 模特精品在线| 久久久精品午夜少妇| 亚洲一区久久久| aa成人免费视频| 亚洲精品久久久久久久久久久|