appnium移动端PO模型+数据驱动,实现UI自动化(对之前文章代码的框架设计与代码重构--游客登录与用户登录下功能测试)

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新软件测试全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注软件测试)
img

正文

import os
import time
from appium import webdriver
from appium.webdriver.webdriver import By
from selenium.webdriver.support.wait import WebDriverWait
from appium.webdriver.common.touch_action import TouchAction
from selenium.webdriver import ActionChains
from selenium.webdriver.common.keys import Keys
import pytest
from xToolkit import xfile
import shutil
from pathlib import Path
import config

class BasePage:
def init(self,driver):
self.driver = driver

查找元素

def find_el_by_id(self,id,time =15,frequency=0.1):
return WebDriverWait(self.driver,time,frequency).until(
lambda x: x.find_element(By.ID, id) )

def find_el_by_uiautomator_text(self,el_text,time=18 , frequency=0.01):
return WebDriverWait(self.driver, time, frequency).until(
lambda x: x.find_element(By.ANDROID_UIAUTOMATOR, “new UiSelector().text(”" + el_text + “”)"))

def find_el_by_uiautomator_contains(self,el_text ,time=15 , frequency=0.1):
return WebDriverWait(self.driver,time, frequency).until(
lambda x:x.find_element(By.ANDROID_UIAUTOMATOR,“new UiSelector().textContains(”" + el_text + “”)"))

def find_toast(self,text_result,time=6 , frequency=0.01):
return WebDriverWait(self.driver, time, frequency).until(
lambda x: x.find_element(By.XPATH, ‘//*[contains(@text, “%s”)]’ % text_result))

其他函数

def get_screenshot_as_file(self,path,png_name):
self.driver.get_screenshot_as_file(
path % (time.strftime(“%Y_%m_%d %H_%M_%S”), png_name))

def del_file(path):
for elm in Path(path).glob(‘*’):
elm.unlink() if elm.is_file() else shutil.rmtree(elm)

def wifi_and_data_disable(self):
os.system(“adb shell svc wifi disable”) # 关闭WiFi
os.system(“adb shell svc data disable”) # 关闭流量

def wifi_able(self):
os.system(“adb shell svc wifi enable”)

def read_excelToList_phone(self):
return xfile.read( “…/userLoginData1.xls”).excel_to_dict(sheet=0)

def read_excelToList_email(self):
return xfile.read(config.GET_BACE_PATH+ “/userLoginData1.xls”).excel_to_dict(sheet=1)

def driver_setup():
desi_caps = dict()
desi_caps[‘platformName’] = ‘Android’
desi_caps[‘platformVersion’] = ‘9’
desi_caps[‘deviceName’] = ‘19052315134267’
desi_caps[‘unicodeKeyboard’] = True

desi_caps[‘resetKeyboard’] = True

desi_caps[‘automationName’] = ‘UIAutomator2’

包名

desi_caps[‘appPackage’] = ‘com.waterworld.haifit’

界面名

desi_caps[‘appActivity’] = ‘.ui.module.account.SplashActivity’
return desi_caps

config.py:

import os
from xToolkit import xfile

#设置项目环境域名
path_user = r’D:\AppniumPro1\image_user’ # 输入文件夹地址

agreement = “com.waterworld.haifit:id/tv_dialog_agreement_right”
send_name = “youke_test”
defult_nichen = “HaFit”
test_nichen = defult_nichen +“_test”
confirm =“确认”
permit = “允许”
visitor_login = “游客登录”
finish = “com.waterworld.haifit:id/mbtn_complete”
mine = “我的”
log_out = “退出登录”
visible = “com.waterworld.haifit:id/cb_login_password_is_visible”
tap_the_phone = “com.waterworld.haifit:id/tv_title_left”
tap_emali = “com.waterworld.haifit:id/tv_title_right”
account_phone = “com.waterworld.haifit:id/et_account_phone”
account_email = “com.waterworld.haifit:id/et_account_email”
input_psw = “com.waterworld.haifit:id/medt_input_psw”

#账号登录按钮
enter = “com.waterworld.haifit:id/mbtn_login”

#获取根目录,参数__file__指的是当前文件的目录,config位于根目录下,所以返回值就是根目录(当前文件的目录)
GET_BACE_PATH = os.path.dirname(file)
print(GET_BACE_PATH)
print(“------”)
phone_list = xfile.read(GET_BACE_PATH + “/userLoginData1.xls”).excel_to_dict(sheet=0)
print(phone_list)

login.py:

import time
import config
from base.base_page import BasePage

class LoginPage(BasePage):
#同意
def agreement(self):
time.sleep(15)
self.find_el_by_id(config.agreement).click()

def confirm(self):
self.find_el_by_uiautomator_text(config.confirm).click()

def permit(self):
self.find_el_by_uiautomator_text(config.permit).click()

def find_el_by_id_and_click(self,el_id,time =15, frequency =0.1):
self.find_el_by_id(el_id,time,frequency).click()

def find_el_by_uiautomator_text_click(self, el_text ,time =18, frequency =0.01):
self.find_el_by_uiautomator_text(el_text,time,frequency).click()

def find_el_by_id_sendkeys(self,id,data,time =15, frequency =0.1):
self.find_el_by_id(id,time =15, frequency =0.1).send_keys(data)

#---------退出登录–
def loginoff(self):
print(“进入退出登录–”)
self.find_el_by_uiautomator_text_click(config.mine)
self.find_el_by_uiautomator_text_click(config.log_out)
self.confirm()
print(“—登录状态退出”)
#------------------------------进入账号登录环节-----------------------------------------
def input_testdata(self,data_list,user_id,password_id):

可见密码

print(“开始测了–11”)
self.find_el_by_id_and_click(config.visible)
print(“密码已经设置为可见–”)
for i in data_list:
text_result = i.get(“预期结果”)

self.find_el_by_id_sendkeys(user_id, i.get(“账号”))
time.sleep(1)
print(“–账号已输入–”)
self.find_el_by_id_sendkeys(password_id, i.get(“密码”))
time.sleep(1)
print(“–密码已输入–”)

if i.get(“预期结果”) == “不可点” or i.get(“预期结果”) == “登录成功”:
print(“是不可点或者登录成功”)
self.find_el_by_id_and_click(config.enter)
time.sleep(4)
self.get_screenshot_as_file(“…/image_user/%s%s.png”, text_result)
time.sleep(2)
else:

text模糊定位

print(“-----------------登录错误提示:”)
self.find_el_by_id_and_click(config.enter)
print(“已经点击登录了 -----”)
element = self.find_toast(text_result)
self.get_screenshot_as_file(“…/image_user/%s%s .png”, element.text)
if element.text == text_result:
print(“%s,结果一致” % i.get(“预期结果”))
time.sleep(2)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
深入研究,那么很难做到真正的技术提升。**

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
[外链图片转存中…(img-2hHueune-1713285297398)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 24
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值