问题(二)

1、字典排序使用到的函数具体是哪个?举例说明
sorted

2、字符串格式化使用到的关键字是哪个,举例说明
formant

3、列表中append()与insert()的区别是什么?举例说明
append()是在列表的最后添加
insert()是按索引添加

4、列表与元组的区别是什么
列表是可变的,元组是不可变的

5、查看一个对象的类型关键字是什么?查看对象的内存地址关键字是什么
type,id

6、怎么获取字符串的索引信息
使用enumerate()遍历字符串获得索引

7、举例说明列表推导式的使用

list1 = [x for x in range(0, 10)]
print(list1)


8、当元组只有一个对象的时候,需要注意什么?
当元组只有一个对象需要加逗号

9、怎么理解函数的返回值?
返回值关键字是return,函数的返回值可以是函数的形式参数
输出结果时都会返回结果,没有加return,它返回的是None,加return返回指定内容

10、怎么理解函数的动态参数
当函数数据类型不确定的时

11、字符串与列表之间的互相转换
使用到的关键字split()对指定字符进项转换

str1 = "hello word"
str_list = str1.split(',')
print(type(str_list))
print(str_list)

list_str = '-'.join(str_list)
print(type(list_str))
print(list_str)

 

12、字符串的替换使用到的方法是?
replace()将指定字符替换

str1 = "hello python"
print(str1.replace('python', 'word'))


13、怎么理解is,in,==
is:判断两个字符串的内存地址
=:判断两个数是否相等
in:判断两个对象,一个对象里是否包含另一个对象

14、使用os库编写一个文件的路径拼接

import os
base_dir=os.path.dirname(os.path.dirname(__file__))
   
f=open(os.path.join(base_dir,'函数/log.txt'),'r')
print(f.read())

 

15、怎么理解序列化与反序列化

序列化 :把python对象转换为字符串的数据类型,(把 python的数据类型(字典、元组,列表),转换为str数据类型的过程)

反序列化:就是把str的数据类型转换为python对象的过程(把str数据类型转换为python的数据类型(字典、元组,列表)的过程)

 

16、举例说明文件的a,w,r的模式

def fileW():
    """W模式,创建文件,并把文件写进去"""
    a = open(file='a.sys', mode='w')
    a.write('nihao')
    a.close()
fileW()

def fileA():
    """A模式,在原有基础上添加内容"""
    a = open(file='a.sys', mode='a',encoding='utf-8')
    a.write('buhao')
    a.close()
fileA()

def readFile():
    a = open(file='a.sys', encoding='utf-8')
    # 读取文件
    # print(a.read())
    # 读取文件里面的第行内容
    # print(a.readline())
    # 换行读取文件里面的所有内容
    for item in a.readlines():
        print(item.strip())
readFile()

 

18、怎么理解编码与解码

编码:就是把str的数据类型转为bytes的数据类型的过程,使用到的关键字是encode
解码: 把bytes的数据类型转为str的数据类型的过程,使用到的关键字是decode
19、使用datetime获取当前的时间

import datetime
import time
  
print('获取当前时间:', datetime.datetime.now())

20、使用time等待5秒的时间

import time

time.sleep(5)

21、怎么理解装饰器

在很多程序都要修改一个内容时,使用装饰器可以一次性解决


22、怎么理解局部变量与全局变量

全局变量:在一个Python文件里面,定义的变量,可以把它理解为全局变量,在Python文件中,全局变量的优先级是高于
局部变量的
局部变量:在一个Python文件里面的函数里面,定义的变量,可以理解为局部变量,在函数内部,局部变量的优先级是高于
全局变量的
在函数内部使用全局变量的时候,可以使用关键字global来引用,global申明全局变量


23、Java的继承与Python的继承有什么区别

Java的继承是单继承

Python的继承是多继承


24、如果子类重写了父类的方法,那么实例化子类后,调用重写后的方法,调用的是子类的方法还是父类的方法
子类


1、查看进程的命令

ps
2、查看端口的命令

lsof -i: 端口号
3、赋予文件权限的关键字

chmod
4、r,w,x对应的数字是多少

r --> 4
w --> 2
x --> 1
5、给一个文件给rwx权限

chomd 421 文件名
6、git提交文件的命令是什么

git add 文件名

git commit -m " "
7、git创建仓库的命令是什么

git init
8、查看内存的命令

free
9、编辑文件的步骤

步骤一:touch创建新的空白文件

步骤二:vim 进入编辑文件,添加文字

步骤三:Esc+:wq保存文件

10、查看文件前5行的命令

head -n 5
11、查看文件后10行的命令

tail -n 10
12、文件查看命令

cat 

13、平均负载怎么查看

uptime

 

测试基础理论:
1、bug完整的生命周期

发现BUG-->提交BUG-->指派BUG-->研发确认BUG-->研发去修复BUG-->回归验证BUG-->是否通过验证-->关闭BUG
2、编写测试用例的要素是什么?

⽤例ID;
⽤例名称;
测试⽬的;
测试级别;
参考信息;
测试环境;
前提条件;
测试步骤;
预期结果;
设计⼈员。

3、怎么理解黑合测试,白盒测试

黑盒测试:功能测试

白盒测试:
可以看见程序的内部的结构关系,是代码级别测试,针对函数或者方法、逻辑准确性的测试。
这些测试就包含了针对程序判断逻辑,判断分⽀,判断循环,程序流程⾛向的测试。

4、测试按阶段划分,主要分为那几个阶段

单元测试
集成测试
系统测试
验收测试


5、怎么理解等价类和边界值

等价类是对输入数据 进行测试,分有效等价类和无效等价类 ,
如:年龄分数在0-100之间,有效等价类就是0-100之间的数字
无效等价类 就是,小于0,大于100的数字,
边界值是对等价类的补充
6、请描述一个完整的测试流程

 

UI自动化测试:
1、常用的元素定位有那几种方法,请举例说明

class By(object):

ID="id"

XPATH="xpath"

LINK_TEXT="link text"

PARTIAL_LINK_TEXT="partial link text"

NAME="name"

TAG_NAME="tag name"

CLASS_NAME="class name"

CSS_SELECTOR="css selector"

2、单个元素定位与多个元素定位的区别是什么?

单个元素定位:find_element

多个元素定位:find_elements

单个元素定位和多个元素定位的区别就是,单个元素定位返回是单个元素,多个元素定位返回的是包含多个元素的一个列表。
3、如果是iFrame的框架,如何来定位里面的元素属性的对象

或者id定位:

driver.switch_to.frame('login_frame')

使用索引:

driver.switch_to.frame(0)

4、怎么理解页面对象设计模式

在 UI 自动化测试中对页面元素的处理引入面向对象思想。从测试用例中剥离页面元素操作,并以页面为单位的类将页面元素上的定位方式及操作进行封装。
5、怎么理解显式等待和隐式等待

显示等待:显式等待指定某个条件,然后设置最长等待时间。如果在这个时间还没有找到元素,那么便会抛出异常了。

隐式等待:等待时间完成即可(单位:秒)默认等待时间为0
6、在测试中遇到多窗口,具体怎么解决,请描述具体的步骤和编写具体的案例代码

1、循环所有的窗口
2、判断是否是当前窗口
3、如果不是,切换到新的窗口
4、在新的窗口进行操作
5、关闭新的窗口
6、切换到最开始窗口

'''注册网易邮箱超链接'''
driver=webdriver.Chrome()
driver.maximize_window()
driver.get('https://mail.163.com/')
oldwindow=driver.current_window_handle
driver.find_element_by_xpath('//*[@id="normalLoginTab"]/div[1]/div[2]/a[1]').click()
t.sleep(3)
allwindow=driver.window_handles
for window in allwindow:
    if oldwindow!=window:
        driver.switch_to.window(window)
        t.sleep(3)
driver.find_element_by_class_name('j-register').click()
t.sleep(3)
dtest=driver.find_element_by_xpath('/html/body/div[2]/div/div/div[2]/div[2]/div[1]/div[2]')
assert dtest.text=='邮箱地址不能为空'
driver.switch_to.window(oldwindow)
t.sleep(2)
driver.quit()

  单元测试框架:
1、unittest与pytest的框架

 

2、unittest的常用组件有哪些

TestCase:测试用例,测试用例里面会有很多测试方法,是单元测试中最小维度的测试行为。

TestSuite:测试套件,是测试用例的集合。

TestFixure:测试固件,测试准备工作和收尾工作,打开和关闭浏览器,链接和关闭数据库,可有可无

TestRunner:测试运行器,运行测试用例。

TestReport:将测试结果呈现给用户,生成测试报告。

3、unittest中怎么理解测试固件

 setUp() 方法用于初始化测试固件;而 tearDown() 方法用于销毁测试固件

setUp() :最开始执行

tearDown():最后执行

 

4、怎么理解setUp(),tearDown()与类测试固件的测试

局别:

setUp(),tearDown()每次都要执行
类测试固件只执行一次

5、在unittest测试框架中,加载所有的测试模块使用到的方法是什么?具体参数是什么?

用到的方法:discover

具体参数

路径参数,测试文件名

6、在unittest中使用那个库来生成对应的测试报告

import HTMLTestRunner

7、一个完整的测试用例包含哪些步骤

拿到测试需求 -> 分析需求(画思维导图) -> 编写⽤例 -> 划分⽤例优先级
8、怎么理解参数化

解决的问题:

测试进行相同的步骤,只是输入的数据不同,其他操作都是一样的,这样需要写很多测试用例,参数化可以解决这种问题,让代码更加简洁。

9、一个完整的自动化测试用例包含哪些?

(1)测试准备

(2)测试用例

(3)测试收尾
10、测试用例之间可以依赖吗?

不可以,测试用例是单独的

posted @ 2021-09-04 20:58  星德川  阅读(82)  评论(0)    收藏  举报