日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

dbunit使用_摆脱困境:在DbUnit数据集中使用空值

發布時間:2023/12/3 编程问答 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 dbunit使用_摆脱困境:在DbUnit数据集中使用空值 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

dbunit使用

如果我們正在為使用Spring Framework的應用程序編寫集成測試,則可以通過使用Spring Test DbUnit將DbUnit與Spring測試框架集成。

但是, 這種集成并非沒有問題

通常,我們必須在運行測試之前向數據庫中插入空值,或者驗證保存到特定表列中的值是否為空 。 這些是非常基本的用例,但是編寫支持它們的集成測試非常棘手。

這篇博客文章指出了與空值有關的問題,并描述了如何解決它們。 讓我們從快速查看被測系統開始。

如果您不知道如何為存儲庫編寫集成測試,則應閱讀我的博客文章,標題為: Spring Data JPA教程:集成測試 。

它說明了如何為Spring Data JPA存儲庫編寫集成測試,但是您可以使用相同的方法為其他使用關系數據庫的Spring支持的存儲庫編寫測試。

被測系統

經過測試的“應用程序”具有一個實體和一個Spring Data JPA存儲庫,該存儲庫為該實體提供CRUD操作。

我們的實體類稱為Todo ,其源代碼的相關部分如下所示:

import javax.persistence.*;@Entity @Table(name="todos") public class Todo {private static final int MAX_LENGTH_DESCRIPTION = 500;private static final int MAX_LENGTH_TITLE = 100;@Id@GeneratedValue(strategy = GenerationType.AUTO)private Long id;@Column(name = "description", nullable = true, length = MAX_LENGTH_DESCRIPTION)private String description;@Column(name = "title", nullable = false, length = MAX_LENGTH_TITLE)private String title;@Versionprivate long version;//Constructors, builder class, and getters are omitted. }
  • 您可以從Github獲取Todo類的完整源代碼 。

另外,我們不應該使用構建器模式,因為在創建新的Todo對象時,我們的實體只有兩個String字段被設置。 但是,我在這里使用它是因為它使我們的測試更易于閱讀。

我們的Spring Data JPA存儲庫接口稱為TodoRepository ,它擴展了CrudRepository <T,ID擴展了Serializable>接口。 該存儲庫為Todo對象提供CRUD操作。 它還聲明了一種查詢方法,該方法返回其說明與給定搜索詞匹配的所有待辦事項條目。

TodoRepository接口的源代碼如下所示:

import org.springframework.data.repository.CrudRepository;public interface TodoRepository extends CrudRepository<Todo, Long> {List<Todo> findByDescription(String description); }

補充閱讀:

  • CrudRepository接口的Javadoc
  • Spring Data JPA教程
  • Spring Data JPA –參考文檔

讓我們繼續前進,了解在編寫用于從關系數據庫讀取信息或將信息保存到其中的代碼的集成測試時,如何處理空值。

處理空值

在為數據訪問代碼編寫集成測試時 ,我們必須在每個測試用例之前將數據庫初始化為已知狀態,并確保將正確的數據寫入數據庫。

本節確定了在編寫集成測試以解決我們遇到的問題

  • 使用平面XML數據集。
  • 將空值寫入數據庫,或確保表列的值為null 。

我們還將學習如何解決這些問題。

將空值插入數據庫

當我們編寫從數據庫讀取信息的集成測試時,我們必須在調用測試之前將該數據庫初始化為已知狀態,有時我們必須向數據庫中插入空值。

因為我們使用平面XML數據集,所以可以通過省略相應的屬性值將空值插入表列。 這意味著,如果我們想在todos表的description列中插入空值,則可以使用以下DbUnit數據集來做到這一點:

<dataset><todos id="1" title="FooBar" version="0"/> </dataset>

但是,通常我們必須在已使用的數據庫表中插入多行。 以下DbUnit數據集( todo-entries.xml )將兩行插入todos表:

<dataset><todos id="1" title="FooBar" version="0"/><todos id="2" description="description" title="title" version="0"/> </dataset>

讓我們找出對TodoRepository接口的findByDescription()方法編寫集成測試并使用先前的數據集( todo-entries.xml )初始化數據庫時會發生什么情況。 我們的集成測試的源代碼如下所示:

import com.github.springtestdbunit.DbUnitTestExecutionListener; import com.github.springtestdbunit.annotation.DatabaseSetup; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.TestExecutionListeners; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import org.springframework.test.context.support.DependencyInjectionTestExecutionListener; import org.springframework.test.context.support.DirtiesContextTestExecutionListener; import org.springframework.test.context.transaction.TransactionalTestExecutionListener;import static org.assertj.core.api.Assertions.assertThat;@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = {PersistenceContext.class}) @TestExecutionListeners({ DependencyInjectionTestExecutionListener.class,DirtiesContextTestExecutionListener.class,TransactionalTestExecutionListener.class,DbUnitTestExecutionListener.class }) public class ITTodoRepositoryTest {private static final Long ID = 2L;private static final String DESCRIPTION = "description";private static final String TITLE = "title";private static final long VERSION = 0L;@Autowiredprivate TodoRepository repository;@Test@DatabaseSetup("todo-entries.xml")public void findByDescription_ShouldReturnOneTodoEntry() {List<Todo> todoEntries = repository.findByDescription(DESCRIPTION);assertThat(todoEntries).hasSize(1);Todo found = todoEntries.get(0);assertThat(found.getId()).isEqualTo(ID);assertThat(found.getTitle()).isEqualTo(TITLE);assertThat(found.getDescription()).isEqualTo(DESCRIPTION);assertThat(found.getVersion()).isEqualTo(VERSION);} }

當運行此集成測試時,我們得到以下斷言錯誤:

java.lang.AssertionError: Expected size:<1> but was:<0> in: <[]>

這意味著從數據庫中找不到正確的待辦事項條目。 發生了什么? 我們的查詢方法是如此簡單,以至于它應該起作用,特別是因為在調用測試用例之前,我們已將正確的數據插入數據庫。

好吧,實際上兩行的描述列都是空的。 DbUnit常見問題說明了發生這種情況的原因 :

DbUnit使用表的第一個標記來定義要填充的列。 如果此表的以下記錄包含額外的列,那么將不會填充這些列。

它還提供了解決此問題的方法:

從DBUnit 2.3.0開始,有一種稱為“列感知”的功能,該功能基本上將整個XML讀入緩沖區,并在出現新列時動態添加它們。

我們可以通過反轉todos元素的順序來解決此問題,但這很麻煩,因為每次創建新數據集時我們都必須記住要做的事情。 我們應該使用列檢測,因為它消除了人為錯誤的可能性。

我們可以按照以下步驟啟用列檢測:

  • 創建一個擴展了AbstractDataSetLoader類的數據集加載器類。
  • 重寫AbstractDataSetLoader類的受保護的IDateSet createDataSet(Resource resource)方法。
  • 通過啟用列檢測并返回新的FlatXmlDataSet對象來實現此方法。
  • ColumnSensingFlatXmlDataSetLoader類的源代碼如下所示:

    import com.github.springtestdbunit.dataset.AbstractDataSetLoader; import org.dbunit.dataset.IDataSet; import org.dbunit.dataset.xml.FlatXmlDataSetBuilder; import org.springframework.core.io.Resource; import java.io.InputStream;public class ColumnSensingFlatXMLDataSetLoader extends AbstractDataSetLoader {@Overrideprotected IDataSet createDataSet(Resource resource) throws Exception {FlatXmlDataSetBuilder builder = new FlatXmlDataSetBuilder();builder.setColumnSensing(true);try (InputStream inputStream = resource.getInputStream()) {return builder.build(inputStream);}} }

    補充閱讀:

    • FlatXmlDataSet類的Javadoc

    現在,我們可以通過使用@DbUnitConfiguration批注注釋測試類并將其加載器屬性的值設置為ColumnSensingFlatXmlDataSetLoader.class,來配置測試類以使用此數據加載器 。

    我們的固定集成測試的源代碼如下所示:

    import com.github.springtestdbunit.DbUnitTestExecutionListener; import com.github.springtestdbunit.annotation.DatabaseSetup; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.TestExecutionListeners; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import org.springframework.test.context.support.DependencyInjectionTestExecutionListener; import org.springframework.test.context.support.DirtiesContextTestExecutionListener; import org.springframework.test.context.transaction.TransactionalTestExecutionListener;import static org.assertj.core.api.Assertions.assertThat;@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = {PersistenceContext.class}) @TestExecutionListeners({ DependencyInjectionTestExecutionListener.class,DirtiesContextTestExecutionListener.class,TransactionalTestExecutionListener.class,DbUnitTestExecutionListener.class }) @DbUnitConfiguration(dataSetLoader = ColumnSensingFlatXMLDataSetLoader.class) public class ITTodoRepositoryTest {private static final Long ID = 2L;private static final String DESCRIPTION = "description";private static final String TITLE = "title";private static final long VERSION = 0L;@Autowiredprivate TodoRepository repository;@Test@DatabaseSetup("todo-entries.xml")public void findByDescription_ShouldReturnOneTodoEntry() {List<Todo> todoEntries = repository.findByDescription(DESCRIPTION);assertThat(todoEntries).hasSize(1);Todo found = todoEntries.get(0);assertThat(found.getId()).isEqualTo(ID);assertThat(found.getTitle()).isEqualTo(TITLE);assertThat(found.getDescription()).isEqualTo(DESCRIPTION);assertThat(found.getVersion()).isEqualTo(VERSION);} }

    當我們第二次運行集成測試時,它通過了。

    讓我們找出如何驗證空值是否已保存到數據庫中。

    驗證表列的值是否為空

    在編寫將信息保存到數據庫的集成測試時,我們必須確保將正確的信息確實保存到數據庫,有時我們必須驗證表列的值為null 。

    例如,如果我們寫這證實了,當我們創建一個沒有描述一個待辦事項條目正確的信息保存到數據庫中的集成測試,我們必須確保一個空值插入到待辦事項表的說明列。

    我們的集成測試的源代碼如下所示:

    import com.github.springtestdbunit.DbUnitTestExecutionListener; import com.github.springtestdbunit.annotation.DatabaseSetup; import com.github.springtestdbunit.annotation.DbUnitConfiguration; import com.github.springtestdbunit.annotation.ExpectedDatabase; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.TestExecutionListeners; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import org.springframework.test.context.support.DependencyInjectionTestExecutionListener; import org.springframework.test.context.support.DirtiesContextTestExecutionListener; import org.springframework.test.context.transaction.TransactionalTestExecutionListener;import static org.assertj.core.api.Assertions.assertThat;@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = {PersistenceContext.class}) @TestExecutionListeners({ DependencyInjectionTestExecutionListener.class,DirtiesContextTestExecutionListener.class,TransactionalTestExecutionListener.class,DbUnitTestExecutionListener.class }) @DbUnitConfiguration(dataSetLoader = ColumnSensingFlatXMLDataSetLoader.class) public class ITTodoRepositoryTest {private static final String DESCRIPTION = "description";private static final String TITLE = "title";@Autowiredprivate TodoRepository repository;@Test@DatabaseSetup("no-todo-entries.xml")@ExpectedDatabase("save-todo-entry-without-description-expected.xml")public void save_WithoutDescription_ShouldSaveTodoEntryToDatabase() {Todo todoEntry = Todo.getBuilder().title(TITLE).description(null).build();repository.save(todoEntry);} }

    這不是一個很好的集成測試,因為它僅測試Spring Data JPA和Hibernate是否正常工作。 我們不應該通過為框架編寫測試來浪費時間。 如果我們不信任框架,則不應使用它。

    如果您想學習為數據訪問代碼編寫好的集成測試,則應該閱讀標題為: 編寫數據訪問代碼測試的教程。

    用于初始化數據庫的DbUnit數據集( no-todo-entries.xml )如下所示:

    <dataset><todos/> </dataset>

    因為我們沒有設置保存的todo條目的描述 ,所以todos表的description列應該為null 。 這意味著我們應該從數據集中省略它,以驗證是否將正確的信息保存到數據庫中。

    該數據集( save-todo-entry-without-description-expected.xml )如下所示:

    <dataset><todos id="1" title="title" version="0"/> </dataset>

    當我們運行集成測試時,它失敗,并且我們看到以下錯誤消息:

    junit.framework.ComparisonFailure: column count (table=todos, expectedColCount=3, actualColCount=4) Expected :[id, title, version] Actual :[DESCRIPTION, ID, TITLE, VERSION]

    問題在于DbUnit期望todos表僅具有id , title和version列。 這樣做的原因是,這些列是從數據集的第一行(也是唯一的行)中找到的唯一列。

    我們可以使用ReplacementDataSet解決此問題。 ReplacementDataSet是一個修飾器,它用替換對象替換從平面XML數據集文件中找到的占位符。 讓我們修改自定義的數據集加載類返回一個ReplacementDataSet對象替換“[空]”字符串與空 。

    我們可以通過對自定義數據集加載器進行以下更改來做到這一點:

  • 將私有的createReplacementDataSet()方法添加到數據集加載器類。 此方法返回一個ReplacementDataSet對象,并采用FlatXmlDataSet對象作為方法參數。
  • 通過創建新的ReplacementDataSet對象并返回創建的對象來實現此方法。
  • 修改createDataSet()方法以調用私有的createReplacementDataSet()方法并返回創建的ReplacementDataSet對象。
  • ColumnSensingReplacementDataSetLoader類的源代碼如下所示:

    import com.github.springtestdbunit.dataset.AbstractDataSetLoader; import org.dbunit.dataset.IDataSet; import org.dbunit.dataset.ReplacementDataSet; import org.dbunit.dataset.xml.FlatXmlDataSet; import org.dbunit.dataset.xml.FlatXmlDataSetBuilder; import org.springframework.core.io.Resource;import java.io.InputStream;public class ColumnSensingReplacementDataSetLoader extends AbstractDataSetLoader {@Overrideprotected IDataSet createDataSet(Resource resource) throws Exception {FlatXmlDataSetBuilder builder = new FlatXmlDataSetBuilder();builder.setColumnSensing(true);try (InputStream inputStream = resource.getInputStream()) {return createReplacementDataSet(builder.build(inputStream));}}private ReplacementDataSet createReplacementDataSet(FlatXmlDataSet dataSet) {ReplacementDataSet replacementDataSet = new ReplacementDataSet(dataSet);//Configure the replacement dataset to replace '[null]' strings with null.replacementDataSet.addReplacementObject("[null]", null);return replacementDataSet;} }

    補充閱讀:

    • IDataSet接口的最常用實現
    • ReplacementDataSet類的Javadoc

    我們可以按照以下步驟修復集成測試:

  • 通過使用ColumnSensingReplacementDataSetLoader類,配置我們的測試類以加載使用的DbUnit數據集。
  • 修改我們的數據集以驗證description列的值為null 。
  • 首先 ,我們必須配置測試類以使用ColumnSensingReplacementDataSetLoader類加載DbUnit數據集。 因為我們已經使用@DbUnitConfiguration注釋了測試類,所以我們必須將其loader屬性的值更改為ColumnSensingReplacementDataSetLoader.class 。

    固定測試類的源代碼如下所示:

    import com.github.springtestdbunit.DbUnitTestExecutionListener; import com.github.springtestdbunit.annotation.DatabaseSetup; import com.github.springtestdbunit.annotation.DbUnitConfiguration; import com.github.springtestdbunit.annotation.ExpectedDatabase; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.TestExecutionListeners; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import org.springframework.test.context.support.DependencyInjectionTestExecutionListener; import org.springframework.test.context.support.DirtiesContextTestExecutionListener; import org.springframework.test.context.transaction.TransactionalTestExecutionListener;import static org.assertj.core.api.Assertions.assertThat;@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = {PersistenceContext.class}) @TestExecutionListeners({ DependencyInjectionTestExecutionListener.class,DirtiesContextTestExecutionListener.class,TransactionalTestExecutionListener.class,DbUnitTestExecutionListener.class }) @DbUnitConfiguration(dataSetLoader = ColumnSensingReplacementDataSetLoader.class) public class ITTodoRepositoryTest {private static final String DESCRIPTION = "description";private static final String TITLE = "title";@Autowiredprivate TodoRepository repository;@Test@DatabaseSetup("no-todo-entries.xml")@ExpectedDatabase("save-todo-entry-without-description-expected.xml")public void save_WithoutDescription_ShouldSaveTodoEntryToDatabase() {Todo todoEntry = Todo.getBuilder().title(TITLE).description(null).build();repository.save(todoEntry);} }

    其次 ,我們必須驗證null值是否保存到todos表的description列中。 為此,我們可以向數據集中唯一的todos元素添加一個description屬性,并將description屬性的值設置為'[null]'。

    我們的固定數據集( save-todo-entry-without-description-expected.xml )如下所示:

    <dataset><todos id="1" description="[null]" title="title" version="0"/> </dataset>

    當我們運行集成測試時,它會通過。

    讓我們繼續并總結從這篇博客文章中學到的知識。

    摘要

    這篇博客文章教會了我們四件事:

    • DbUnit假定數據庫表僅包含從指定表行的列的第一個標記中找到的那些列。 如果要覆蓋此行為,則必須啟用DbUnit的列感測功能。
    • 如果要確保將null值保存到數據庫,則必須使用替換數據集。
    • 我們學習了如何創建自定義數據集加載器,以創建替換數據集并使用列感測。
    • 我們了解了如何配置用于加載DbUnit數據集的數據集加載器。

    您可以從Github獲得此博客文章的示例應用程序 。

    翻譯自: https://www.javacodegeeks.com/2014/11/spring-from-the-trenches-using-null-values-in-dbunit-datasets.html

    dbunit使用

    創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

    總結

    以上是生活随笔為你收集整理的dbunit使用_摆脱困境:在DbUnit数据集中使用空值的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    一区二区三区精品久久久 | 中文字幕在线国产精品 | 狠狠狠色丁香综合久久天下网 | 日韩av专区 | 成人av久久 | 欧美a在线免费观看 | 国产色在线,com | 丰满少妇对白在线偷拍 | 娇妻呻吟一区二区三区 | 91九色国产视频 | 99国产视频在线 | 国产va精品免费观看 | 亚洲视频免费在线观看 | v片在线看| 一区 二区 精品 | av一区在线 | 99精品热视频只有精品10 | 中文字幕av影院 | 麻豆免费在线播放 | 精品在线观看一区二区三区 | 日本电影黄色 | 婷婷在线色 | 欧美极度另类 | 不卡的av在线 | 国产成人在线免费观看 | 亚州国产精品视频 | 亚洲精品黄色在线观看 | 天天干天天操天天入 | 六月婷色 | 久久综合爱 | 91香蕉视频好色先生 | 成人av电影在线观看 | 国产精品美女久久久久久久久久久 | 久久男人免费视频 | 国产成人精品免费在线观看 | 亚洲国产片色 | 天天色天天草天天射 | 婷婷激情网站 | 免费视频三区 | 久久久久国产a免费观看rela | 久久久久观看 | 最近2019好看的中文字幕免费 | av永久网址| 亚洲视频在线免费看 | 黄p在线播放 | 国产精品毛片一区二区在线 | 国产视频日韩 | 亚洲a色| 五月婷婷深开心 | 久久精品久久精品久久39 | 久久精品视频中文字幕 | www夜夜| 国产高清不卡一区二区三区 | 久久开心激情 | 久久国精品| 人人射 | 我要色综合天天 | 91亚洲国产成人 | 91激情视频在线观看 | 亚洲免费在线看 | 免费在线观看a v | 免费日韩一区二区三区 | 国内外成人免费在线视频 | 91污污视频在线观看 | 久久伦理| 狠狠色丁香婷婷综合久小说久 | 国产九九精品视频 | 免费国产在线精品 | 国产精品国产三级在线专区 | 日本一区二区不卡高清 | 久久久亚洲麻豆日韩精品一区三区 | 国产成人精品综合久久久 | 国产玖玖精品视频 | 日本特黄特色aaa大片免费 | 亚洲视频在线视频 | 日韩精品高清视频 | 天天玩夜夜操 | 国产日韩精品在线观看 | 91久久人澡人人添人人爽欧美 | 99视频网站 | 久久99深爱久久99精品 | 欧美一级片 | 手机色站 | 五月婷婷激情六月 | 成av在线| 99在线观看 | 久久欧洲视频 | 91色在线观看视频 | 国产午夜精品av一区二区 | 97免费视频在线播放 | 久草视频一区 | 国内精品久久久久久久影视简单 | 国产美女在线精品免费观看 | 在线观看国产www | 麻豆网站免费观看 | 制服丝袜一区二区 | av三级av| 激情丁香综合 | 免费观看av网站 | 国产成人精品综合久久久久99 | 成人小视频在线观看免费 | 久久久96| 美女网站在线看 | 日韩性片 | 日韩肉感妇bbwbbwbbw | 91成人免费看片 | 一区二区三区久久精品 | 五月婷婷丁香六月 | 日韩精品在线看 | 中文字幕乱码在线播放 | 亚洲午夜精品福利 | 日韩一区正在播放 | 国产第一页精品 | 色五月色开心色婷婷色丁香 | 在线播放国产一区二区三区 | 久久久久久麻豆 | 精品在线亚洲视频 | 欧美激情视频三区 | 日本3级在线观看 | 亚洲精品乱码久久久久久蜜桃91 | 成人av av在线| 国产黄色成人av | 手机色在线 | 免费av影视 | 在线观看视频福利 | 国内精品久久久久久 | 911精品美国片911久久久 | 日韩欧美在线不卡 | 国产小视频91 | 六月色丁香| 2019中文字幕第一页 | 国产视频一区二区三区在线 | 久久久久国产精品免费免费搜索 | 视频国产在线 | 亚洲乱码中文字幕综合 | 国产黄a三级 | 久久久亚洲网站 | 国产日韩欧美在线 | 亚洲理论在线观看电影 | 日韩美在线 | 97视频在线观看播放 | 夜夜躁日日躁狠狠躁 | 九色91av| 三级动态视频在线观看 | 亚洲视频免费在线看 | 久久不射电影院 | 日韩城人在线 | 91av大全| 一本一本久久a久久精品综合妖精 | 91精品欧美一区二区三区 | 美州a亚洲一视本频v色道 | 久久精品视频国产 | 97在线观看免费高清完整版在线观看 | 久久影院午夜论 | 国产精品欧美久久久久三级 | 日日夜夜人人精品 | 在线免费视频一区 | 日韩欧美国产精品 | 久久久久久久久综合 | 精品人人爽 | 麻豆国产精品永久免费视频 | 国产二级视频 | 嫩草av在线 | 1024手机在线看 | 岛国一区在线 | av在线电影免费观看 | 毛片网在线播放 | 99热这里只有精品国产首页 | 少妇性xxx | 人人干在线 | 国产九九热 | 欧美成人a在线 | 人人舔人人爱 | 在线观看中文字幕2021 | 91视视频在线直接观看在线看网页在线看 | 国产69精品久久久久99 | bbb搡bbb爽爽爽 | 久久蜜臀一区二区三区av | 欧美贵妇性狂欢 | 日本三级不卡 | 成人免费观看视频网站 | 久久精品1区 | 精品久久久久久久久久久久久久久久久久 | 人人插人人搞 | 亚洲a成人v | 亚洲另类视频 | 在线成人高清电影 | 免费观看一区二区三区视频 | 日韩av一区二区在线播放 | 粉嫩av一区二区三区四区 | 精品一区精品二区 | 中文字幕第一页在线 | 久草a视频 | www.色爱 | 精品国产_亚洲人成在线 | 欧美日韩国产成人 | 91麻豆精品国产自产在线 | 91麻豆精品国产自产在线 | 免费日韩一级片 | 成人av av在线| 精品国产乱码一区二 | 国产视频在线观看一区二区 | 91影视成人 | 久久久久免费精品国产 | 成人a视频片观看免费 | 欧美日韩国产一二 | 81精品国产乱码久久久久久 | 国产精品毛片完整版 | 日本久久电影 | 精品一区二区久久久久久久网站 | 国产精品自产拍在线观看蜜 | 午夜10000| 国产精品欧美久久久久天天影视 | 色a在线观看 | 正在播放国产一区 | 视频在线99| 日韩在线免费观看视频 | 国产一区福利在线 | 亚洲视频一区二区三区在线观看 | 又黄又爽又色无遮挡免费 | 欧美十八 | 五月婷婷丁香激情 | 日韩一区二区三区免费电影 | 在线观看国产福利片 | 韩国精品在线观看 | 特级xxxxx欧美 | 国内精品久久久久影院男同志 | 在线中文字幕av观看 | 成人毛片久久 | 精品福利av | 午夜精品99久久免费 | 99九九免费视频 | av免费在线观 | 成人午夜免费福利 | 国产一区二区在线播放视频 | 天天干天天综合 | 久久激情五月激情 | 超碰日韩 | 99精品免费在线 | 久草在线资源网 | 中文字幕亚洲不卡 | 欧美精品在线观看免费 | 日本久久综合网 | 日韩精品免费一区二区三区 | 天天射天天色天天干 | 青青网视频 | 99精品热视频只有精品10 | 天天干一干| 精品在线99 | 国产成人精品久久亚洲高清不卡 | 狠狠色狠狠色综合日日92 | 久久色视频| 91在线区| 中文字幕中文字幕中文字幕 | 亚洲精品午夜久久久久久久 | 久久字幕精品一区 | 超碰在线最新 | 日本中文字幕视频 | 午夜精品中文字幕 | 久久在线播放 | 欧美亚洲三级 | 日韩精品电影在线播放 | 亚洲精品乱码久久久久久蜜桃欧美 | 国产成人一区二区三区久久精品 | 欧美日韩亚洲在线观看 | 精品三级av | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 在线观看电影av | 天天久久夜夜 | 久久久久久蜜av免费网站 | 天天射天天射天天射 | 超碰在线9 | 久久国产精品第一页 | 99久久国产免费,99久久国产免费大片 | 丁香六月av| 久久精品美女视频 | 欧美福利视频一区 | 最近中文字幕国语免费av | 日本精a在线观看 | 成人综合免费 | 日韩欧美一区二区三区视频 | 伊人五月天综合 | 伊人伊成久久人综合网站 | 91在线视频 | 国产视频18 | 午夜精品电影一区二区在线 | av一区二区三区在线播放 | 婷婷六月激情 | 色网免费观看 | 亚州av一区 | 五月婷婷欧美视频 | 日韩欧美亚洲 | aaa日本高清在线播放免费观看 | 亚洲精品国产综合99久久夜夜嗨 | 日韩av网站在线播放 | 在线观看av国产 | 99草在线视频 | 永久免费观看视频 | 在线综合 亚洲 欧美在线视频 | 欧美日韩国产在线一区 | 91探花视频| 国产中文字幕久久 | 久草在线免费播放 | 亚洲精品88欧美一区二区 | 久久成人欧美 | 成人免费观看视频大全 | 久草视频手机在线 | 免费能看的黄色片 | 最近日本韩国中文字幕 | 久久久久久久久久福利 | 极品中文字幕 | 久久久久久国产精品美女 | 亚洲黄色免费电影 | 免费看网站在线 | 欧美在线aa| 久久精品免费观看 | 亚洲精品成人网 | 久草在线精品观看 | 在线视频欧美精品 | 日韩久久精品一区二区 | 蜜臀av性久久久久av蜜臀三区 | 在线观看黄av | av久久久 | 99麻豆久久久国产精品免费 | 国产伦理久久精品久久久久_ | 欧美91精品久久久久国产性生爱 | 91中文在线视频 | 国产日韩欧美自拍 | 色香天天 | 日韩网站中文字幕 | 国产91亚洲精品 | 6080yy精品一区二区三区 | 色综合久久88色综合天天人守婷 | 91视频xxxx| 精品国产亚洲在线 | 亚洲在线网址 | 91av国产视频 | 四虎成人精品永久免费av | 99久久er热在这里只有精品66 | 亚洲国产美女久久久久 | 黄色毛片电影 | 91精品在线免费 | 色婷婷狠狠 | 国内精品久久久久久久久久清纯 | 欧美亚洲专区 | 黄色免费网站下载 | 欧美精品网站 | 一区二区三区在线免费 | 五月婷婷丁香六月 | 欧美日韩在线精品 | 97视频久久久 | 激情综合网五月 | 在线免费av电影 | 国内精品视频在线播放 | 国产精品11 | 四虎国产精品免费观看视频优播 | 精品久久免费 | 国产一级片网站 | 在线免费观看羞羞视频 | 婷婷网在线| 91视频国产免费 | 五月导航| 91成人免费观看视频 | 久久人人爽人人人人片 | 操操操干干干 | 日韩免费成人av | 成人黄色电影在线 | 欧美在线观看视频一区二区 | 九九在线高清精品视频 | 中文字幕在线色 | 国产精品ⅴa有声小说 | 中文字幕最新精品 | 国产精品午夜久久 | 中文字幕在线播出 | 91福利试看| 91精品91| 日韩免费av片 | 日韩毛片在线播放 | 在线视频欧美精品 | 天天要夜夜操 | 亚洲经典视频在线观看 | 91亚洲精品久久久 | 国产精品网红直播 | 8x8x在线观看视频 | 久久久久国产a免费观看rela | 亚洲欧洲精品一区二区 | 精品国产一区二区三区日日嗨 | av片子在线观看 | 亚洲精选在线观看 | 四虎影视8848aamm| 又黄又爽又色无遮挡免费 | 国产精品久久久久久久久久久久午夜片 | 欧美一级看片 | 久草在线资源观看 | 免费av小说 | 韩国一区二区三区在线观看 | 国产在线一区二区三区播放 | 999超碰 | 久久与婷婷 | 久久一区二区三区四区 | 日韩电影在线看 | 中文字幕2021 | 成人午夜电影网 | 久久午夜免费视频 | 美女久久久久久久 | 日本性生活免费看 | 中文字幕久久网 | 99精品国产兔费观看久久99 | 日韩av偷拍| 亚洲美女免费精品视频在线观看 | 日韩精品短视频 | 在线成人国产 | 国产精品久久久久永久免费观看 | 天天色天天草天天射 | 久久这里有精品 | 亚洲国产中文在线观看 | 三级黄在线 | 国产精品亚 | 一区 二区 精品 | 日韩精品一区二区三区第95 | 国内精品久久久久影院日本资源 | 久久激情五月激情 | av一级一片 | 久草香蕉在线视频 | 日韩免费视频网站 | 黄色影院在线免费观看 | 欧美一级性生活 | 免费a网站 | 色www免费视频 | 综合久久久久 | 亚洲女欲精品久久久久久久18 | 国产麻豆精品传媒av国产下载 | 国产精品美女免费看 | 久久视频精品在线观看 | 国产精品久久精品国产 | av在线中文 | 日韩美精品视频 | 久久99视频免费 | 欧美aa在线 | 欧美激情xxxx性bbbb | 波多野结衣视频一区二区 | 久久色在线播放 | 国产午夜精品一区二区三区在线观看 | 美女精品久久久 | 一区二区不卡视频在线观看 | 中文字幕一区二区三 | 欧美极品xxxxx | 国产在线观看免 | 操操操夜夜操 | 久久人人爽人人片 | 在线视频 日韩 | 天天爱天天干天天爽 | 午夜精品成人一区二区三区 | 在线播放国产一区二区三区 | 有码中文在线 | 激情视频在线高清看 | 色婷婷色 | 九九亚洲精品 | 97成人精品视频在线播放 | 日日婷婷夜日日天干 | 玖玖999| 久草久| 欧洲精品视频一区 | 玖玖在线看 | 午夜12点| 久草精品在线播放 | 伊人看片 | 国产精品12 | 午夜免费视频网站 | 夜夜澡人模人人添人人看 | 久久久久人人 | 欧美日韩午夜爽爽 | 亚洲天堂香蕉 | 国产一级片免费视频 | 国产精品中文久久久久久久 | 婷婷丁香导航 | 美女黄频在线观看 | 成人av电影免费在线播放 | 久草线| 波多野结衣日韩 | 婷婷久久一区二区三区 | 婷婷久久网 | 808电影免费观看三年 | 丁香视频全集免费观看 | 黄色tv视频 | 免费观看一级特黄欧美大片 | 在线视频 国产 日韩 | 黄色一区三区 | 久久综合爱 | 狠色在线 | 欧美大香线蕉线伊人久久 | 日韩三级久久 | 激情网第四色 | 久草手机视频 | 黄色一级大片在线免费看国产一 | 国产剧情一区在线 | 中文字幕色综合网 | 在线观看黄a | 欧美91精品久久久久国产性生爱 | 天天插天天操天天干 | 亚洲国产视频在线 | 中文字幕在线观看免费高清完整版 | 亚洲国产97在线精品一区 | 免费精品在线观看 | av九九九 | 91九色视频导航 | 91精选在线观看 | 日本三级久久 | 成人三级黄色 | 国产精品毛片一区二区 | 国产精品午夜8888 | 国产成人久久精品一区二区三区 | 天天操天天操天天 | www.综合网.com | 国产美女精品视频 | 亚洲视频在线免费看 | 欧美日韩视频免费 | 精品久久久久久久 | 中文字幕第一页在线 | 日韩视频一区二区三区 | 国内精品久久久久久久影视简单 | 美女在线免费观看视频 | 国产精品一区久久久久 | 久久精久久精 | 亚洲一级电影在线观看 | 天天婷婷| 亚洲精品国产精品国自产观看 | 免费日韩| 99视频在线免费观看 | 免费婷婷 | 91精选| 亚洲成人黄色在线 | 亚洲干 | 婷婷久久婷婷 | 色噜噜色噜噜 | 欧美一区二区三区在线看 | 免费又黄又爽 | 亚洲欧美日韩精品久久奇米一区 | 久久久久久国产精品亚洲78 | 亚洲资源在线观看 | 999国内精品永久免费视频 | avwww在线 | 99免在线观看免费视频高清 | 四虎国产精品免费观看视频优播 | 麻豆91在线看 | 狠狠色噜噜狠狠狠狠2021天天 | 国产福利免费在线观看 | 国产剧情av在线播放 | 激情婷婷六月 | 香蕉影院在线观看 | www.97色.com | 亚洲午夜久久久影院 | 中文字幕国语官网在线视频 | 色就干| 欧美极品xxxx | 午夜美女网站 | 天天综合人人 | 狠狠干夜夜操天天爽 | 中文字幕一区二区三区精华液 | 成人av在线播放网站 | 日韩中文幕 | 天天干天天玩天天操 | 日韩系列 | 久久综合欧美 | 成人黄色片免费 | 久久久久亚洲精品男人的天堂 | 91传媒激情理伦片 | 亚洲a资源 | 国产在线看一区 | 人人舔人人射 | 日韩三级成人 | av片在线观看 | 色先锋av资源中文字幕 | 中文字幕91| 亚洲一二三区精品 | 国产精品免费观看国产网曝瓜 | 免费在线观看中文字幕 | 在线免费高清一区二区三区 | 天天干,天天草 | 亚洲国产av精品毛片鲁大师 | 久久女教师 | 操一草| 性色va| 天堂av官网 | 国产成人精品免费在线观看 | www久久| 免费在线一区二区 | 97超碰在线免费观看 | 91成人亚洲 | 国产91精品久久久久 | 婷婷丁香色综合狠狠色 | 久久久国产一区二区 | 五月婷婷视频在线观看 | 亚洲国产免费 | 91精品在线免费观看视频 | 在线亚洲免费视频 | 欧美男男激情videos | 色99视频| 在线中文字幕av观看 | 国产黄色精品网站 | 久久久亚洲麻豆日韩精品一区三区 | 欧美一区日韩精品 | 中文av不卡| 亚洲国产成人久久综合 | 日本黄色大片免费看 | 最近中文字幕在线播放 | 在线免费国产视频 | 国产人免费人成免费视频 | 免费人成网ww44kk44 | 午夜精品视频福利 | 丝袜制服天堂 | 色综合久久88色综合天天 | 久久免费毛片 | www.99av| 国产精品久久久久久影院 | 九九在线播放 | 日韩在线视频免费播放 | 午夜国产一区二区 | 国产精品一区二区中文字幕 | 91免费网站在线观看 | 九九亚洲精品 | 国产不卡免费 | 97操操| 波多野结衣在线观看视频 | 夜色成人av | 天天操天天爱天天干 | 韩国一区二区三区视频 | 国产精品亚洲视频 | 天天亚洲 | 毛片网在线播放 | 黄色毛片一级 | 亚洲高清视频在线观看免费 | 黄色a视频 | 亚洲在线视频播放 | 在线天堂中文在线资源网 | 成人av在线资源 | 久久久久亚洲国产 | 国产中文视 | 伊人va| 国产精品视频大全 | 97超碰在| 国内精品一区二区 | 欧美一区二区三区在线观看 | 美女网站视频免费黄 | 人人澡人人爱 | 天天操夜夜逼 | 国产精品一区一区三区 | 美女国产在线 | 久久成人免费电影 | 日韩专区在线观看 | 中文字幕在线国产精品 | 久久久久草 | 天天干天天上 | 69av免费视频 | 天天天综合 | 亚洲一级电影 | 豆豆色资源网xfplay | 亚洲午夜剧场 | 特级黄色电影 | 日韩电影在线一区 | 91免费看黄 | 成人三级网站在线观看 | v片在线看 | 免费在线观看黄色网 | 黄色网址a | 久久久久久久久久影院 | 一 级 黄 色 片免费看的 | 国产精品短视频 | 五月婷婷婷婷婷 | 婷色| 国产精品ssss在线亚洲 | 久久只精品99品免费久23小说 | 91九色pron| 91久久人澡人人添人人爽欧美 | 亚洲精品伦理在线 | 欧美一级片免费 | 99热这里只有精品国产首页 | 日韩欧美综合精品 | 永久免费精品视频 | 久草视频在线免费看 | 91麻豆国产福利在线观看 | 奇米7777狠狠狠琪琪视频 | 精品国自产在线观看 | 探花视频在线观看免费 | 黄色小说免费观看 | 国产香蕉视频在线播放 | 91天堂素人约啪 | 天天爱天天操天天干 | 日韩理论在线播放 | 91在线观看黄 | 久久美女精品 | 久久综合偷偷噜噜噜色 | 九九九热精品免费视频观看网站 | 日韩大片在线播放 | 深爱激情av | 国产高清中文字幕 | 亚洲精品日韩一区二区电影 | 亚洲欧美视频 | 麻豆久久一区二区 | 黄色小网站免费看 | 国产日韩视频在线播放 | 天天干.com| 国产精品手机视频 | 国产第一福利网 | 91在线麻豆 | 亚洲国产精品99久久久久久久久 | 精品视频免费看 | 久久久久亚洲天堂 | 国产一级免费播放 | 久草爱视频 | 在线国产91 | 欧美久久久久久久久久久久久 | 欧美一二三四在线 | 日韩欧美在线观看一区二区三区 | www国产亚洲 | 国产97在线看 | 91精品国自产在线 | 国产精品毛片一区视频播不卡 | 91精品国产乱码 | 97超碰在线资源 | 蜜桃视频成人在线观看 | 毛片美女网站 | 国产视频在线免费观看 | 最近中文字幕在线中文高清版 | 国产精品自产拍在线观看桃花 | 免费看十八岁美女 | 久精品在线观看 | 亚洲欧美在线综合 | 菠萝菠萝蜜在线播放 | 在线电影日韩 | 香蕉视频国产在线观看 | 久草网在线观看 | 永久免费视频国产 | 在线观看国产日韩 | 中文字幕国产视频 | 久久久国产精品视频 | 91午夜精品 | 久二影院| 久久综合色婷婷 | 亚洲人成在 | 99久久影院 | 国产aaa免费视频 | 91网页版在线观看 | 日本精品在线看 | 97视频免费在线看 | 亚洲粉嫩av| www麻豆视频 | 草樱av | 久久精品久久精品久久 | 国产精品美女久久久久久2018 | 成片免费观看视频大全 | 国产成人一区二区三区在线观看 | 超碰免费在线公开 | 精品福利网 | 日韩av一区二区在线影视 | 国产在线国偷精品产拍免费yy | 天天操夜夜操国产精品 | 在线视频欧美亚洲 | 五月天激情开心 | 国产电影一区二区三区四区 | av片子在线观看 | 亚洲精品成人免费 | 99热播精品| 久久99亚洲网美利坚合众国 | 在线观看中文字幕av | 91在线视频观看 | 欧美一区二区在线免费看 | 黄色国产在线观看 | 视频一区二区国产 | 久久天堂网站 | 天堂资源在线观看视频 | 国色综合 | 97超碰色 | 毛片的网址 | 特黄特色特刺激视频免费播放 | 亚洲综合在线五月天 | 久久久久99精品国产片 | 一区二精品 | 中文在线a∨在线 | 五月婷婷激情五月 | 一区二区激情视频 | 久久在线精品 | 一区 在线 影院 | 欧美日韩国产色综合一二三四 | 国产在线不卡精品 | 午夜精品久久久 | 国产日韩欧美自拍 | av在线在线 | 日韩在线视频观看 | 国产二区免费视频 | 97精品在线视频 | 中文字幕在线观看一区二区三区 | 亚洲欧美一区二区三区孕妇写真 | 国产亚州av | 国产精品色婷婷视频 | 国产精品国产自产拍高清av | 国产一区不卡在线 | 四虎国产精品免费 | 西西www444 | 国产亚洲精品成人 | 欧美日韩国产一区 | 丁香五香天综合情 | 一区二区三区免费在线观看 | 国产精品二区在线观看 | 成人一区二区在线观看 | 国产激情小视频在线观看 | 免费看黄在线观看 | 在线观看岛国片 | 亚洲亚洲精品在线观看 | 成人h在线 | 日韩视频在线不卡 | www九九热 | 天天操天天舔天天爽 | 中文欧美字幕免费 | 国产精品久久久久一区二区三区共 | 最新中文字幕在线观看视频 | 伊人久久一区 | 精品国产视频一区 | 99re久久资源最新地址 | 中文字幕在线观看第一区 | 91中文字幕在线 | 免费观看mv大片高清 | 国产在线观看 | 国产日韩精品欧美 | 91在线视频导航 | 精品久久久免费视频 | 天天操天| 日韩精品免费一区二区 | 国产69久久久 | 亚洲精品午夜视频 | 国产91精品欧美 | 国产免费一区二区三区最新 | 国产中文字幕网 | 久久久福利影院 | 人人澡超碰碰97碰碰碰软件 | 激情亚洲综合在线 | 日本精品免费看 | 欧美性生活一级片 | 国产精品久久99精品毛片三a | 一区二区三区精品久久久 | 又色又爽又激情的59视频 | 亚洲爽爽网 | 国产亚洲精品久久久久久电影 | 麻豆传媒视频在线播放 | 久久这里只有精品视频99 | 成人毛片100免费观看 | 日韩精品中文字幕久久臀 | 美女网站在线免费观看 | av官网在线 | 午夜精品电影 | 亚洲最大免费成人网 | 在线亚洲欧美视频 | 青草视频免费观看 | 亚洲成年人免费网站 | 国产剧在线观看片 | 亚洲午夜av | 中文字幕制服丝袜av久久 | 亚洲色五月 | 中文字幕成人av | 麻豆国产精品永久免费视频 | 色小说av | 亚洲精品成人 | 免费99| 中文字幕.av.在线 | 欧美热久久| 日本女人在线观看 | 亚洲涩涩网 | 日韩av成人在线观看 | 特级黄色一级 | 午夜av日韩| 亚洲国产网站 | 国产999在线观看 | 国产成a人亚洲精v品在线观看 | 国产香蕉视频 | 久久av黄色 | 久久久午夜视频 | 在线小视频你懂得 | 亚洲成人午夜av | 亚洲砖区区免费 | 精品国产伦一区二区三区观看方式 | 久久99国产精品自在自在app | 91 在线视频播放 | 99热99| 国产精品美女久久久久久久网站 | 免费亚洲视频在线观看 | 日韩最新中文字幕 | 五月开心网 | 中文字幕在线人 | 欧美另类人妖 | 久久99国产综合精品 | 久久久久久久久久久网站 | 黄色在线成人 | 免费黄色a级毛片 | 国产亚洲欧美在线视频 | 成年人视频在线免费播放 | 操操操干干干 | av手机在线播放 | 在线精品亚洲一区二区 | 黄色小网站在线 | 欧美综合在线视频 | 日韩亚洲国产精品 | 亚洲第一区在线观看 | 黄色成人免费电影 | 99亚洲精品在线 | 欧美一级片免费观看 | 亚洲午夜久久久久久久久电影网 | 久久成人国产精品一区二区 | 四虎影视av | 波多野结衣电影久久 | 天天射天天做 | 久久久91精品国产一区二区三区 | 国产va饥渴难耐女保洁员在线观看 | 色综合天天狠天天透天天伊人 | 天天操比| 日韩网站免费观看 | 亚洲国产午夜视频 | 国产一级电影网 | 天天透天天插 | 午夜黄色一级片 | 久久 亚洲视频 | 欧美坐爱视频 | 在线观看久草 | 中文字幕一区在线 | 中文字幕在线观看2018 | 99电影| 亚洲国产成人在线 | 高清一区二区三区av | 二区三区在线视频 | 欧美精品三级 | 久久一久久 | 国产亚洲激情视频在线 | 中文区中文字幕免费看 | 国产精品麻豆91 | 日日添夜夜添 | 成人一区二区在线 | 九九热免费观看 | 在线观看色网 | 又黄又刺激视频 | 91综合久久一区二区 | 免费黄a大片| 国产精品美女久久久久久久 | 极品美女被弄高潮视频网站 | 日韩理论电影在线观看 | 精品人人爽 | 天天天天天天操 | 五月婷婷丁香色 | 欧美一级激情 | 性色av香蕉一区二区 | 国产精品一区二区三区免费视频 | av超碰在线 | 国产成人av综合色 | 碰超在线观看 | 免费成人在线电影 | 91九色蝌蚪视频 | 9797在线看片亚洲精品 | 最新日韩视频在线观看 | 国产精品永久久久久久久www | 国产专区在线视频 | 国产一区二区三区高清播放 | 麻豆91小视频 | 欧美激情va永久在线播放 | av在线播放国产 | 娇妻呻吟一区二区三区 | 精品国产一二三 | 日韩欧美高清视频在线观看 | 人人插人人搞 | 国产成人a亚洲精品 | 丁香资源影视免费观看 | 色综合天天狠天天透天天伊人 | 国产成人一区二区三区电影 | 三上悠亚一区二区在线观看 | 国产精品高清免费在线观看 | av久久在线 | 欧美片一区二区三区 | 国产xxxxx在线观看 | 天堂麻豆| 国产精品第一页在线 | 国产成人99久久亚洲综合精品 | 99自拍视频在线观看 | 成年人在线免费看视频 | 高清免费av在线 | 人人爽人人爽av | 成人av网址大全 | 久久草草影视免费网 | 中文av在线播放 | 久久久久久久网 | 久久试看 | 国产 日韩 欧美 在线 | 欧美成人a在线 | 久久久观看 | 99人久久精品视频最新地址 | 五月天六月丁香 | 午夜 久久 tv | 国产视频一级 | 97视频在线免费播放 | 国产精品欧美久久久久久 | www.天天成人国产电影 | 夜夜摸夜夜爽 |