黄a在线观看-黄a在线-黄a大片-黄色片在线看-黄色毛片免费-黄色大片网站

您的位置:首頁技術文章
文章詳情頁

Python reques接口測試框架實現代碼

瀏覽:3日期:2022-07-16 10:34:29

一、框架菜單

Python reques接口測試框架實現代碼

1.1 common模塊

Python reques接口測試框架實現代碼

1.2 其他

Python reques接口測試框架實現代碼

二、Excel接口測試案例編寫

Python reques接口測試框架實現代碼

Python reques接口測試框架實現代碼

三、讀取Excel測試封裝(核心封裝)

excel_utils.py 讀取Excel中的數據

import osimport xlrd #內置模塊、第三方模塊pip install 自定義模塊class ExcelUtils(): def __init__(self,file_path,sheet_name): self.file_path = file_path self.sheet_name = sheet_name self.sheet = self.get_sheet() # 整個表格對象 def get_sheet(self): wb = xlrd.open_workbook(self.file_path) sheet = wb.sheet_by_name(self.sheet_name) return sheet def get_row_count(self): row_count = self.sheet.nrows return row_count def get_col_count(self): col_count = self.sheet.ncols return col_count def __get_cell_value(self,row_index, col_index): cell_value = self.sheet.cell_value(row_index,col_index) return cell_value def get_merged_info(self): merged_info = self.sheet.merged_cells return merged_info def get_merged_cell_value(self,row_index, col_index): '''既能獲取普通單元格的數據又能獲取合并單元格數據''' cell_value = None for (rlow, rhigh, clow, chigh) in self.get_merged_info(): if (row_index >= rlow and row_index < rhigh):if (col_index >= clow and col_index < chigh): cell_value = self.__get_cell_value(rlow, clow) break; # 防止循環去進行判斷出現值覆蓋的情況else: cell_value = self.__get_cell_value(row_index, col_index) else:cell_value = self.__get_cell_value(row_index, col_index) return cell_value def get_sheet_data_by_dict(self): all_data_list = [] first_row = self.sheet.row(0) #獲取首行數據 for row in range(1, self.get_row_count()): row_dict = {} for col in range(0, self.get_col_count()):row_dict[first_row[col].value] = self.get_merged_cell_value(row, col) all_data_list.append(row_dict) return all_data_listif __name__==’__main__’: current_path = os.path.dirname(__file__) excel_path = os.path.join( current_path,’..’,’samples/data/test_case.xlsx’ ) excelUtils = ExcelUtils(excel_path,'Sheet1') for row in excelUtils.get_sheet_data_by_dict(): print( row )

import osfrom common.excel_utils import ExcelUtilsfrom common.config_utils import configcurrent_path = os.path.dirname(__file__)test_data_path = os.path.join( current_path,’..’, config.CASE_DATA_PATH )class TestdataUtils(): def __init__(self,test_data_path = test_data_path): self.test_data_path = test_data_path self.test_data = ExcelUtils(test_data_path,'Sheet1').get_sheet_data_by_dict() self.test_data_by_mysql = SqlUtils().get_mysql_test_case_info() def __get_testcase_data_dict(self): testcase_dict = {} for row_data in self.test_data: testcase_dict.setdefault( row_data[’測試用例編號’],[] ).append( row_data ) return testcase_dict def def_testcase_data_list(self): testcase_list = [] for k,v in self.__get_testcase_data_dict().items(): one_case_dict = {} one_case_dict['case_id'] = k one_case_dict['case_info'] = v testcase_list.append( one_case_dict ) return testcase_listif __name__=='__main__': testdataUtils = TestdataUtils() for i in testdataUtils.def_testcase_data_list(): print( i )

testdata_utils.py 讀取Excel中的數據后處理成需要的數據

四、request封裝(核心封裝)

requests_utils.py 包含post請求,get請求,異常,調用斷言

import astimport reimport requestsimport jsonpathfrom requests.exceptions import RequestExceptionfrom requests.exceptions import ProxyErrorfrom requests.exceptions import ConnectionErrorfrom common.config_utils import configfrom common.check_utils import CheckUtilsclass RequestsUtils(): def __init__(self): self.hosts = config.hosts self.headers = {'ContentType':'application/json;charset=utf-8'} self.session = requests.session() self.temp_variables = {} def __get(self,get_info): try: url = self.hosts + get_info['請求地址'] response = self.session.get( url = url, params = ast.literal_eval(get_info['請求參數(get)']) ) response.encoding = response.apparent_encoding if get_info['取值方式'] == 'json取值':value = jsonpath.jsonpath( response.json(),get_info['取值代碼'] )[0]self.temp_variables[ get_info['傳值變量'] ] = value elif get_info['取值方式'] == '正則取值':value = re.findall(get_info['取值代碼'],response.text)[0]self.temp_variables[get_info['傳值變量']] = value result = CheckUtils(response).run_check(get_info[’期望結果類型’], get_info[’期望結果’]) except ProxyError as e: result = {’code’: 4, ’result’: ’[%s]請求:代理錯誤異常’ % (get_info['接口名稱'])} except ConnectionError as e: result = {’code’: 4, ’result’: ’[%s]請求:連接超時異常’ % (get_info['接口名稱'])} except RequestException as e: result = {’code’: 4, ’result’: ’[%s]請求:Request異常,原因:%s’ % (get_info['接口名稱'], e.__str__())} except Exception as e: result = {’code’:4,’result’:’[%s]請求:系統異常,原因:%s’%(get_info['接口名稱'],e.__str__())} return result def __post(self,post_info): try: url = self.hosts + post_info['請求地址'] response = self.session.post( url = url, headers = self.headers, params = ast.literal_eval(post_info['請求參數(get)']), # data = post_infos['提交數據(post)'], json=ast.literal_eval(post_info['提交數據(post)']) ) response.encoding = response.apparent_encoding if post_info['取值方式'] == 'json取值':value = jsonpath.jsonpath( response.json(),post_info['取值代碼'] )[0]self.temp_variables[ post_info['傳值變量'] ] = value elif post_info['取值方式'] == '正則取值':value = re.findall(post_info['取值代碼'],response.text)[0]self.temp_variables[post_info['傳值變量']] = value #調用CheckUtils() result = CheckUtils(response).run_check(post_info[’期望結果類型’],post_info[’期望結果’]) except ProxyError as e: result = {’code’: 4, ’result’: ’[%s]請求:代理錯誤異常’ % (post_info['接口名稱'])} except ConnectionError as e: result = {’code’: 4, ’result’: ’[%s]請求:連接超時異常’ % (post_info['接口名稱'])} except RequestException as e: result = {’code’: 4, ’result’: ’[%s]請求:Request異常,原因:%s’ % (post_info['接口名稱'], e.__str__())} except Exception as e: result = {’code’:4,’result’:’[%s]請求:系統異常,原因:%s’%(post_info['接口名稱'],e.__str__())} return result def request(self,step_info): try: request_type = step_info['請求方式'] param_variable_list = re.findall(’${w+}’, step_info['請求參數(get)']) if param_variable_list:for param_variable in param_variable_list: step_info['請求參數(get)'] = step_info['請求參數(get)'] .replace(param_variable,’'%s'’ % self.temp_variables.get(param_variable[2:-1])) if request_type == 'get':result = self.__get( step_info ) elif request_type == 'post':data_variable_list = re.findall(’${w+}’, step_info['提交數據(post)'])if data_variable_list: for param_variable in data_variable_list: step_info['提交數據(post)'] = step_info['提交數據(post)'] .replace(param_variable, ’'%s'’ % self.temp_variables.get(param_variable[2:-1]))result = self.__post( step_info ) else:result = {’code’:1,’result’:’請求方式不支持’} except Exception as e: result = {’code’:4,’result’:’用例編號[%s]的[%s]步驟出現系統異常,原因:%s’%(step_info[’測試用例編號’],step_info['測試用例步驟'],e.__str__())} return result def request_by_step(self,step_infos): self.temp_variables = {} for step_info in step_infos: temp_result = self.request( step_info ) # print( temp_result ) if temp_result[’code’]!=0:break return temp_resultif __name__=='__main__': case_info = [ {’請求方式’: ’get’, ’請求地址’: ’/cgi-bin/token’, ’請求參數(get)’: ’{'grant_type':'client_credential','appid':'wxXXXXXxc16','secret':'XXXXXXXX'}’, ’提交數據(post)’: ’’, ’取值方式’: ’json取值’, ’傳值變量’: ’token’, ’取值代碼’: ’$.access_token’, ’期望結果類型’: ’正則匹配’, ’期望結果’: ’{'access_token':'(.+?)','expires_in':(.+?)}’}, {’請求方式’: ’post’, ’請求地址’: ’/cgi-bin/tags/create’, ’請求參數(get)’: ’{'access_token':${token}}’, ’提交數據(post)’: ’{'tag' : {'name' : '衡東'}}’,’取值方式’: ’無’, ’傳值變量’: ’’, ’取值代碼’: ’’, ’期望結果類型’: ’正則匹配’, ’期望結果’: ’{'tag':{'id':(.+?),'name':'衡東'}}’} ] RequestsUtils().request_by_step(case_info)

五、斷言封裝(核心封裝)

check_utils.py 斷言封裝,與實際結果核對

import reimport astclass CheckUtils(): def __init__(self,check_response=None): self.ck_response=check_response self.ck_rules = { ’無’: self.no_check, ’json鍵是否存在’: self.check_key, ’json鍵值對’: self.check_keyvalue, ’正則匹配’: self.check_regexp } self.pass_result = { ’code’: 0, ’response_reason’: self.ck_response.reason, ’response_code’: self.ck_response.status_code, ’response_headers’: self.ck_response.headers, ’response_body’: self.ck_response.text, ’check_result’: True, ’message’: ’’ # 擴招作為日志輸出等 } self.fail_result = { ’code’: 2, ’response_reason’: self.ck_response.reason, ’response_code’: self.ck_response.status_code, ’response_headers’: self.ck_response.headers, ’response_body’: self.ck_response.text, ’check_result’: False, ’message’: ’’ # 擴招作為日志輸出等 } def no_check(self): return self.pass_result def check_key(self,check_data=None): check_data_list = check_data.split(’,’) #把需要判斷的值做切割,取出鍵值 res_list = [] #存放每次比較的結果 wrong_key = [] #存放比較失敗key for check_data in check_data_list: #把切割的鍵值和取出響應結果中的所有的鍵一個一個對比 if check_data in self.ck_response.json().keys():res_list.append(self.pass_result ) else:res_list.append( self.fail_result )wrong_key.append(check_data) #把失敗的鍵放進來,便于后續日志輸出 # print(res_list) # print(wrong_key) if self.fail_result in res_list: return self.fail_result else: return self.pass_result def check_keyvalue(self,check_data=None): res_list = [] # 存放每次比較的結果 wrong_items = [] # 存放比較失敗 items for check_item in ast.literal_eval(check_data).items(): #literal_eval()安全性的把字符串轉成字典,items()取出鍵值對 if check_item in self.ck_response.json().items():res_list.append( self.pass_result ) else:res_list.append( self.fail_result )wrong_items.append(check_item) # print( res_list ) # print( wrong_items ) if self.fail_result in res_list: return self.fail_result else: return self.pass_result def check_regexp(self,check_data=None): pattern = re.compile(check_data) if re.findall(pattern=pattern,string=self.ck_response.text): #匹配到了,不為空,為true return self.pass_result else: return self.fail_result def run_check(self,check_type=None,check_data=None): code = self.ck_response.status_code if code == 200: if check_type in self.ck_rules.keys():result=self.ck_rules[check_type](check_data)return result else:self.fail_result[’message’] = ’不支持%s判斷方法’%check_typereturn self.fail_result else: self.fail_result[’message’] = ’請求的響應狀態碼非%s’%str(code) return self.fail_resultif __name__=='__main__': # 檢查鍵是否存在,{'access_token':'hello','expires_':7200} 設為響應結果,'access_token,expires_in' 為檢查對象值 CheckUtils({'access_token':'hello','expires_':7200}).check_key('access_token,expires_in') #檢查鍵值對是否存在 CheckUtils({'access_token':'hello','expires_i':7200}).check_keyvalue(’{'expires_in': 7200}’) #正則對比 #TURE print(CheckUtils(’{'access_token':'hello','expires_in':7200}’).check_regexp(’'expires_in':(.+?)’)) #False print(CheckUtils(’{'access_token':'hello','expires':7200}’).check_regexp(’'expires_in':(.+?)’))

六、api_testcase下的api_test.py 封裝

import warningsimport unittestimport paramunittestfrom common.testdata_utils import TestdataUtilsfrom common.requests_utils import RequestsUtils#如果是mysql數據源的話切換成 def_testcase_data_list_by_mysql() exccel數據源:def_testcase_data_list()case_infos = TestdataUtils().def_testcase_data_list_by_mysql()@paramunittest.parametrized( *case_infos)class APITest(paramunittest.ParametrizedTestCase): def setUp(self) -> None: warnings.simplefilter(’ignore’, ResourceWarning) #不會彈出警告提示 def setParameters(self, case_id, case_info): self.case_id = case_id self.case_info = case_info def test_api_common_function(self): ’’’測試描述’’’ self._testMethodName = self.case_info[0].get('測試用例編號') self._testMethodDoc = self.case_info[0].get('測試用例名稱') actual_result = RequestsUtils().request_by_step(self.case_info) self.assertTrue( actual_result.get(’check_result’),actual_result.get(’message’) )if __name__ == ’__main__’: unittest.main()

七、common下的log_utils.py 封裝

import osimport loggingimport timefrom common.config_utils import configcurrent_path = os.path.dirname(__file__)log_output_path = os.path.join( current_path,’..’, config.LOG_PATH )class LogUtils(): def __init__(self,log_path=log_output_path): self.log_name = os.path.join( log_output_path ,’ApiTest_%s.log’%time.strftime(’%Y_%m_%d’) ) self.logger = logging.getLogger('ApiTestLog') self.logger.setLevel( config.LOG_LEVEL ) console_handler = logging.StreamHandler() # 控制臺輸出 file_handler = logging.FileHandler(self.log_name,’a’,encoding=’utf-8’) # 文件輸出 formatter = logging.Formatter('%(asctime)s %(name)s %(levelname)s %(message)s') console_handler.setFormatter(formatter) file_handler.setFormatter(formatter) self.logger.addHandler( console_handler ) self.logger.addHandler( file_handler ) console_handler.close() # 防止打印日志重復 file_handler.close() # 防止打印日志重復 def get_logger(self): return self.loggerlogger = LogUtils().get_logger() # 防止打印日志重復if __name__ == ’__main__’: logger.info(’hello’)

八、common下的config_utils.py的封裝

配置文件的編寫:

Python reques接口測試框架實現代碼

對配置文件的讀取封裝:

import osimport configparsercurrent_path = os.path.dirname(__file__)cfgpath = os.path.join(current_path, '../conf/local_config.ini')print(cfgpath)class ConfigUtils: def __init__(self,config_path=cfgpath): self.__conf=configparser.ConfigParser() self.__conf.read(config_path, encoding='utf-8') def read_ini(self,sec,option): value=self.__conf.get(sec,option) return value @property def hosts(self): value=self.read_ini(’default’,’hosts’) return value @property def LOG_PATH(self): value = self.read_ini(’path’, ’LOG_PATH’) return value @property def CASE_DATA_PATH(self): value = self.read_ini(’path’, ’CASE_DATA_PATH’) return value @property def REPORT_PATH(self): value = self.read_ini(’path’, ’REPORT_PATH’) return value @property def LOG_LEVEL(self): value = int(self.read_ini(’log’, ’LOG_LEVEL’)) return value @property def smtp_server(self): smtp_server_value = self.read_ini(’email’, ’smtp_server’) return smtp_server_value @property def smtp_sender(self): smtp_sender_value = self.read_ini(’email’, ’smtp_sender’) return smtp_sender_value @property def smtp_password(self): smtp_password_value = self.read_ini(’email’, ’smtp_password’) return smtp_password_value @property def smtp_receiver(self): smtp_receiver_value = self.read_ini(’email’, ’smtp_receiver’) return smtp_receiver_value @property def smtp_cc(self): smtp_cc_value = self.read_ini(’email’, ’smtp_cc’) return smtp_cc_value @property def smtp_subject(self): smtp_subject_value = self.read_ini(’email’, ’smtp_subject’) return smtp_subject_valueconfig=ConfigUtils()if __name__==’__main__’: current_path = os.path.dirname(__file__) cfgpath = os.path.join(current_path, '../conf/local_config.ini') config_u=ConfigUtils() print(config_u.hosts) print(config_u.LOG_LEVEL)

九、test_runner下的run_case.py 封裝

class RunCase(): def __init__(self): self.test_case_path = test_case_path self.report_path = test_report_path self.title = ’P1P2接口自動化測試報告’ self.description = ’自動化接口測試框架’ self.tester = ’測試開發組’ def load_test_suite(self): discover = unittest.defaultTestLoader.discover(start_dir=self.test_case_path, pattern=’api_test.py’, top_level_dir=self.test_case_path) all_suite = unittest.TestSuite() all_suite.addTest( discover ) return all_suite def run(self): report_dir = HTMLTestReportCN.ReportDirectory(self.report_path) report_dir.create_dir(self.title) report_file_path = HTMLTestReportCN.GlobalMsg.get_value(’report_path’) fp = open( report_file_path ,’wb’ ) runner = HTMLTestReportCN.HTMLTestRunner(stream=fp, title=self.title, description=self.description, tester=self.tester) runner.run( self.load_test_suite() ) fp.close() return report_file_pathif __name__==’__main__’: report_path = RunCase().run() EmailUtils(open(report_path, ’rb’).read(), report_path).send_mail()

十、common下的email_utils.py 封裝

import osimport smtplibfrom email.mime.text import MIMETextfrom email.mime.multipart import MIMEMultipartfrom common.config_utils import configclass EmailUtils(): def __init__(self,smtp_body,smtp_attch_path=None): self.smtp_server = config.smtp_server self.smtp_sender = config.smtp_sender self.smtp_password = config.smtp_password self.smtp_receiver = config.smtp_receiver self.smtp_cc = config.smtp_cc self.smtp_subject = config.smtp_subject self.smtp_body = smtp_body self.smtp_attch = smtp_attch_path def mail_message_body(self): message = MIMEMultipart() message[’from’] = self.smtp_sender message[’to’] = self.smtp_receiver message[’Cc’] = self.smtp_cc message[’subject’] = self.smtp_subject message.attach( MIMEText(self.smtp_body,’html’,’utf-8’) ) if self.smtp_attch: attach_file = MIMEText(open(self.smtp_attch, ’rb’).read(), ’base64’, ’utf-8’) attach_file[’Content-Type’] = ’application/octet-stream’ attach_file.add_header(’Content-Disposition’, ’attachment’, filename=(’gbk’, ’’, os.path.basename(self.smtp_attch))) message.attach(attach_file) return message def send_mail(self): smtp = smtplib.SMTP() smtp.connect(self.smtp_server) smtp.login(user=self.smtp_sender, password=self.smtp_password) smtp.sendmail(self.smtp_sender,self.smtp_receiver.split(',')+ self.smtp_cc.split(','), self.mail_message_body().as_string())if __name__==’__main__’: html_path = os.path.dirname(__file__) + ’/../test_reports/接口自動化測試報告V1.1/接口自動化測試報告V1.1.html’ EmailUtils(’<h3 align='center'>自動化測試報告</h3>’,html_path).send_mail()

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 久久男女视频 | 成年男女免费视频 | 国产人妖ts重口系列喝尿视频 | 欧美成人看片黄a免费看 | 亚洲老妈激情一区二区三区 | 高潮一区| 免费国产成人高清在线观看网站 | 91丨九色丨蝌蚪丨对白 | 免费看男女www网站入口在线 | 一区高清| 欧美一区二区三区啪啪 | 国产少妇露脸精品 | 国产成人高清 | 国产网站在线看 | 国产在线观看免费麻豆 | 肉视频在线观看 | 亚洲欧美国产欧美色欲 | 免费小视频在线观看 | 国产福利在线观看 | 亚洲精品乱码久久 | 国产精品12区 | 亚洲色成人网站www永久男男 | 免费看一级黄色大全 | 亚洲最大福利网站 | 国产美女作爱全过程免费视频 | 刺激一区仑乱 | 国产 精品 自在自线 | 午夜视频免费 | 日韩少妇内射免费播放 | 精品久久久三级丝袜 | 国产91在线免费观看 | 扶她futa粗大做到怀孕 | 国产成人成网站在线播放青青 | 天堂网av手机版 | 久久亚洲中文字幕精品一区 | 人人妻人人爽人人做夜欢视频 | 杂技xxx裸体xxx欧美 | 不卡国产一区二区三区四区 | 久久精品一级片 | 一区二区三区av在线 | 久久久久久91亚洲精品中文字幕 | 欧美不卡一区二区三区 | 国产精品 日韩精品 | 日韩视频在线一区 | 国产视频一区二区在线 | 天天澡天天狠天天天做 | 一区二区高清 | 国产精品久久久久久欧美2021 | 久久久久女教师免费一区 | 国产男女裸体做爰爽爽 | 日韩免费视频 | 中国白嫩丰满人妻videos | 肉欲性大交毛片 | 性一交一刮一伦96a 性一交一乱一伧老太 | 涩涩爱网站 | 都市激情自拍 | 黑人大群体交免费视频 | 亚洲精品一区二区三区蜜桃 | 国产视频污| 久久er热在这里只有精品66 | 日韩激情网站 | 一区一区三区产品乱码 | 女人和拘做爰正片视频 | 欧美成人精品一级乱黄 | 亚洲精品中文字幕无码蜜桃 | 久久久久久久国产精品影院 | 最新中文字幕av无码不卡 | 久久999精品久久久有什么优势 | 尤物在线视频 | 日女人免费视频 | 欧亚激情偷人伦小说专区 | 欧美jizz18性欧美 | 男女爱爱好爽视频免费看 | 九九九热视频 | 欧美日韩国产三级 | 性生交大片免费全视频 | 国产视频中文字幕 | 中文在线а天堂中文在线新版 | 91九色在线视频 | 中文字幕被公侵犯的漂亮人妻 | 国产成人久久婷婷精品流白浆 | 日本少妇喷水 | 国产成人av性色在线影院 | 日本成年x片免费观看 | 国产真人无码作爱视频免费 | 喷水白丝蜜臀av久久av | 国产一区不卡 | 国产激情综合 | 亚洲图片欧美在线看 | 色五月激情五月 | 国产成人无码一区二区三区在线 | 欧美手机在线观看 | 精品免费在线观看 | 国产中老年妇女精品 | 欧美日韩国产一区二区三区不卡 | 欧美精品二区三区 | 精品国产aⅴ无码一区二区 亚洲人成人无码网www国产 | 精品理论片| 国产又色又爽又刺激在线观看 | 久久最新视频 | 欧美老妇xxx | 久久无码高潮喷水 | 亚洲精品一区二区另类图片 | 欧美大尺度做爰啪啪免费 | 欧美一级少妇aaaabbbb | 色婷婷综合久久久久中文字幕 | 亚洲美女福利视频 | 色妞av永久一区二区国产av开 | 精品国产百合女同互慰 | 亚洲一级免费在线观看 | 日韩精品免费一区二区三区竹菊 | 少妇私密会所按摩到高潮呻吟 | 牛牛影视一区二区 | 欧美大肥婆大肥bbbbb | 久久久一级 | 中文字幕av高清片 | 亚洲国产成人av好男人在线观看 | 亚洲第8页 | 特黄三级男人添女人下面 | 久久品| 蜜桃网av | 亚一区二区三区 | 国产伦精品一区二区三区88av | 一级中文字幕 | 亚洲国产精品久久久久秋霞1 | 欧美三p| 可以看的av网站 | 欧美精品在欧美一区二区少妇 | 欧美黄色大片免费观看 | 国产卡一卡二卡三无线 | 国产无遮挡免费观看视频网站 | 精品剧情v国产在线观看 | 国产成人a∨激情视频厨房 国产精品无码一区二区三级 | 欧洲欧美人成视频在线 | 国产亚洲欧美精品久久久www | 亚日韩av| 国产伦精品一区二区三区视频网站 | 97精品一区| 国产精品久久久久永久免费看 | 久久av无码精品人妻系列试探 | 亚洲污污网站 | www噜噜噜 | 亚洲日批视频 | 久久疯狂做爰流白浆xx | 国产在线不卡精品网站 | 愉拍自拍第169页 | 亚洲九九热 | 亚洲欧美在线视频免费 | 授乳喂奶av中文在线 | 亚洲日产韩国一二三四区 | 国产女人好紧好爽 | ww又激又色又爽又免费视频 | 精品无码黑人又粗又大又长 | 艳妇臀荡乳欲伦交换在线看 | 日韩欧美久久 | 97在线观看播放 | 日韩精品欧美 | 亚洲成av人片一区二区三区 | 超碰女人 | 99热这里只有精品在线观看 | 国产做爰xxxⅹ高潮69 | 亚洲伊人色综合网站小说 | 伊人情人综合 | 欧美天天影院 | 青青草精品在线视频 | 亚洲第一视频网站 | 免费美女毛片 | 一级淫片a | 三级网站视频在在线播放 | 麻豆影视免费观看 | 午夜婷婷国产麻豆精品 | 中文字幕1区 | jizz在线观看视频 | 午夜国人精品av免费看 | 青青草91久久久久久久久 | 欧美一级网| 亚洲精品一区二区三区四区乱码 | 日韩一区在线视频 | 亚洲欧美另类综合 | 亚洲不卡av不卡一区二区 | 高h禁伦餐桌上的肉伦水视频 | 嫩草视频免费观看 | 视频久久精品 | wwwcomcn成人| 国产精品无码久久久久久 | 美女在线网站 | wwwav黄色| 四虎在线免费 | 女人18毛片水真多 | 长河落日电视连续剧免费观看01 | 国产精品一区二区在线免费观看 | 粉嫩一区二区三区色综合 | av香港经典三级级 在线 | 午夜寂寞影视在线观看 | 欧美日韩国产精品久久 | 久久婷婷综合99啪69影院 | 无码人妻精品一区二区三区在线 | 免费成人在线观看视频 | 香蕉视频在线网站 | 手机福利在线 | 色七七视频 | 国产二区精品 | 精品乱子伦一区二区三区 | 国产精品久久久一区二区三区网站 | 一本大道久久精品 | 日韩欧美123 | 天天综合干 | 催眠调教邻居美人若妻在线播放 | 日韩av一二三 | a 'v片欧美日韩在线 | 久久亚洲精品久久国产一区二区 | 免费精品国产 | www.youjizz.com视频| 好吊日免费视频 | 青娱乐极品视觉盛宴国产视频 | 六个黑人玩一个中国少妇视频 | 国产精品久久久久久久久久妞妞 | 免费久久一级欧美特大黄 | 慈禧一级淫片免费放特级 | 拔萝卜在线视频免费观看 | 国产高清不卡无码视频 | 亚洲黄色小说视频 | 久草热8精品视频在线观看 人妻互换 综合 | 一本之道高清码狼人 | 欧美激情视频一区二区三区在线播放 | 少妇又紧又深又湿又爽视频 | 蜜桃导航-精品导航 | 久久黄色一级视频 | 91久久久久久| 性欧美激情 | 催眠调教后宫乱淫校园 | 伊人艹| 国产午夜在线播放 | 毛片无码一区二区三区a片视频 | 亚洲第一成年人网站 | 猫咪www免费人成人入口 | 国产精品女同一区二区久久夜 | 啪啪日韩 | 久久午夜网站 | 自拍视频啪 | 伊人网免费视频 | 99re热这里只有精品视频 | 国产偷窥女洗浴在线观看 | 人妻少妇乱子伦精品无码专区电影 | 日韩欧美一区在线观看 | 日本韩国欧美一区二区 | 日韩黄色在线播放 | 欧美一级大黄 | 久草在线色站 | 美女在线不卡 | 夹得我好紧好爽日出了水视频 | 久久精品国产亚洲a∨蜜臀 久久精品国产亚洲沈樵 | 五月婷婷俺也去 | 青青青在线免费观看 | 中文字幕视频免费观看 | 香蕉av一区| 日本边舌吻边做爽的视频 | 亚洲欧美另类视频 | av综合网男人的天堂 | 久久99一区 | 日本精品久久久久中文字幕乱中年 | 狠狠色噜噜狠狠色综合久 | 穿情趣内衣c到高潮av片 | 亚洲高清av一区二区三区 | 深夜福利一区二区三区 | 欧美黄色一级视频 | 日韩一区国产二区欧美三区 | 国产首页 | 白嫩少妇抽搐高潮12p | 国产激情久久久久久熟女老人av | 少妇午夜三级伦理影院播放器 | 精品国产免费一区二区三区香蕉 | 91精品久久久久含羞草 | 中文字幕精品久久久久人妻红杏ⅰ | 亚洲免费网站在线观看 | 国产网站黄 | 日日爱夜夜操 | 爆操网站 | 国产男人的天堂 | 中文字幕久久999及 中文字幕久久av | 欧美日韩在线高清 | 亚洲国产精品综合久久网络 | 91成人国产| 精品伊人| 欧美日韩在线视频一区二区 | 鲁夜天天末成午 | 女人被狂躁c到高潮喷水电影 | 天堂色av | 国产成人午夜精品5599 | 亚洲免费播放 | 欧美精品综合 | 激情欧美一区二区免费视频 | 亚洲最大黄色网址 | 肉体暴力强伦轩在线播放 | 国产精品天堂avav在线 | 日韩av免费| 国产成人精品123区免费视频 | 亚洲一区欧美二区 | 91精品国产高清91久久久久久 | 亚洲国产精品久久久 | 中文字幕人妻无码系列第三区 | 国产亚洲无 | 国产色欲av一区二区三区 | 国产精品无码av天天爽 | 久久zyz资源站无码中文动漫 | 99久久欧美日韩国产二区 | 久久国产精品免费 | 欧美黄色影院 | 久久精品青草社区 | 乳女教师の诱惑juliamagnet | 一级黄色免费大片 | 天天艹天天操 | 久久www人成免费产片 | 在线免费观看麻豆 | 国产经典盗摄91区x99av | aa免费视频| 国产精品久久久久9999爆乳 | 国产午夜亚洲精品不卡下载 | 国产成人精品一区二区在线小狼 | 国产福利社 | 新版天堂资源中文8在线 | 福利所导航| 欧美破处大片 | 超碰97自拍| 久久亚洲a片com人成 | 中文在线观看免费高清 | 欧美亚洲精品一区二区三区 | 大学生久久香蕉国产线看观看 | 在线播放亚洲 | 黄色毛片一级片 | 男女啪啪做爰高潮www成人福利 | 亚洲中文字幕va福利 | 国产精品中文字幕在线 | 成人免费视频视频 | 伊人www22综合色 | 国产浮力第一页草草影院 | 亚洲色tu| 精品一区视频 | 曰本女人与公拘交酡免费视频 | 亚洲永久精品ww47 | 亚洲激情综合 | 超碰中文在线 | 韩国成年人网站 | 精品国产一区二区三区小蝌蚪 | 日本性视频网站 | 真实国产露脸乱 | 亚洲欧美国产毛片在线 | 亚洲人成综合网站7777香蕉 | 国内精品人妻久久毛片app | 一级淫片免费 | 午夜精品射精入后重之免费观看 | 成人午夜高潮a∨猛片 | 极品淫少妇 | 52avavjizz亚洲精品 | 日日躁你夜夜躁你av蜜 | 亚洲日本va中文字幕久久 | av免费在线观看不卡 | 欧美一本乱大交性xxxⅹ | 久久久久久久久无码精品亚洲日韩 | 精品免费国产一区二区三区四区介绍 | 国产精品人人做人人爽人人添 | 永久免费未满 | 衣服被扒开强摸双乳18禁网站 | 伊人影院中文字幕 | 91在线资源 | 91羞羞视频 | 日本做爰全过程免费的叫床 | 女性无套免费网站在线看动漫 | 国产一区二区欧美 | 日本黑人一区二区免费视频 | 成人亚洲性情网站www在线观看 | 精品国产自在精品国产 | 中文 在线 日韩 亚洲 欧美 | 国产精品18p | 天天久久久 | 亚洲视频在线免费播放 | 国产情侣一区二区三区 | 午夜福利毛片 | 爽爽影院免费观看视频 | 成人在线91 | 免费人成再在线观看网站 | 直接看的av网站 | 91精品打屁股sm调教 | 人人爽日日躁夜夜躁尤物 | 春色激情站 | 成人伊人精品色xxxx视频 | 亚洲日韩乱码一区二区三区四区 | 日本国产在线观看 | 国产精品成人一区二区三区 | 一级做a毛片 | vvvv88亚洲精品欧美精品 | 国产精品亚洲а∨无码播放麻豆 | 少妇高潮喷潮久久久影院 | 欧美有码视频 | www.日韩在线| 久久久久久夜精品精品免费啦 | 最新国产毛片 | 涩涩视频免费在线观看 | a男人天堂 | 国偷自产视频一区二区久 | 久久午夜精品视频 | 国产无玛| 国产精品刺激对白97 | 久久奇米 | 欧美日韩在线a | 天堂a v网2019 | 99久久久无码国产精品试看 | 女人夜夜春精品a片 | 艳妇臀荡乳欲伦交换在线播放 | 欧美性猛交富婆辛迪 | 亚洲一区在线看 | 亚洲精品乱码久久久久久黑人 | 亚洲国产精品无码专区影院 | 福利免费观看 | 在线 | 一区二区三区四区 | 欧美成人午夜 | 久久久久久久97 | 中文字幕精品久久久 | 黄瓜视频污在线观看 | 性猛交xxxx乱大交孕妇2 | 国产精彩视频在线观看 | 粗喘呻吟撞击猛烈疯狂 | 第一章豪妇荡乳黄淑珍 | 欧美性猛交aaaa片黑人 | 中文字幕一区二区三区乱码 | 99精品国产成人一区二区 | 免费在线看黄网站 | 欧美大喷水吹潮合集在线观看 | 成人免费看黄 | 欧美午夜精品一区二区 | 少妇高清精品毛片在线视频 | 中文韩国午夜理伦三级好看 | 888久久久 | 狠狠88综合久久久久综合网 | 精品久久久无码中文字幕 | 思思99热| 高h禁伦1v1公妇借种 | 精品国产露脸精彩对白 | 综合网天天 | 亚洲黄色av| 国产精品久久久久aaaa九色 | 久久久国产网站 | 香港经典a毛片免费观看播放 | 久久99精品九九九久久婷婷 | 和粗大男人做爰过程 | 欧美久久久精品 | 国产l精品国产亚洲区在线观看 | 二区三区在线 | jlzzjlzz亚洲女人18 | 成人片黄网站色大片免费毛片 | 欧美在线性视频 | 亚洲吧 | 性生交大片免费全毛片 | 香蕉视频成人在线 | av爽妇网 | 国产模特av私拍大尺度 | 天天操天天拍 | 久艹av | 国产网红无码精品视频 | 自拍偷自拍亚洲精品情侣 | 国产亚洲欧美在线视频 | 国产精品无套粉嫩白浆在线 | 日本强伦姧人妻一区二区 | 亚洲国产精品婷婷 | 懂色av中文在线 | 好了av四色综合网站 | 夜夜高潮夜夜爽国产伦精品 | 亚洲国产精品一区 | 亚洲视频日韩 | 好吊妞视频在线 | 在线观看黄色av | 中文字幕资源站 | 四虎国产精品免费观看视频优播 | 久久性生活片 | 91色片| 国产精品毛片大码女人 | 美女张开腿黄网站免费下载 | 自慰无码一区二区三区 | 天堂av在线免费观看 | 人妻中文字幕乱人伦在线 | 少妇高潮尖叫黑人激情在线 | 亚洲国产成人精品片在线观看 | 国产伦精品一区二区三区免费优势 | 福利视频二区 | 大胆欧美熟妇xx | 国产午夜亚洲精品不卡下载 | 超清 忍不住的亲子伦中文字幕 | jvid精品视频hd在线 | 人摸人人人澡人人超碰97 | 美女与动人物aa交性 | 国产精品高清一区二区三区不卡 | 国产精品字幕 | 国产精品国产三级国产潘金莲 | 国产素人在线观看 | 九色丨porny丨喷水 | 国产免国产免费 | 国产亚洲视频在线播放香蕉 | 午夜免费一区 | 在线播放高清视频www | 成人av一区二区兰花在线播放 | 91成人毛片 | 无码高潮少妇毛多水多水免费 | 久久国产a | 日韩不卡在线观看 | 日韩精品无码一区二区三区久久久 | 亚洲欧美日韩中文久久 | 久久永久免费视频 | r级无码视频在线观看 | 2024国产精品自拍 | 欧美一区久久久 | 久久精品亚洲中文无东京热 | 欧美在线观看一区二区 | 国产伦孑沙发午休精品 | 北条麻妃一对7黑人mv | 男女做aj视频免费的网站 | 1024国产精品 | 日本真人做爰免费的视频 | 国产精品主播一区二区 | 日韩精品在线播放 | 毛片网站免费观看 | 在线天堂中文www视软件 | 国产福利一区二区三区在线观看 | 日本一本久 | 精品少妇一区二区 | 亚洲精品国产精品自产a区红杏吧 | 福利精品视频 | 欧美日韩一区视频 | 久久免费在线视频 | 四虎永久免费地址 | 日本一级二级三级久久久 | 国产乱码字幕精品高清av | 久久精品麻豆日日躁夜夜躁 | 欧美一性一乱一交 | 特黄少妇60分钟在线观看播放 | 五月天丁香综合久久国产 | 九九热精品在线观看 | 欧美日韩免费视频 | 露出调教羞耻91九色 | 日日日人人人 | 欧美成人精品一区二区 | 18性夜影院午夜寂寞影院免费 | 最新色网站 | 精东粉嫩av免费一区二区三区 | 午夜欧美成人 | 成人国产在线视频 | 999精欧美一区二区三区黑人 | 亚洲图片中文字幕 | 丁香花开心四播房麻豆 | 樱井莉亚av | 亚州少妇无套内射激情视频 | 免费成人小视频 | 色偷偷色噜噜狠狠成人免费视频 | 一级黄色性生活视频 | 99国产精品99久久久久久粉嫩 | 免费网站日本a级淫片免费看 | 亚洲精品免费播放 | 亚洲三级精品 | 欧美毛片在线 | 国产偷国产偷亚洲清高动态图 | 国产一区二区在线免费 | 69精产国品一二三产区视频 | 天天天色综合 | 色综合久久88 | 国产精品成人一区二区三区 | 乳女教师の诱惑julia | 一性一交一口添一摸视频 | 精品欧洲av无码一区二区14 | 国产人交视频xxxcom | 国产精品人妻一区二区三区四 | 少妇做爰免费视频网站www | 国产欧美一级片 | 成人免费午夜视频69影院 | 少妇又色又爽又高潮极品 | 超碰黑丝| 国产男女无套免费网站 | 夜夜高潮夜夜爽夜夜爱爱一区 | 黄色成人在线 | 日本丰满熟妇videossexhd 午夜福利影院私人爽爽 | 免费av在线网 | 俺去俺来也在线www色官 | 久久久国产视频 | 人妻少妇精品视频二区 | 亚洲精品女人久久久 | 久久久久久蜜桃一区二区 | 九九在线精品 | 午夜国产一区 | 含羞草传媒mv免费观看视频 | 久久久精品区 | 日产亚洲一区二区三区 | 欧美精品色视频 | 国产成人久久精品激情 | 欧美一级α片 | 少妇无内裤下蹲露大唇92 | 成人在线观看网址 | 青青草无码精品伊人久久 | 国产成人综合欧美精品久久 | 五月婷婷网 | 国产又大又黑又粗免费视频 | 伊人av超碰久久久麻豆 | av一卡| 久草在线综合 | 成人免费网站视频 | 成人在线观看www | 久久精品视频99 | 2021久久精品国产99国产精品 | av无码久久久久不卡网站下载 | 国产精品特级毛片一区二区三区 | 国产成人精品无码短视频 | 又污又爽又黄的网站 | 日本成熟老妇乱 | 69视频网站| 91九色丨porny丨丰满6 | 国产乱xxxxx978国语对白 | 色视频网| 中文字幕无码日韩专区 |