你真的会开发测试框架?

基本概念

  • 英文单词叫Library,库是由代码集合成的一个产品,供程序员调用。面向对象的代码组织造成的库叫类库,面向过程的代码组织造成的库叫函数库。前端

  • 框架 英文单词叫Framework,框架是为解决一个或一类问题而开发的产品,用户通常只须要使用框架提供的类或函数,便可实现所有功能。vue

  • 工具 英文单词叫Tools,在我看来工具与框架所作的事情相似,只是工具提供了更高层次的封装,屏蔽了底层的代码,提供单独的操做界面供用户操做。例如,UFT(QTP)、Katalon属于自动化测试工具。java

常见库

根据上面的概念,Requests是HTTP库,请看官方的简介。python

Requests is an elegant and simple HTTP library for Python, built for human beings.mysql

它的使用是这样的:git

import requests
r = requests.get('https://api.github.com/events')

那么,其实 Selenium Webdriver也只是一个而已。程序员

from selenium import webdriver
browser = webdriver.Firefox()

browser.get('http://www.yahoo.com')

注意:我说的可不是整个Selenium工具,整个Selenium包含:Selenium IDE, Selenium Grid, Selenium Webdriver等。github

咱们只须要用到库里面的某个类、函数就可完成本身想要实现的功能。web

常见框架

再来讲说框架, unittest叫单元测试框架,请看官方的简介。算法

The unittest unit testing framework was originally inspired by JUnit and has a similar flavor as major unit testing frameworks in other languages. It supports test automation, sharing of setup and shutdown code for tests, aggregation of tests into collections, and independence of the tests from the reporting framework.

因此,咱们在使用unittest的时候是这样的。

import unittest

class TestStringMethods(unittest.TestCase):

    def test_upper(self):
        self.assertEqual('foo'.upper(), 'FOO')


if __name__ == '__main__':
    unittest.main()

这应该是编写的最简单的一条测试用例了。

django叫 Web开发框架,我想你应该也没意见。

mysite/
    manage.py
    mysite/
        __init__.py
        settings.py
        urls.py
        wsgi.py
    polls/
        __init__.py
        admin.py
        apps.py
        migrations/
            __init__.py
        models.py
        tests.py
        views.py

这是一个框架的目录结构。那怕我只是想用django在Web页面上展现一行"hello world",那么也要涉及到多个文件的代码编写。

框架的学习和使用成本更高,咱们要想使用框架可能须要到它所提供的多个类、函数,并且还要遵循它的代码结构或目录结构。

常见工具

工具很好理解,postman、JMeter、fiddler...这些须要下载安装的通常都叫工具。这不是咱们讨论的重点。

一个的框架诞生过程

回到框架的话题上,通常一个框架的诞生过程会经历三个阶段。

  • 学会使用
    通常就是看框架的官方文档,首先,安装,而后,拿它来作项目。这一用就是好多年。好比,我用django好几年了,历来没完整的看过它的官方文档了,更别说读用它的源码了。

  • 阅读源码
    通常牛B一点,或经验丰富开发,固然不想只局限于框架的使用层面上。他们会花几周,甚至几个月来阅读框架的源码。这样有助于框架使用过程的各类问题的处理和排查。

  • 自研框架
    可以自研框架,除了天赋,还要有机遇。好比大家公司对性能有着极高的要求,全部的开源或商业的框架都没法知足大家需求。因而乎走上了自研的道路,分析整个框架性能瓶颈,用更高性能的语言替换关键模块,或更牛B的算法实现关键功能。

阿里的dubbo叫框架,应该没人反对吧?

Apache Dubbo™ is a high-performance, java based open source RPC framework.

自动化测试框架

而咱们测试人员口中说的,开发自动化测试框架 大多数状况是:

  • python + unittest + HTMLTestRunner + page objects

  • python + pytest + allure + page objects

开发人员.... ? 这不就是我用:

python + django + pymysql + HTML + CSS + JavaScript 实现一个Web系统

这不是叫"项目开发"么?你只是拿一堆现成的东西整合到了一块儿,实现了本身的想要的某某功能。这叫 项目开发,不叫 框架开发

robot framework是框架

robot framework固然是自动化测试框架了。

Robot Framework is a generic open source automation framework for acceptance testing.

为何它能叫框架?就由于它带个"framework"?固然不是,由于它实现的自动化测试的一整套东西。

  • 如何编写用例
  • 如何组织用例
  • 如何运行测试用例
  • 如何统计用例结果
  • 如何生成测试报告
  • 如何扩展测试库

若是上面这些都是你本身设计和封装的,那么你也能够说本身开发了一个自动化测试框架,明明用着unittest/pytest却说本身开发的自动化测试框架!要么被误导,要么不要脸。

开发框架能教么?

那么问题来了,有人能教你开发测试框架么?

你问 尤大神 教你怎么开发一个 前端框架 ? 嗯,他能够给你讲一讲 Vue.js 在项目中的使用 ,或者你是前端开发大牛,大家能够坐一块儿聊聊 Vue.js 的设计思想。你也能够参与到vue.js 的项目维护当中。

你问 debugtalk 教你怎么开发一个 接口自动化测试框架? 嗯,他能够给你讲一讲 HttpRunner 在项目中的使用技巧 ,若是你有多年的接口测试经验,也能够提一些意见交流交流。

你一个测试小白,上来就要 “开发测试框架” ,还要别人教你怎么开发?你咋不上天呢?