51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

123
返回列表 发新帖
楼主: lsekfe
打印 上一主题 下一主题

【你来问我来答第97期】:如何设计搭建自动化测试框架!(活动结束)

[复制链接]

该用户从未签到

41#
发表于 2018-11-22 13:30:33 | 只看该作者
老师你好,目前在学习自动化测试框架。
Serenity、Robot Framework、RedwoodHQ、Sahi、Galen Framework、Gauge这6个主流的框架。
我学习的编程语言是java,工具的话是 Selenium。但是框架太多,我想了解下如果目前在公司中哪种框架使用的比较多,像我这种情况的话应该怎么来学习?谢谢!
回复 支持 反对

使用道具 举报

该用户从未签到

42#
发表于 2018-11-22 13:33:32 | 只看该作者
老师你好,用c#从零开始开发了一个自动化测试框架,请问这是什么水平?
背后的意思,老板该给我多少工资了,做出来象征性的给我涨了一千块
工具包含了功能测试,接口测试,性能测试三个模块,可以编辑用例,导入导出用例,监控测试过程,输出测试结果。
回复 支持 反对

使用道具 举报

  • TA的每日心情
    慵懒
    3 天前
  • 签到天数: 994 天

    连续签到: 1 天

    [LV.10]测试总司令

    43#
    发表于 2018-11-26 11:01:00 | 只看该作者
    My_JIE 发表于 2018-11-22 13:33
    老师你好,用c#从零开始开发了一个自动化测试框架,请问这是什么水平?
    背后的意思,老板该给我多少工资了 ...

    自己能编写框架66666
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    奋斗
    2018-3-8 09:22
  • 签到天数: 2 天

    连续签到: 1 天

    [LV.1]测试小兵

    44#
    发表于 2018-11-28 09:47:22 | 只看该作者
    你好,在工作的途中执行脚本的时候一直卡这里就不运行了,网上说要修改等待时间什么的,没用,您看看这是什么原因呢?
    python+appium+unittest


    appium中:
    > error: Unhandled error: TypeError: undefined is not a function
    >     at [object Object].ADB.getPIDsByName (D:\Appium\loadspace\Appium\node_modules\appium\node_modules\appium-adb\lib\adb.js:1037:8)
    >     at [object Object].ADB.killProcessesByName (D:\Appium\loadspace\Appium\node_modules\appium\node_modules\appium-adb\lib\adb.js:1079:8)
    >     at [object Object].UiAutomator.start (D:\Appium\loadspace\Appium\node_modules\appium\lib\devices\android\uiautomator.js:29:12)
    >     at [object Object].<anonymous> (D:\Appium\loadspace\Appium\node_modules\appium\lib\devices\android\android.js:115:37)
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:607:21
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:246:17
    >     at iterate (D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:146:13)
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:157:25
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:248:21
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:612:34
    >     at [object Object].androidCommon.initUnicode (D:\Appium\loadspace\Appium\node_modules\appium\lib\devices\android\android-common.js:878:5)
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:607:21
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:246:17
    >     at iterate (D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:146:13)
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:157:25
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:248:21
    >     at D:\Appium\loadspace\Appium\node_modules\appium\node_modules\async\lib\async.js:612:34
    >     at [object Object].<anonymous> (D:\Appium\loadspace\Appium\node_modules\appium\node_modules\appium-adb\lib\adb.js:180:9)
    >     at ChildProcess.exithandler (child_process.js:742:7)
    >     at ChildProcess.emit (events.js:110:17)
    >     at maybeClose (child_process.js:1016:16)
    >     at Process.ChildProcess._handle.onexit (child_process.js:1088:5) context: [POST /wd/hub/session {"capabilities":{"firstMatch":[{}],"alwaysMatch":{"platformName":"Android","appium:platformVersion":"7.0","appium:deviceName":"0123456789ABCDEF:5037","appium:appPackage":"com.njzx.care","appium:appAct]


    Test_report说:
      File "D:\python\lib\http\client.py", line 297, in begin    version, status, reason = self._read_status()  File "D:\python\lib\http\client.py", line 266, in _read_status    raise RemoteDisconnected("Remote end closed connection without"urllib3.exceptions.ProtocolError: ('Connection aborted.', RemoteDisconnected('Remote end closed connection without response',))
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    奋斗
    2018-3-8 09:22
  • 签到天数: 2 天

    连续签到: 1 天

    [LV.1]测试小兵

    45#
    发表于 2018-11-28 09:48:15 | 只看该作者
    bling123 发表于 2018-11-28 09:47
    你好,在工作的途中执行脚本的时候一直卡这里就不运行了,网上说要修改等待时间什么的,没用,您看看这是什 ...

    脚本:

    test_case1_njzx_login.py文件中:
    ## 实现守护宝app登录
    #  包名和activity名:com.njzx.care/com.njzx.care.activity.MainActivity
    # !/usr/bin/python
    # encoding:utf-8
    import time
    import unittest
    from appium import  webdriver

    class test_login(unittest.TestCase):
        #  1、环境准备与还原:文件配置
        def setUp(self):
            desired_caps = {}
            desired_caps['platformName'] = 'Android'
            desired_caps['platformVersion'] = '7.0'
            desired_caps['deviceName'] = '0123456789ABCDEF:5037'
            # desired_caps['browserName'] = ''
            #  desired_caps['chromeOptions'] = {'androidProcess': 'com.tencent.mm:tools'}  # 驱动html5,必备
            desired_caps['appPackage'] = 'com.njzx.care'
            desired_caps['appActivity'] = 'com.njzx.care.activity.MainActivity'
            # desired_caps["unicodeKeyboard", "True"]  # 支持中文输入
            # desired_caps["resetKeyboard", "True"]  # 支持中文输入,必须两条都配置
            # desired_caps['automationName'] = 'Selendroid'#  link_text定位方式是Selendroid框架中的定位方式,因此appium若想采用,则需在代码加入
            desired_caps['newCommandTimeout'] = '100'  # 超时时间
            self.driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)

        def tearDown(self):
            self.driver.quit()

        #  2、登录业务流程:
        #     (1)启动app
        #     (2)点击text = "您好,请登录"或者id  = "com.njzx.care:id/tv_helloname"进入登录界面
        #     (3)输入手机号码id = "com.njzx.care:id/et_username"和密码id = "com.njzx.care:id/et_password"
        #     (4)如果手机已经注册,可以直接登录;如果不存在,需要注册text= "快速注册"
        #     (5)点击登录id = "com.njzx.care:id/iv_login"
        def test_sendAndLogin(self):
            time.sleep(2)#  动态加载等待对象的时间,可以添加个WebDriverWait
            startLogin_text = self.find_element_by_text("您好,请登录")
            startLogin_text_id = self.find_element_by_id("com.njzx.care:id/tv_helloname")
            startLogin_text.click()
            time.sleep(2)
            text_num1 = input("请输入注册号码:")
            text_psd2 = input("请输入密码:")

            #  打开本地的用户名+ 密码存储文件
            user_info_file = open('user_info.txt', 'r')  # 用户名和密码存储文件
            user_info_list = user_info_file.readlines()  # 正确的用户名和密码存储队列
            correct_username = user_info_list[0].strip()  # 正确的用户名
            correct_password = user_info_list[1]  # 正确的密码
            user_info_file.close()

            if text_num1 == correct_username and text_psd2 == correct_password:
                print('账号存在,可以登录')
                time.sleep(2)
                self.find_element_by_id("com.njzx.care:id/et_username").send_keys(text_num1)
                self.find_element_by_id("com.njzx.care:id/et_password").send_keys(text_psd2)
            else:
                print('账号不存在,请重新注册!')
                # register = self.find_element_by_text("快速注册")
                # time.sleep(2)
                # # 注册id = com.njzx.care:id/et_phone
                # register_text = self.find_element_by_id("com.njzx.care:id/et_phone")
                # register_text.send_keys(number)
                # time.sleep(2)
                # self.find_element_by_id("com.njzx.care:id/img_submit")
                # time.sleep(2)
                # code_text = self.find_element_by_id("com.njzx.care:id/et_code")
                # code_text.send_keys(input("请输入验证"))
                # self.find_element_by_id("com.njzx.care:id/img_submit")
                return False

            time.sleep(2)
            submit = self.find_element_by_id("com.njzx.care:id/iv_login")
            submit.click()
            time.sleep(2)
            #  提交登陆之后,判断是否登陆成功
            # 方法1:可以判断某一个元素是否存在:
            #     如:“你好,请登录”这个元素是否存在isDisplayed():
            # try:
            #     get_user_info_message = self.find_element_by_id("com.njzx.care:id/tv_helloname").isDisplayed()
            #     print("登陆成功!")
            # except Exception as e:
            #     print("登录失败!",format(e))
            #  或者使用断言assert:
            try:
                self.find_element_by_id("com.njzx.care:id/ll_userinfo").click()# 进入个人信息界面
                time.sleep(2)
                info_message = self.find_element_by_id("com.njzx.care:id/tv_title").text  #  获取到元素中的文本信息
                correct_message = "个人信息"
                assert info_message == correct_message
                print("登陆成功")
            except Exception as e:
                print("登录失败!",format(e))

            # 方法2:可以判断只有登录成功才能出现的界面,如果存在,就表明登陆成功


    testsuit_njzx.py文件中:

    # !/usr/bin/python
    # encoding:utf-8

    import unittest
    import test_case1_njzx_login
    from HTMLTestRunner import HTMLTestRunner

    #  测试用例集合:
    if __name__ == '__main__':
        suite = unittest.TestSuite()  # unittest模块中的TestSuite()创建一个对象接收testcase
        suite.addTests(unittest.TestLoader().loadTestsFromNames(['test_case1_njzx_login.test_login']))
        with open('D:/HTMLReport.html', 'wb') as f:#  模式wb
            runner = HTMLTestRunner(stream=f,
                                    title=' Test Report',
                                    description='generated by HTMLTestRunner----黄亮.',
                                    verbosity=2
                                    )
            runner.run(suite)
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2019-8-10 21:26
  • 签到天数: 2 天

    连续签到: 1 天

    [LV.1]测试小兵

    46#
    发表于 2018-11-28 15:49:45 | 只看该作者
    悠悠小仙仙 发表于 2018-11-22 13:24
    老师你好,我想问下一个项目中自动化测试是否能有效的展开,自动化测试框架是关键所在是在哪里?

    你好,自动化能否有效的开展,概括的讲可以从“测试用例的覆盖范围”,以及“测试执行效率”这两方面来进行考量,当然还可以加上如“自动化缺陷发现量与总缺陷量的占比”等相关统计数据来综合评估。
    讲的口语化些,就是上了自动化后,产品或项目的测试范围有哪些变化或增量?执行时长比原来缩短了多少?有哪些缺陷是通过自动化测试才发现的?或者说是手工测试较难或难以发现的缺陷。
    举个实际案例:
    有次在调试自动化接口测试时,发现有个api接口在发送请求时,json传参里有很多和实际需求不相关的参数,虽然功能上能正常使用,也就是在做黑盒功能测试时不会觉得有什么问题,但实际上是增加了应用的资源开销。尤其在用户量达到一定量级后,性能上造成的影响就会暴露。于是提交了给开发做了优化。算是在做性能测试前提前排了个雷。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2019-8-10 21:26
  • 签到天数: 2 天

    连续签到: 1 天

    [LV.1]测试小兵

    47#
    发表于 2018-11-28 15:56:17 | 只看该作者
    MilgGtery 发表于 2018-11-22 13:30
    老师你好,目前在学习自动化测试框架。
    Serenity、Robot Framework、RedwoodHQ、Sahi、Galen Framework、G ...

    你好,对java比较熟悉的话可以尝试下Jenkins,该框架结合基于Junit的TestNG,以及Selenium都可以很好的配套使用,网上有不少相关的教程和帖子可以观摩学习。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2019-8-10 21:26
  • 签到天数: 2 天

    连续签到: 1 天

    [LV.1]测试小兵

    48#
    发表于 2018-11-28 16:22:57 | 只看该作者
    bling123 发表于 2018-11-28 09:48
    脚本:

    test_case1_njzx_login.py文件中:

    看不清楚。
    建议从报错信息源头去跟踪排查。
    比如从你帖出来的信息,可以看到报错点出在:
    error: Unhandled error: TypeError: undefined is not a function
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2019-8-10 21:26
  • 签到天数: 2 天

    连续签到: 1 天

    [LV.1]测试小兵

    49#
    发表于 2018-11-28 16:23:05 | 只看该作者
    bling123 发表于 2018-11-28 09:48
    脚本:

    test_case1_njzx_login.py文件中:

    看不清楚。
    建议从报错信息源头去跟踪排查。
    比如从你帖出来的信息,可以看到报错点出在:
    error: Unhandled error: TypeError: undefined is not a function
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    50#
    发表于 2019-1-14 17:23:20 | 只看该作者
    卡卡罗特 发表于 2018-11-7 17:31
    条件允许的话,如果希望测试数据尽可能接近生产环境(这点我也比较赞同),可以考虑把生产库的数据全部或 ...

    独立的自动化测试环境,在执行上还是很有必要的。认同这句话,问题是很多公司都不提供独立的自动化测试环境,经常见到的是,开发团队使用的测试环境A,手工测试和自动化测试共用测试环境B。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    51#
    发表于 2019-1-14 17:30:49 | 只看该作者
    卡卡罗特 发表于 2018-11-7 17:16
    因为以上这些问题还是比较发散式的,点题的目的主要也是为了引发大家的思考。
    如果全部具体讲解的话,可 ...

    测试数据准备通常放在自动化测试执行起始处。放在结束处还请举例。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    52#
    发表于 2020-6-24 16:36:21 | 只看该作者
    bling123 发表于 2018-11-7 15:44
    你好,我这里有一个关于app元素定位的问题:
    定位到一个元素,如QQ中的“写说说”这个按钮(是一个半屏幕 ...

    d(className="android.widget.LinearLayout", instance=2).click()
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-4-25 04:43 , Processed in 0.072759 second(s), 21 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表