精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

現(xiàn)代軟件工程講義之單元測(cè)試和回歸測(cè)試

開發(fā) 測(cè)試
本文將給大家談?wù)勯_發(fā)過程中的單元測(cè)試和回歸測(cè)試,這屬于現(xiàn)代軟件工程中的一部分。

  1單元測(cè)試

  你的RP是由你的程序質(zhì)量決定的。

  ——阿超

  這一章講的是兩人合作,既然程序是兩個(gè)人寫的,那就會(huì)出現(xiàn)一個(gè)人寫的模塊被另一個(gè)人寫的模塊調(diào)用的情況。很多誤解、疏忽都發(fā)生在兩個(gè)模塊之間。如何能讓自己寫的模塊盡量無懈可擊?單元測(cè)試就是一個(gè)很有效的解決方案。

  1.1 用VSTS寫單元測(cè)試

  例子:我們寫一個(gè)比較常用的類型,看看它的單元測(cè)試應(yīng)該怎么寫?比如在各種網(wǎng)站應(yīng)用程序中都會(huì)用到的“用戶”這一類型。誰自告奮勇上來表演一下寫代碼?小飛,好,請(qǐng)上臺(tái)。

  小飛創(chuàng)建了一個(gè)C#的類庫(Class Library),并寫了如代碼清單11-1的代碼:

  代碼清單11-1

  1.   namespace DemoUser  
  2.   {  
  3.   public class User  
  4.   {  
  5.   public User(string userEmail)  
  6.   {  
  7.   m_email = userEmail;  
  8.   }  
  9.   private string m_email; //user email as user id  
  10.   }  
  11.   } 

  好,現(xiàn)在右鍵選中User,就可以看到“Create Unit Tests”的菜單,這樣就可以創(chuàng)建新的單元測(cè)試(如圖11-2所示)。

  圖11-2 創(chuàng)建單元測(cè)試項(xiàng)目

  創(chuàng)建單元測(cè)試后,注意到在Solution Explorer中出現(xiàn)了三個(gè)新的文件(如圖11-3所示)。

  圖11-3 新的單元測(cè)試文件

  Class1.cs是程序的文件,而Class1Test.cs是與之對(duì)應(yīng)的單元測(cè)試文件。

  DemoUser.vsmdi:測(cè)試管理文件。

  Localtestrun.testrunconfig:本地測(cè)試運(yùn)行設(shè)置文件。

  如何管理設(shè)置文件呢?右鍵再選屬性(Property)并不對(duì)。你得雙擊文件才能進(jìn)入管理及設(shè)置界面。在設(shè)置界面中,你可以讓單元測(cè)試產(chǎn)生“demouser.dll”的代碼覆蓋報(bào)告。

  注意在單元測(cè)試中,VSTS自動(dòng)為你生成了測(cè)試的骨架,但是你還是要自己做不少事情,最起碼要把那些//TODO的事情給做了(如代碼清單11-2所示)。在這個(gè)時(shí)候,單元測(cè)試還都是用的Assert. Inconclusive,表明這是一個(gè)未經(jīng)驗(yàn)證的單元測(cè)試。

  代碼清單11-2

  1.   /// <summary> 
  2.   ///A test for User (string)  
  3.   ///</summary> 
  4.   [TestMethod()]  
  5.   public void ConstructorTest()  
  6.   {  
  7.   string userEmail = null; // TODO: Initialize to an appropriate  
  8.   // value  
  9.   User target = new User(userEmail);  
  10.   // TODO: Implement code to verify target  
  11.   Assert.Inconclusive("TODO: Implement code to verify target");  
  12.   } 

  進(jìn)行簡單的修改后,我們得到了一個(gè)如代碼清單11-3正式的單元測(cè)試:

  代碼清單11-3

  1.   [TestMethod()]  
  2.   public void ConstructorTest()  
  3.   {  
  4.   string userEmail = "someone@somewhere.com";  
  5.   User target = new User(userEmail);  
  6.   Assert.IsTrue(target != null);  
  7.   } 

  //我們還可以進(jìn)一步測(cè)試E-mail是否的確是保存在User類型中。

  解釋單元測(cè)試的結(jié)構(gòu)

  從上面這個(gè)例子可以看到創(chuàng)建單元測(cè)試函數(shù)的主要步驟:

  (1)設(shè)置數(shù)據(jù)(一個(gè)假想的正確的E-mail地址);

  (2)使用被測(cè)試類型的功能(用E-mail地址來創(chuàng)建一個(gè)User類的實(shí)體);

  (3)比較實(shí)際結(jié)果和預(yù)期的結(jié)果(Assert.IsTrue(target!= null);)。

  現(xiàn)在可以運(yùn)行單元測(cè)試了,同時(shí)可以看看代碼覆蓋報(bào)告“code coverage report”,代碼***地都被覆蓋了。

  當(dāng)然這時(shí)候的代碼還有很多情況沒有處理,同學(xué)們?cè)谂_(tái)下雜曰——

  處理空的字符串,長度為零的字符串,都是空格的串……

  小飛熟練地用Copy/Paste又寫了下面的三個(gè)測(cè)試,如代碼清單11-4所示。

  代碼清單11-4

  1.   [TestMethod()]  
  2.   [ExpectedException(typeof (ArgumentNullException))]  
  3.   public void ConstructorTestNull()  
  4.   {  
  5.   User target = new User(null);  
  6.   }  
  7.  [TestMethod()]  
  8.   [ExpectedException(typeof(ArgumentException))]  
  9.   public void ConstructorTestEmpty()  
  10.   {  
  11.   User target = new User("");  
  12.   }  
  13.   [TestMethod()]  
  14.   [ExpectedException(typeof(ArgumentNullException))]  
  15.   public void ConstructorTestBlank()  
  16.   {  
  17.   User target = new User(" ");  
  18.   } 

  如果不修改類庫中的代碼,單元測(cè)試會(huì)報(bào)告這三個(gè)新的測(cè)試都失敗了。

  小飛對(duì)代碼做了相應(yīng)的修改。結(jié)果出了這樣的錯(cuò)誤,見代碼清單11-5:

  代碼清單11-5

  Test method UserTest.UserTest.ConstructorTestBlank threw exception System.ArgumentException, but exception System. ArgumentNull- Exception was expected. Exception message: System.Argument- Exception: Value does not fall within the expected range.

  大家定睛一看,原來小飛的Copy/Paste用了原來的ArgumentNullExcep- tion,而不是ArgumentException。

  如果有人加了下面的代碼:

  1.  if (!m_email.Contains("@"))  
  2.   {  
  3.   throw new ArgumentException();  
  4.   } 

  這時(shí),代碼覆蓋測(cè)試就會(huì)報(bào)告代碼覆蓋率是85%左右。那還得加上新的單元測(cè)試以保證所有的代碼都得到了基本的測(cè)試。

  二柱:現(xiàn)在我知道為什么有些軟件寫了好幾年都沒有發(fā)布了,敢情他們都忙著寫單元測(cè)試了。

  阿超:也許因?yàn)樗麄儧]有在一開始就寫單元測(cè)試,所以后來有很多小強(qiáng)要處理。很多調(diào)查顯示,在軟件開發(fā)后期發(fā)現(xiàn)的Bug,修復(fù)起來要花更多的時(shí)間。

  蕓蕓:這對(duì)我們?cè)O(shè)計(jì)人員有什么用呢?好像都是一些細(xì)節(jié)的東西。

  阿超:在我們寫規(guī)格說明書(specification)的時(shí)候,要越詳細(xì)越好,***你的各項(xiàng)要求都可以表達(dá)成單元測(cè)試的一個(gè)測(cè)試用例。

  蕓蕓:如果不能表示為一個(gè)單元測(cè)試呢?

  二柱:那就是你寫得還不夠細(xì)。

  小飛:我大膽地說一句。如果是一個(gè)人寫寫程序玩玩,單元測(cè)試似乎不那么重要。

  二柱:你可以大膽地對(duì)你的女朋友說:“我們只是玩一玩……”看看效果如何。

  阿超:如果玩一玩,什么都不太重要。如果你寫的模塊會(huì)有不同的人,在不同的時(shí)間使用,那你***把你這一“單元”要做的事,以及它不能做的事,用單元測(cè)試清晰地表達(dá)出來。

  1.2 好的單元測(cè)試的標(biāo)準(zhǔn)

  下面我們講講怎樣才算一個(gè)好的單元測(cè)試。

  單元測(cè)試應(yīng)該準(zhǔn)確、快速地保證程序基本模塊的正確性。下面是驗(yàn)證單元測(cè)試好壞的一系列標(biāo)準(zhǔn):

  單元測(cè)試應(yīng)該在***的功能/參數(shù)上驗(yàn)證程序的正確性。

  單元測(cè)試應(yīng)該測(cè)試程序中最基本的單元——如在C++/C#/Java中的類,在此基礎(chǔ)上,可以測(cè)試一些系統(tǒng)中最基本的功能點(diǎn)(這些功能點(diǎn)由幾個(gè)基本類組成),從面向?qū)ο蟮脑O(shè)計(jì)原理出發(fā),系統(tǒng)中最基本的功能點(diǎn)也應(yīng)該由一個(gè)類及其方法來表現(xiàn)。單元測(cè)試要測(cè)試API中的每一個(gè)方法及每一個(gè)參數(shù)。

  單元測(cè)試必須由最熟悉代碼的人(程序的作者)來寫。

  代碼的作者最了解代碼的目的、特點(diǎn)和實(shí)現(xiàn)的局限性。所以,寫單元測(cè)試沒有比作者更適合的人選了。

  問:如果我很忙,能不能讓別人代勞做單元測(cè)試?

  答:如果忙到連單元測(cè)試都沒有時(shí)間做,那么你也沒有時(shí)間寫好這個(gè)功能。在一些極限編程的方法中,是可以考慮讓別人來做單元測(cè)試的,但是,程序的作者還是要對(duì)單元測(cè)試負(fù)責(zé)。

  ***是在設(shè)計(jì)的時(shí)候就寫好單元測(cè)試,這樣單元測(cè)試就能體現(xiàn)API的語義,如果沒有單元測(cè)試,語義的準(zhǔn)確性就不能得到保障,以后會(huì)產(chǎn)生歧義。

  單元測(cè)試過后,機(jī)器狀態(tài)保持不變。

  這樣就可以不斷地運(yùn)行單元測(cè)試,如果單元測(cè)試創(chuàng)建了臨時(shí)的文件或目錄,應(yīng)該在Teardown階段把這些臨時(shí)的文件或目錄刪除。

  如果單元測(cè)試在數(shù)據(jù)庫中創(chuàng)建或修改了記錄,那么也許要?jiǎng)h除這些記錄,或者每一個(gè)單元測(cè)試使用一個(gè)新的數(shù)據(jù)庫,這樣可以保證單元測(cè)試不受以前單元測(cè)試實(shí)例的干擾。

  單元測(cè)試要快(一個(gè)測(cè)試運(yùn)行時(shí)間是幾秒鐘,而不是幾分鐘)。

  快,才能保證效率。因?yàn)橐粋€(gè)軟件中有幾十個(gè)基本模塊(類),每個(gè)模塊又有幾個(gè)方法,基本上我們要求一個(gè)類的測(cè)試要在幾秒鐘內(nèi)完成。如果軟件有相互獨(dú)立的幾個(gè)層次,那么在測(cè)試組中可以分類,如數(shù)據(jù)庫層次、網(wǎng)絡(luò)通信層次、客戶邏輯層次和用戶界面層次,可以分類運(yùn)行測(cè)試,比如只修改了“用戶界面”的代碼,則只需運(yùn)行“用戶界面”的單元測(cè)試。

  單元測(cè)試應(yīng)該產(chǎn)生可重復(fù)、一致的結(jié)果。

  如果單元測(cè)試的結(jié)果是錯(cuò)的,那一定是程序出了問題,而且這個(gè)錯(cuò)誤一定是可以重復(fù)的。

  問:如果用隨機(jī)數(shù)以增加測(cè)試的真實(shí)性,好么?

  答:一般情況下不好,如果某個(gè)隨機(jī)數(shù)導(dǎo)致程序出錯(cuò),但是下一次運(yùn)行又不能重復(fù)這一錯(cuò)誤,于事無補(bǔ)。要注意我們還是要用隨機(jī)數(shù)等辦法“增加測(cè)試的真實(shí)性”,但是不是在單元測(cè)試中。單元測(cè)試不能解決所有問題,所以也不必期望它會(huì)發(fā)現(xiàn)所有的缺陷。

  獨(dú)立性,單元測(cè)試的運(yùn)行/通過/失敗不依賴于別的測(cè)試,可以人為構(gòu)造數(shù)據(jù),以保持單元測(cè)試的獨(dú)立性。

  程序中的各個(gè)模塊都是互相依賴的,否則它們就不會(huì)出現(xiàn)在一個(gè)程序中。一般情況下,單元測(cè)試中的模塊可以直接引用其他的模塊,并期待其他的模塊能返回正確的結(jié)果。

  如果其他的模塊很不穩(wěn)定,或者其他模塊運(yùn)行比較費(fèi)時(shí)(如進(jìn)行網(wǎng)絡(luò)操作),而且對(duì)于本模塊的正確性并不起關(guān)鍵的作用,這時(shí)可以人為地構(gòu)造數(shù)據(jù)以保證這個(gè)單元測(cè)試的獨(dú)立性。

  單元測(cè)試應(yīng)該覆蓋所有代碼路徑,包括錯(cuò)誤處理路徑,為了保證單元測(cè)試的代碼覆蓋率,單元測(cè)試必須測(cè)試公開的和私有的函數(shù)/方法。

  單元測(cè)試必須覆蓋所測(cè)單元的所有代碼路徑。

  問:啊!這樣豈不是要寫很多啰里啰唆的測(cè)試方法?

  答:對(duì),因?yàn)槌绦蛑泻芏嗳毕荻际菑倪@些啰里啰唆的錯(cuò)誤處理中產(chǎn)生的。如果你的模塊中某個(gè)錯(cuò)誤處理路徑很難到達(dá),那你也許要想想是否可以把這個(gè)錯(cuò)誤處理拿掉。

  大栓:這對(duì)于那些愛寫復(fù)雜代碼的人是一個(gè)很好的懲罰,不對(duì),是一個(gè)很好的鍛煉。

  阿超:對(duì),把單元測(cè)試的責(zé)任和代碼作者綁定在一起后,代碼作者就能更真切地體會(huì)到復(fù)雜代碼的副作用,因?yàn)轵?yàn)證復(fù)雜代碼的正確性要困難得多。要注意的一點(diǎn)是:100%的代碼覆蓋率并不等同于100%的正確性。

  單元測(cè)試應(yīng)該集成到自動(dòng)測(cè)試的框架中。

  另一個(gè)重要的措施是要把單元測(cè)試自動(dòng)化,這樣每個(gè)人都能很容易地運(yùn)行它,并且可以使單元測(cè)試每天都運(yùn)行。每個(gè)人都可以隨時(shí)在自己的機(jī)器上運(yùn)行。團(tuán)隊(duì)一般是在每日構(gòu)建中運(yùn)行單元測(cè)試的,這樣每個(gè)單元測(cè)試的錯(cuò)誤就能及時(shí)被發(fā)現(xiàn)并得到修改。

  單元測(cè)試必須和產(chǎn)品代碼一起保存和維護(hù)。

  單元測(cè)試必須和代碼一起進(jìn)行版本維護(hù)。如果不是這樣,過了一陣,代碼和單元測(cè)試就會(huì)出現(xiàn)不一致,而且所有代碼的作者要花時(shí)間來確認(rèn)哪些是程序出現(xiàn)的錯(cuò)誤,哪些是由于單元測(cè)試更新滯后造成的錯(cuò)誤。這樣就失去了單元測(cè)試的意義,同時(shí)又給大家增加了負(fù)擔(dān)。如此折騰多次以后,大家就會(huì)覺得維護(hù)單元測(cè)試是一件很費(fèi)時(shí)費(fèi)力的事。

  1.3回歸測(cè)試

  在單元測(cè)試的基礎(chǔ)上, 我們就能夠建立關(guān)于這一模塊的回歸測(cè)試 (Regression Test).

  Regress 的英語定義是: return to a worse or less developed state。是倒退、退化、退步的意思。

  在軟件項(xiàng)目中,如果一個(gè)模塊或功能以前是正常工作的,但是在一個(gè)新的構(gòu)建中出了問題,那這個(gè)模塊就出現(xiàn)了一個(gè)“退步”(Regression),從正常工作的穩(wěn)定狀態(tài)退化到不正常工作的不穩(wěn)定狀態(tài)。

  在一個(gè)模塊的功能逐步完成的同時(shí),與此功能有關(guān)的測(cè)試用例也同樣在完善中。一旦有關(guān)的測(cè)試用例通過,我們就得到了此模塊的功能基準(zhǔn) (Baseline) , 一個(gè)模塊的所有單元測(cè)試就是這個(gè)模塊最初的Baseline。

  假如,在3.1.5版本,模塊A的測(cè)試用例125是通過的,但是測(cè)試人員發(fā)現(xiàn)在新的版本3.1.6,這個(gè)測(cè)試用例卻失敗了,這就是一個(gè)“倒退”。在新版本上運(yùn)行所有已通過的測(cè)試用例以驗(yàn)證有沒有“退化”情況發(fā)生,這個(gè)過程就是一個(gè)“Regression Test”。如果這樣的“倒退”是由于模塊的功能發(fā)生了正常變化(由于設(shè)計(jì)變更的原因)引起的,那么測(cè)試用例的基準(zhǔn)就要修改,以便和新的功能保持一致。

  針對(duì)一個(gè)Bug Fix, 我們也要作Regression Test。

  (1)驗(yàn)證新的代碼的確把缺陷改正了。

  (2)同時(shí)要驗(yàn)證新的代碼沒有把模塊的現(xiàn)有功能破壞,沒有Regression。

  所以對(duì)于“回歸測(cè)試”中的“回歸”,我們可以理解為“回歸到以前不正常的狀態(tài)”。

  回歸測(cè)試***要自動(dòng)化,因?yàn)檫@樣就可以對(duì)于每一個(gè)構(gòu)建快速運(yùn)行所有回歸測(cè)試,以保證盡早發(fā)現(xiàn)問題。單元測(cè)試是回歸測(cè)試的基礎(chǔ).

  在專注于模塊基本功能的單元測(cè)試之外, 還有功能測(cè)試 – 從用戶的角度檢查功能完成得怎么樣。 在微軟的實(shí)踐中,在一個(gè)項(xiàng)目的***穩(wěn)定階段,所有人都要參加全面的測(cè)試工作,把所有以前發(fā)現(xiàn)并修復(fù)的bug 找出來, 一個(gè)一個(gè)驗(yàn)證, 以保證所有已經(jīng)修復(fù)過的Bug的確得到了修復(fù),并且沒有在***一個(gè)版本中“復(fù)發(fā)”, 這是一個(gè)大規(guī)模的、全面的“回歸測(cè)試”。

原文鏈接:http://www.cnblogs.com/xinz/archive/2011/11/20/2255830.html

【編輯推薦】

  1. 測(cè)試用例設(shè)計(jì)方法1 等價(jià)類邊界值
  2. 測(cè)試用例設(shè)計(jì)方法2 因果圖判定表
  3. 軟件測(cè)試接口測(cè)試的測(cè)試用例類型
  4. 關(guān)于手機(jī)測(cè)試用例設(shè)計(jì)的幾件事
  5. 淺談跟蹤測(cè)試用例
  6. 測(cè)試用例與輸入數(shù)據(jù)的設(shè)計(jì)方法
責(zé)任編輯:彭凡 來源: 博客園
相關(guān)推薦

2017-01-14 23:42:49

單元測(cè)試框架軟件測(cè)試

2012-01-09 09:09:15

2017-02-23 15:59:53

測(cè)試MockSetup

2020-08-18 08:10:02

單元測(cè)試Java

2021-03-11 12:33:50

JavaPowerMock技巧

2011-05-16 16:41:06

軟件測(cè)試單元測(cè)試

2017-03-28 12:25:36

2017-01-16 12:12:29

單元測(cè)試JUnit

2017-01-14 23:26:17

單元測(cè)試JUnit測(cè)試

2011-06-20 17:25:02

單元測(cè)試

2011-05-16 16:52:09

單元測(cè)試徹底測(cè)試

2016-09-14 21:55:33

前端測(cè)試Karma

2017-03-23 16:02:10

Mock技術(shù)單元測(cè)試

2011-01-25 10:42:29

Visual Stud

2021-05-05 11:38:40

TestNGPowerMock單元測(cè)試

2023-07-26 08:58:45

Golang單元測(cè)試

2020-05-07 17:30:49

開發(fā)iOS技術(shù)

2011-07-04 18:16:42

單元測(cè)試

2023-09-20 21:30:14

單元測(cè)試完全指南

2023-08-02 13:59:00

GoogleTestCTest單元測(cè)試
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

制服 丝袜 综合 日韩 欧美| 欧美不卡在线播放| 又骚又黄的视频| 亚洲国产精品久久久天堂| 91精品国产麻豆国产自产在线| www国产免费| 欧美精品久久久久久久久久丰满| 性欧美暴力猛交另类hd| 日韩视频免费观看| 国产激情视频网站| 亚洲精品69| 午夜国产不卡在线观看视频| 奇米影视首页 狠狠色丁香婷婷久久综合 | 密臀av一区二区三区| 二区三区在线观看| 久久夜色精品一区| 亚洲综合在线做性| 欧美brazzers| 亚洲一级黄色| 久久激情视频免费观看| 成人免费无码大片a毛片| 91精品视频一区二区| 欧美性xxxxxxx| 免费看欧美一级片| 国产在线激情视频| 欧美激情综合五月色丁香小说| 国产91免费视频| 在线观看毛片av| 香蕉久久夜色精品| 国模吧一区二区三区| 国产免费美女视频| 青青草综合网| 亚洲欧美国产精品| 久久午夜夜伦鲁鲁片| 亚洲一区二区免费在线观看| 欧美熟乱第一页| 国产91对白刺激露脸在线观看| 在线观看的网站你懂的| 自拍偷拍国产精品| 亚洲三区在线| 日本电影在线观看网站| 国产午夜精品福利| 日韩av不卡在线播放| 五十路在线观看| gogo大胆日本视频一区| 国产精品v欧美精品∨日韩| 国产欧美一区二区三区视频在线观看| 免费av成人在线| 国产精品久久久久久久9999| 超碰在线观看91| 日韩国产欧美在线视频| 日本亚洲欧美三级| 无码人妻丰满熟妇精品| 日韩成人av影视| 国产精品成人免费视频| 中文字幕av第一页| 日本不卡视频一二三区| 国产精品日韩在线| 亚洲熟女乱色一区二区三区久久久 | 中文字幕亚洲欧美日韩2019| 国产精品成人无码免费| japanese国产精品| 上原亚衣av一区二区三区| 我要看一级黄色录像| 99re6这里只有精品| 久久韩剧网电视剧| 日韩欧美中文字幕视频| 黄色日韩精品| 欧洲精品毛片网站| 成人黄色三级视频| 国产自产视频一区二区三区| 亚洲xxx自由成熟| 女人18毛片一区二区三区| 99久久精品一区| 日本福利一区二区三区| 秋霞午夜在线观看| 亚洲午夜影视影院在线观看| 免费在线观看亚洲视频| 色天使综合视频| 欧美一区二区三区婷婷月色| 中文字幕第3页| 中日韩免视频上线全都免费| 中文字幕欧美精品在线| a在线视频播放观看免费观看| 伊人影院久久| 欧美在线国产精品| 91麻豆视频在线观看| 丁香婷婷综合网| 欧美日韩一区二区三| 黄色网址在线免费播放| 性做久久久久久免费观看| 三级a在线观看| 亚洲国产一区二区三区网站| 精品无人区乱码1区2区3区在线 | 日韩欧美视频| 久久久久久久一区二区| 亚洲精品久久久久久久蜜桃| 国产精品1024| 日韩啊v在线| 青草影视电视剧免费播放在线观看| 高跟丝袜一区二区三区| 色婷婷.com| 欧美jizz19性欧美| 久久久精品国产网站| 国产成人亚洲欧洲在线| 极品销魂美女一区二区三区| 久久er99热精品一区二区三区| eeuss影院在线播放| 亚洲第一久久影院| 日本黄色的视频| 免费av一区| 欧美激情一二三| 一本色道久久综合熟妇| 91在线视频18| 一二三四中文字幕| 一二区成人影院电影网| 亚洲电影第1页| 丝袜美腿小色网| 奇米四色…亚洲| 久久久久久九九九九| 日韩另类在线| 欧美喷水一区二区| 人人爽人人爽人人片| 亚洲三级网站| 97人人模人人爽人人喊38tv| 午夜在线小视频| 在线一区二区视频| 亚洲精品理论片| 亚洲国产mv| 丁香五月网久久综合| 国产欧美黑人| 欧美精品久久99| 亚洲欧美日韩第一页| 免费看黄裸体一级大秀欧美| 国产精品国产三级欧美二区| 八戒八戒神马在线电影| 911精品产国品一二三产区| 免费福利视频网站| 天堂影院一区二区| 欧美日韩精品不卡| 中文字幕在线视频网站| 日韩成人在线视频观看| 日韩免费黄色片| 成人深夜在线观看| 人妻少妇精品久久| 国产成人夜色高潮福利影视| 欧美激情视频一区| 黄片毛片在线看| 亚洲午夜一二三区视频| 日本精品一二三区| 在线电影一区| 精品不卡一区二区三区| 手机在线观看av| 亚洲精品自产拍| 嫩草影院一区二区三区| 亚洲国产精品激情在线观看| 制服丝袜综合网| 久久精品亚洲欧美日韩精品中文字幕| 国产精品私拍pans大尺度在线| www.av在线| 4438x亚洲最大成人网| 免费在线黄色网| 成人午夜激情视频| 国产一区二区三区精彩视频| 精品国产91乱码一区二区三区四区| 日韩免费不卡av| 素人av在线| 日韩写真欧美这视频| 欧美成人aaaaⅴ片在线看| 97se狠狠狠综合亚洲狠狠| 四虎永久在线精品无码视频| 国语产色综合| 亚洲一区二区三区视频播放| heyzo高清中文字幕在线| 日韩精品小视频| 美女黄页在线观看| 一区二区三区日本| 无码人妻aⅴ一区二区三区| 日韩高清在线不卡| 男人草女人视频| 香蕉视频一区二区三区| 国产精品永久免费观看| 污网站在线免费看| 精品在线欧美视频| 国产一区二区小视频| 亚洲国产精品久久久久婷婷884| 亚洲第一页av| 狠狠色丁香久久婷婷综合_中| 欧美国产日韩激情| 日韩精品四区| 国产伦精品一区二区三区四区视频 | 尤物在线精品| 这里只有精品66| 日韩精品a在线观看91| 国产一区二区在线免费视频| 国产白丝在线观看| 深夜福利国产精品| 性感美女福利视频| 3d动漫精品啪啪一区二区竹菊| 午夜毛片在线观看| 亚洲欧美精品午睡沙发| 永久免费看mv网站入口78| 国产原创一区二区三区| 国产男女在线观看| 欧美日韩午夜| 影音欧美亚洲| 国产精品一线天粉嫩av| 成人资源视频网站免费| 欧洲精品久久久久毛片完整版| 2019中文在线观看| 特级毛片在线| 菠萝蜜影院一区二区免费| 青春草在线观看| 日韩一区二区三区视频| 伊人免费在线观看高清版| 黄色精品一区二区| 久久黄色免费网站| 国产精品天干天干在线综合| 毛茸茸多毛bbb毛多视频| 成人黄色网址在线观看| 国内av免费观看| 日韩国产精品大片| 亚洲人成色77777| 中文在线一区| 久艹视频在线免费观看| 欧美国产精品| ijzzijzzij亚洲大全| 国产成人精品一区二区免费看京| 国产免费高清一区| 99久久香蕉| 91九色极品视频| 国产美女亚洲精品7777| 成人精品视频久久久久 | 亚洲a在线播放| 亚洲ww精品| 国产在线98福利播放视频| 亚州一区二区三区| 国产精品 欧美在线| 超碰国产一区| 国产成人综合亚洲| 欧美成人黑人| 国产精品久久久久久久久久三级| 成人爽a毛片免费啪啪| 2021国产精品视频| 日本电影欧美片| 国产激情999| 国产一区二区精品调教| 国产精品精品国产| 国产精品麻豆成人av电影艾秋| 国产精品黄视频| 国产成人免费| 成人黄色短视频在线观看| 99久久999| 91一区二区三区| 成人激情自拍| 久久av免费一区| 精品美女久久| 视频一区不卡| 91精品一区二区三区综合在线爱| 香蕉视频免费版| 欧美色图麻豆| 亚洲自偷自拍熟女另类| 丝袜美腿高跟呻吟高潮一区| 中文字幕永久视频| 国模一区二区三区白浆| 极品白嫩少妇无套内谢| 波多野结衣中文字幕一区| 少妇大叫太粗太大爽一区二区| 久久久99精品久久| 国产视频精品免费| 亚洲一二三区在线观看| 亚洲成熟少妇视频在线观看| 欧美日本在线播放| 亚洲奶汁xxxx哺乳期| 国产婷婷97碰碰久久人人蜜臀| 91高清在线视频| 久久99精品久久久久久琪琪| 波多野结衣视频一区二区| 日本高清视频一区| crdy在线观看欧美| 精品国产乱码久久久久久108| 在线亚洲a色| 日本丰满大乳奶| 亚洲免费网址| 久久精品视频在线观看免费| 国产.欧美.日韩| 欧美成人国产精品一区二区| 亚洲欧美日本在线| 蜜臀精品一区二区三区| 日韩欧美另类在线| 国产在线三区| 欧美激情精品久久久久| 日韩av首页| 国产精选在线观看91| 日韩欧美中文| 国产黄视频在线| 国产米奇在线777精品观看| 少妇精品一区二区| 亚洲美女免费视频| 中文字幕av第一页| 亚洲精品不卡在线| 国产区在线看| 国产精品久久久久久搜索 | 国产精品自拍av| 在线免费观看麻豆| 亚洲午夜精品在线| 国产精品无码一区二区桃花视频| 亚洲美女久久久| 国产黄色大片在线观看| 成人网欧美在线视频| 嫩草一区二区三区| 国产欧美日韩小视频| 韩国成人精品a∨在线观看| 少妇久久久久久久久久| 午夜私人影院久久久久| 国产极品久久久| 日韩一区av在线| 电影天堂国产精品| 精品日本一区二区三区| 欧美日韩福利| 亚洲男人天堂av在线| 久久精品日产第一区二区三区高清版| 妺妺窝人体色www婷婷| 欧美福利电影网| lutube成人福利在线观看| 国产91精品久久久| 欧美1区2区3区4区| 999久久欧美人妻一区二区| 精品中文字幕一区二区| 国产欧美一区二区三区在线观看视频| 欧美天堂在线观看| 天天操天天射天天舔| 久久久久久国产精品久久| 亚洲精品一区国产| 99热都是精品| 国产乱子轮精品视频| 亚洲二区在线播放| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲一区二区免费视频| 国产丰满美女做爰| 欧美激情xxxx| 99re91这里只有精品| 日本免费成人网| 成人av资源网站| 欧美三级韩国三级日本三斤在线观看| 欧美精品一区二区三区视频| 超碰在线资源| 含羞草久久爱69一区| 亚洲综合二区| 精品人伦一区二区| 欧美日韩中文字幕一区二区| 一区二区三区视频网站| 成人av色在线观看| 在线一区电影| 国产欧美视频一区| 欧美日韩国产精品一区| 深夜福利视频在线观看| 国产91精品网站| 成人激情诱惑| 97人人模人人爽人人澡| 一区二区三区鲁丝不卡| 人人妻人人澡人人爽精品日本| 97精品伊人久久久大香线蕉| 国产精品chinese在线观看| 自拍日韩亚洲一区在线| 26uuu色噜噜精品一区二区| 69视频免费看| 久久国产精品亚洲| 欧美人妖视频| 91看片在线免费观看| 亚洲日本电影在线| 丰满熟妇人妻中文字幕| 国产91色在线|| 婷婷精品进入| 亚洲综合自拍网| 欧美日韩国产片| 国产第一页在线视频| 欧美一区视久久| 国产一区二区不卡在线| 国产成人在线免费视频| 中文在线不卡视频| julia中文字幕一区二区99在线| 国产日产欧美视频| 亚洲视频一二三| 天天干天天干天天干| 国产精品永久在线| 在线播放亚洲| 日韩精品一区二区三区在线视频| 精品久久人人做人人爱| 你懂得影院夜精品a| av影院在线播放| 欧美国产禁国产网站cc| 亚洲国产精品久久人人爱潘金莲 | 久久久久久一级片| 国产日本精品视频| 国产成人精品久久二区二区91| 欧美成人亚洲| 国产一二三四视频| 日韩激情视频在线播放| 精品国产乱码久久久久久樱花|