高级测试岗位面试题---MARK

  1. 直接手写一个python类
  2. 直接手写一个构造函数
  3. 紧接着上面的代码,直接手写,补充完整代码,要求对列表中的人进行排序,并筛选出分数大于80的人的名单,组成一个新的列表显示出来。
class Person:
def __init__(self, name, gender, age):
self.name = name
self.gender = gender
self.age = age


class Student(Person):
def __init__(self, name, gender, age,score):
super(Student, self).__init__(name, gender, age)
self.score = score

People = [kathy, Jim, John, Alice, Leo]

python的高阶函数有哪些,分别都有什么作用?

高阶函数:把函数作为参数传入,或者把函数作为返回值返回,这样的函数称为高阶函数,函数式编程就是指这种高度抽象的编程范式。

1. map()函数,函数接收两个参数,一个是函数,一个是序列,map将传入的函数依次作用到序列的每个元素,并把结果作为新的list返回。
def f(x):
     return x * x

>>> map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9])
[1, 4, 9, 16, 25, 36, 49, 64, 81]

2.reduce()的用法。reduce把一个函数作用在一个序列[x1, x2, x3...]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算,其效果就是:

reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)
比方说对一个序列求和,就可以用reduce实现:

>>> def add(x, y):
...     return x + y
...
>>> reduce(add, [1, 3, 5, 7, 9])
25

3. Python内置的sorted()函数就可以对list进行排序:

>>> sorted([36, 5, 12, 9, 21])
[5, 9, 12, 21, 36]
此外,sorted()函数也是一个高阶函数,它还可以接收一个比较函数来实现自定义的排序。比如,如果要倒序排序,我们就可以自定义一个reversed_cmp函数:

def reversed_cmp(x, y):
    if x > y:
        return -1
    if x < y:
        return 1
    return 0
传入自定义的比较函数reversed_cmp,就可以实现倒序排序:

>>> sorted([36, 5, 12, 9, 21], reversed_cmp)
[36, 21, 12, 9, 5]

 

简单说说生成器,迭代器,装饰器是什么,都有哪些作用?

迭代器;任何对象,如果它实现了next方法和iter方法,就是迭代器。
next方法要么返回迭代中的下一项,要么返回一个stapIteration异常,iter方法要返回一个迭代器对象,而它本身就是一个迭代器对象,所有返回自己本身。 作用:像我们提供一个中间人即迭代器帮助我们迭代遍历使用 for循环其实就实现了迭代器的功能,在遍历list,string,dict,tuple这些容器时,在 for语句对容器对象调用的iter()方法返回一个定义next()方法的迭代器对象,
它在函数中逐个访问容器内的元素,next和iter都是python内置函数。 生成器:生成器是一种特殊的迭代器,在函数中有yield关键字就可以说是生成器。 怎么用:调用next(),就会返回yield后面的值,生成器挂起,再次使用next就从上次停止的位置继续执行。 作用:延迟计算,一次返回一个结果。当我们需要结果的时候才会调用,而不是一次返回所有的结果。 也就是说,它不会一次生成所有的结果,
这对于大数据量处理,将会非常有用。 创建方法:
1.把列表生成式的[ ]改为()就是一个简单的列表生成器 2.使用yield关键字 生成器和迭代器的区别:生成器能做到迭代器能做到的所有事,因为自动创建iter方法和next方法,显的比较简洁,高效。
使用生成器表达式比列表解析要节省内存(前者是需要的时候才调用next返回一个值,后者直接返回一个列表),自动抛出StopIteration异常 装饰器:在不改变已存在的对象的功能情况下添加额外的功能
def set_fun(func): call_fun(*arge,**kwargs): reurn func(*arge,**kwargs) return call_fun 作用:引用日志,函数执行预计时间,权限校验,缓存等

 

 

Python中,如何将字符串转化为整型?

def to_int(str):
    try:
        int(str)
        return int(str)
    except ValueError: #报类型错误,说明不是整型的
        try:
            float(str) #用这个来验证,是不是浮点字符串
            return int(float(str))
        except ValueError:  #如果报错,说明即不是浮点,也不是int字符串。   是一个真正的字符串
            return False

 

 

TCP 三次握手和四次挥手,请分别直接写出来

客户端向服务端发送一个请求, syn -----服务端返回一个 应答 ack+syn  -----客户端收到后返回一个确认 ack

客户端向服务器发送一个关闭连接请求 fin  m----服务端应答返回ack m+1---服务端返回一个fin n ----客户端收到后发一个确认---ack n+1

 

HTTP常见的状态码有哪些?都是什么含义?

200 - 请求成功
301 - 资源(网页等)被永久转移到其它URL
404 - 请求的资源(网页等)不存在
500 - 内部服务器错误

 

webdriver的核心原理是什么?

1.测试人员运行脚本,由于客户端脚本(java, python, ruby)不能直接与浏览器通信,这时候webdriver启动了一个remote-WebService当做一个翻译器,
它可以把客户端代码翻译成浏览器可以识别的代码(比如js)。webdriver 通过浏览器监听这个端口。
2.客户端(也就是测试脚本)创建1个session,
在该session中通过http请求向WebService发送restful的请求,WebService翻译成浏览器懂得脚本传给浏览器,
3.浏览器把执行的结果返回给WebService,WebService把返回的结果做了一些封装(一般都是json格式),
然后返回给client,根据返回值就能判断对浏览器的操作是不是执行成功

总结: webdriver就是基于Http 协议来进行底层的客户端与服务端通信的。

 

 

appium是什么?主要用来做什么的?它的核心原理是什么?

略,appium client   appium server   bootstrap.js/bootstrap.jar

 

selenium1和selenium2的区别是什么,为何要抛弃selenium1?它有什么缺陷?

常见的元素定位方法有哪些?

by  id,classname, name ,xpath,linktext 等等

直接手写一个冒泡排序和快速排序,时间复杂度是多少?空间复杂度是多少?是否稳定?

//时间复杂度:O(n²)  空间复杂度:空间复杂度为O(1) 典型的用时间换空间的算法
public
class poup{ int[] arr={6,3,8,2,9,1};     System.out.println("排序前数组为:");     for(int num:arr){       System.out.print(num+" ");     }     for(int i=0;i<arr.length-1;i++){//外层循环控制排序趟数       for(int j=0;j<arr.length-1-i;j++){//内层循环控制每一趟排序多少次         if(arr[j]>arr[j+1]){           int temp=arr[j];           arr[j]=arr[j+1];           arr[j+1]=temp;         }       }     }     System.out.println();     System.out.println("排序后的数组为:");     for(int num:arr){       System.out.print(num+" ");     }   } }

 

如何查询Linux后台日志,直接写出命令

cat demo.log

more demo.log

// 查询包含关键字`123456`且包含`aa`的日志内容

grep "123456" demo.log | grep "aa"

 

 

如何查看当前进程?

netstat

 

Dockerfile是什么?如何去创建一个Dockerfile?

Dockerfile 是一个文本文件,其内包含了一条条的指令(Instruction),每一条指令构建一层,因此每一条指令的内容,就是描述该层应当如何构建。

  此处以定制 nginx 镜像为例,使用 Dockerfile 来定制。

  在一个空白目录中,建立一个文本文件,并命名为 Dockerfile :

$ mkdir mynginx
$ cd mynginx
$ touch Dockerfile

其内容为:

FROM nginx
RUN echo '<h1>Hello, Docker!</h1>' > /usr/share/nginx/html/index.html


这个 Dockerfile 很简单,一共就两行。涉及到了两条指令, FROM 和 RUN 。

 

Python有没有垃圾回收机制?它又是通过什么来的?

Python中的垃圾回收是以引用计数为主,分代收集为辅。引用计数的缺陷是循环引用的问题。

https://www.cnblogs.com/pinganzi/p/6646742.html

 

熟悉TESTNG,那请说一下TESTNG的用法?

略, 大致是testsuite,testcase,  testng.xml , 基本注解, listener(Listener包括ISuiteListenerITestListenerIInvokedMethodListener,他们可以在suite级别、test级别和test method一些执行点执行一些自定义操作,如打印日志。因)

 

熟悉JAVA,那请直接手写一个单例模式?

// 饱汉
// UnThreadSafe
public class Singleton1 {
  private static Singleton1 singleton = null;
  private Singleton1() {
  }
  public static Singleton1 getInstance() {
    if (singleton == null) {
      singleton = new Singleton1();
    }
    return singleton;
  }
}

 

数据库增删改查,手写SQL

略, 注意join , group by , having, count(ll)

 

redis是做什么用的?elasticsearch是什么?做什么用的?

Redis是一个开源的key—value型数据库,支持string、list、set、zset和hash类型数据。对这些数据的操作都是原子性的,redus为了保证效率会定期持久化数据。
使用场景:

1.配合关系型数据库做高速缓存

2.缓存高频次访问的数据,降低数据库io

3.分布式架构,做session共享

4.可以持久化特定数据。

5.利用zset类型可以存储排行榜

6.利用list的自然时间排序存储最新n个数据

ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。
Elasticsearch是用Java开发的,并作为Apache许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,
能够达到实时搜索,稳定,可靠,快速,安装使用方便。

 

 

接口测试怎么做的?如果存在接口依赖关系,怎么做?

略, 注意http/https接口,get/post, 参数的差异(json, url等等) 写一个传参函数,将需要传递的参数存储起来供下一条接口使用

 

元祖和列表的区别是什么?

元祖 tuple是有序列表 初始化之后,不能更改,元祖转换为列表:tuple-->list  list(tuple)

列表list 

函数:len()、append()、remove()移除列表中某个值的第一个匹配项、insert()、pop()、sort()、del、list()、reverse()、index()从列表中找出某个值第一个匹配项的索引位置、count()统计某个元素在列表中出现的次数、extend()在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)

删除:del list1[0]

 

 

Python中,arg和*kwarg分别代表什么含义,都有哪些作用?

https://www.jianshu.com/p/e0d4705e8293

当不确定函数传递多少个参数的时候,使用*arg, **kwarg

  • *arg会把多出来的位置参数转化为tuple
  • **kwarg会把关键字参数转化为dict

 

写过爬虫,那请说一下常见的反爬机制有哪些?如果是动态加载的页面,看不到数据,如何去进行爬取?

加入图片识别 ,使用代理,更新IP; 使用cookie登陆 

一般动态加载的数据都以json形式存储,在Filter里填json过滤,可以更加快速地寻找到想要的文件,但不是所有的网站都适用

 

posted on 2018-10-29 16:05  Charles-MQ  阅读(519)  评论(0编辑  收藏  举报

导航