资深测试总结,接口自动化测试常用配置文件(超细整理)

目录:导读

    • 前言
    • 一、Python编程入门到精通
    • 二、接口自动化项目实战
    • 三、Web自动化项目实战
    • 四、App自动化项目实战
    • 五、一线大厂简历
    • 六、测试开发DevOps体系
    • 七、常用自动化测试工具
    • 八、JMeter性能测试
    • 九、总结(尾部小惊喜)


前言

1、常用的配置文件类型

在做自动化测试中,配置文件常用的有2种。

第一种是.ini文件,实际上.ini文件是Initialization file的缩写,即为初始化文件,是Windows系统配置文件所采用的存储格式,统管Windows的各项配置,用户可以通过修改对应的*.ini文件来实现不同的初始化配置

第二种是yaml文件,YML文件格式是YAML (YAML Aint Markup Language)编写的文件格式,YAML是一种直观的能够被电脑识别的的数据数据序列化格式。

2、ini文件

1)什么是ini

ini文件是Initialization File的缩写,即初始化文件,通常存放的是一个程序的初始化信息,是Windows的系统配置文件所采用的存储格式,统管windows的各项配置。ini文件的后缀名不一定是.ini,也可以是.cfg、.conf或者是.tx*。

优点:
通用格式,格式简单

缺点:
不适合存储大量数据

2)ini文件格式&语法规范

ini文件由若干个节(section)组成,每个section由若干键(Key)组成,每个Key可以赋相应的值。读写ini文件实际上就是读写某个的section中相应的Key的值,而这只要借助几个函数即可完成。

参数(Parameter)
ini文件包含的最基本元素是参数,参数包含参数名(name)和参数值(value),格式如下:

name=value

节(section)
所有的参数都是以节为单位结合在一起。节名称独占一行,在节声明后的所有的参数都属于该节。节没有结束标识符,一个section的开始就是上一个section的结束。格式如下:

[section]

注释(comments)
注释用分号;表示,放在注释之前,;号后直到行尾均为注释。示例如下:

;i wish nothing but the best for you

文件实例

[owner]
name=WU yanzu
organization=The United Nations
[UserConfig]
OpenDownloadFileAtOnec=Y
WindowStyle=DevExpress Dark Style
[Language]
Language=CHS
[AutoUpdate]
Version=2.10  ;last version:2.08

注意点

[section]不能重复
同一个[section]key不能重复
等号前后不要用空格
默认类型为字符串
添加、删除、修改只是对内存进行修改,并不会修改实际文件

3)ini文件操作

# 导入包
from configparser import ConfigParser
# 实例化
conf = ConfigParser()
conf.read(‘test.ini’, encoding=“utf-8)
# 掌握
# 获取所有section
sections = conf.sections()
# 获取指定section下所有的key
keys = conf.options(‘log1’)
# 获取指定section下所有的key,value
val_list = conf.items(‘your_section’)
# 获取指定section指定key的值
# 默认读取str
value = conf.get(‘your_section’,’key’)
# 获取布尔值
booleans = conf.getboolean(‘your_section’,’key1’)
# 获取数字为int
number = conf.getint(‘your_section’,’key1’)
# 获取数字类型小数
float = conf.getfloat(‘your_section’,’key1’)
# 了解
# 添加sections(操作内存)
conf.add_section(‘your_section’)
# 添加key,val(操作内存)
conf.set(‘your_section’,’key22’,’val22’)
# 删除(操作内存)
conf.remove_option(‘your_section’, “key1”)
# 写入文件
# 将你内存你的数据全部写入文件进行覆盖,conf初始化的时候读取的是所有对象
conf.write(fp=open(file=file_path,mode=’w’))
import configparser
"""读取ini文件中节点/选项/选项值"""
config = configparser.ConfigParser()
config.read("config.ini")
"""读取ini文件所有的节点"""
selections = config.sections()
print(f"文件中所有的节点:{selections}", type(selections))
print("--------------------------------------------------")
"""获取每个节点下的选线"""
for selection in selections:options = config.options(selection)print(f"{selection}节点所有的选项:{options}", type(options))"""获取选项值"""for option in options:value = config.get(selection,option)print(f"{selection}节点{option}选项的值:{value}")
print("--------------------------------------------------")
"""获取指定节点下的所有options"""
options = config.options("server")
print(f"获取指定节点(server)下的选项:{options}", type(options))
print("--------------------------------------------------")
"""获取指定节点指定选项的值"""
value = config.get(section="server",option="ip")
print(f"获取指定节点(server)下的(ip)的值:{value}")
print("--------------------------------------------------")
"""判断是否有指定的selection"""
print(f"判断是否有指定的server节点:", config.has_section("server"))
print("--------------------------------------------------")
"""判断是否有指定的option"""
print(f"判断在在指定的节点server下是否有指定的ip选项:", config.has_option("server", "ip"))
print("--------------------------------------------------")
config1 = configparser.ConfigParser()
with open("config.ini", "a+") as file:"""添加节点"""config1.add_section("data")"""添加选项以及选项值"""config1.set(section="data", option="TestName", value="Test01")config1.set(section="data", option="TestPassWd", value="12345678")"""移除选项"""config1.remove_option(section="data",option="TestPassWd")"""移除节点"""config1.remove_section(section="data")config1.write(file)
from configparser import ConfigParser
import os
"""
继承ConfigParser类
然后初始化编码格式
"""
class ReadConf(ConfigParser):def __init__(self,file_path):super().__init__()self.read(filenames=file_path,encoding='utf-8')
file_path = os.path.join(os.path.dirname(__file__), 'test.ini')
conf=ReadConf(file_path=file_path)
#使用直接导入conf实例
from confFile.conffengzhuang import conf
values = conf.options('log1')
print(values)
# 输出:['key1', 'key2']

3、yaml文件

1)什么是yaml

YAML是一种广泛使用的语言,用于跨不同语言和框架的配置文件。专注于简化XML的XML人员名单帮助生成Common XML,这是一个功能强大的XML子集,为XML创建了数据序列化的替代方案,特别是与Python ,Perl和Ruby。

它的可读性和可编辑性感觉比json高,支持C++强类型。YAML文件可视为二维。有些库支持配置引用。有些库支持配置引用。

优点:
配置有序,容易阅读。
支持数组,数组中的元素可以是基本数据类型或者对象。
简洁方便,容易与脚本语言交互。
以数据为核心,重数据轻格式。
支持所有编程语言以及支持跨平台

缺点:
不支持 @PropertySource 注解导入自定义的 YAML 配置

2)yaml文件格式&语法格式

yaml特点:
大小写敏感
使用缩进表示层级关系
禁止使用tab键,只能使用空格键
缩进长度无限制,只要是对齐的就算是同一个层级
字符串可以不用引号标注
使用#进行注释
一个yaml文件对外只能有一个类型(读出来要么是dict,要么是list)
可一次性读取全部数据
读取出来的是python对象,可以直接使用

支持数据类型:
字典
通过(:)来连接,冒号后面要带一个空格
key: val
列表
使用连接字符(-)表示,- 后面要带一个空格

hello:
scalar、纯量
字符串、数字、布尔值、不可变数据类型文件实例
yaml文件操作
安装包
pip install pyyaml
导入包
import yaml

3)yaml文件操作
安装包
pip install pyyaml
导入包
import yaml

import yaml
def get_yaml_data(yaml_file):print("*****获取yaml数据*****")with open(yaml_file, encoding='utf-8') as file:content = file.read()print(content)print(type(content))print("*****转换yaml数据为字典或列表*****")# 设置Loader=yaml.FullLoader忽略YAMLLoadWarning警告data = yaml.load(content, Loader=yaml.FullLoader)print(data)print(type(data))print(data.get('my'))  # 类型为字典 <class 'dict'> # print(data[0]["model"]) # 若类型为列表 <class 'list'>
if __name__ == "__main__":get_yaml_data("config.yaml")

yaml键值对:即python中的字典

user: my
pwd: 1111
*****获取yaml数据*****
# yaml键值对:即python中的字典
user: my
pwd: 1111
<class 'str'>
*****转换yaml数据为字典或列表*****
{'user': 'my', 'pwd': 1111}
<class 'dict'>
my

yaml键值对嵌套:即python中的字典嵌套字典

user1:name: apwd: 111222
user2:name: bpwd: 222333
*****获取yaml数据*****
user1:name: apwd: 111222
user2:name: bpwd: 222333
<class 'str'>
*****转换yaml数据为字典或列表*****
{'user1': {'name': 'a', 'pwd': 111222}, 'user2': {'name': 'b', 'pwd': 222333}}
<class 'dict'>
{'name': 'a', 'pwd': 111222}

yaml键值对中嵌套数组

user3:- a- b
user4:- d- e
*****获取yaml数据*****
user3:- a- b
user4:- d- e
<class 'str'>
*****转换yaml数据为字典或列表*****
{'user3': ['a', 'b'], 'user4': ['d', 'e']}
<class 'dict'>
['a', 'b']

yaml中纯量

s_val: hello world
num_val: 15
bol_val: true
nul_val: null
data_val: 2023-08-17
*****获取yaml数据*****
s_val: hello world
num_val: 15
bol_val: true
nul_val: null
data_val: 2023-08-17
<class 'str'>
*****转换yaml数据为字典或列表*****
{'s_val': 'hello world', 'num_val': 15, 'bol_val': True, 'nul_val': None, 'data_val': datetime.date(2023, 8, 17)}
<class 'dict'>
hello world

yaml写入一组数据

current_path = os.getcwd()
path = os.path.join(current_path, 'config.yaml')
aproject = {'name': 'Silenthand Olleander','race': '哈哈哈黑','traits': ['ONE_HAND', 'ONE_EYE']}
# 写
with open(path, 'w', encoding='utf-8')as f1:# 字符串写入yaml中yaml.dump(aproject, f1, default_flow_style=False, encoding='utf-8', allow_unicode=True)
# 读
with open(path, 'r', encoding='utf-8')as f2:# 读取,此时读取出来的是字符串data = f2.read()# 将读取的内容转化成字典# 添加Loader=yaml.FullLoader,不然会有warningresult = yaml.load(data, Loader=yaml.FullLoader)print(result)

yaml写入多组数据

import yaml
import os
current_path = os.getcwd()
path = os.path.join(current_path, 'config.yaml')
user1 = {'name': '张三','age': 18,'like': {'kecheng': '语文','yundong': '跑步'}
}
user2 = {'name': '李四','age': 17,'like': {'kecheng': '数学','yundong': '跳高'}
}
# 写
with open(path, 'w', encoding='utf-8')as f1:# 字符串写入yaml中yaml.dump_all([user1, user2], f1, default_flow_style=False, encoding='utf-8', allow_unicode=True)
# 读
with open(path, 'r', encoding='utf-8')as f2:data = f2.read()# 添加Loader=yaml.FullLoader,不然会有warningresult = yaml.load_all(data, Loader=yaml.FullLoader)for i in result:print(i)
import yaml, os
class YamlUtil():def __init__(self, yaml_path):self.yaml_path = yaml_pathdef get_yml_data(self, is_modify=False, *key_names):"""读取yaml配置文件并根据对应层级的key获取对应的value适用于两层数据:param: key_names: 需要查询的yaml文件的key关键字,从左向右依次:return: result: 根据key值返回对应value,不传key则直接返回所有, 没有对应key则返回None"""with open(self.yaml_path, "r", encoding="utf-8") as f:content = f.read()yaml_content = yaml.safe_load(content)if is_modify:return yaml_contenttry:for key_name in key_names:yaml_content = yaml_content.get(key_name, None)return yaml_contentexcept Exception as e:print(f"get_yml_data error:{e}")return Nonedef set_yaml_data(self, value, *key_names):"""设置yaml文件中的相关属性:param: value:修改后的值:param: key_names: 需要修改的yaml文件的key关键字,从左向右依次"""yaml_content = self.get_yml_data(True, key_names)print(f'yaml_content:before:{yaml_content}')key_name = ''for item in list([[item] for item in key_names]):key_name += str(item)print(f'key_name:{key_name}')command = "yaml_content" + key_name + '=' + str(value)print(f'command:{command}')# exec:将字符串转换成python代码执行exec(command)print(f'yaml_content:after:{yaml_content}')with open(self.yaml_path, mode='w', encoding='utf-8') as f:f.write(yaml.safe_dump(yaml_content))
if __name__ == '__main__':YAML_PATH = os.path.join(os.path.dirname(__file__), 'config.yaml')yamlUtil = YamlUtil(YAML_PATH)print(yamlUtil.get_yml_data("test1", "test2-1"))print(yamlUtil.get_yml_data("test1", "test2-3", "test3-1"))yamlUtil.set_yaml_data(1234, "test1", "test2-1")yamlUtil.set_yaml_data(111, "test1", "test2-3", "test3-1")

一般在使用配置文件的时候,会采用ini文件,在测试数据上会采用yaml文件。同时在大部分的情况下,对于ini文件和yaml文件主要是以读取数据的操作为主,很少会对文件进行增删改操作。

下面是我整理的2023年最全的软件测试工程师学习知识架构体系图

一、Python编程入门到精通

请添加图片描述

二、接口自动化项目实战

请添加图片描述

三、Web自动化项目实战

请添加图片描述

四、App自动化项目实战

请添加图片描述

五、一线大厂简历

请添加图片描述

六、测试开发DevOps体系

请添加图片描述

七、常用自动化测试工具

请添加图片描述

八、JMeter性能测试

请添加图片描述

九、总结(尾部小惊喜)

坚持努力,放飞梦想,每一次坚韧的奋斗都是通往成功的阶梯,只要心怀信念,勇敢迈向前,终将收获属于自己的辉煌时刻。

在人生的道路上,坚持奋斗,勇敢前行,即使困难重重,也要坚定信念,不放弃希望,因为每一份努力都将迎来更美好的明天。

勇敢面对挑战,努力拼搏,相信自己的能力,坚持不懈地追逐梦想,只有不停地前行,才能到达心中向往的成功之地。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/512650.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

洗地机怎么选?2024年洗地机推荐,希亦、添可、追觅、石头哪一款清洁力更好?

洗地机是一款可以一遍搞定扫地和拖地一系列动作的清洁神奇&#xff0c;它能让我们真实的感受到打扫屋子是一件很减压的事情&#xff0c;但是目前市面上的洗地机太多了&#xff0c;大家都不知道怎么样的才算好&#xff0c;希亦、添可、追觅、石头洗地机值不值得买&#xff1f;我…

使用CSS制作动态的环形图/饼图

使用纯 CSS Animation conic-gradient 实现一个环形图。 饼图的实现思路和环形图一样&#xff0c;去掉中间的圆形遮盖 after 伪类元素即可。 一、构建基础样式 构建圆形节点和中间的遮盖元素。 <style>body {background-color: rgb(130, 226, 255);}.circle {top: 16…

5年爬到半山腰,我后悔了吗?

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号【互联网杂货铺】&#xff0c;回复 1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 软件测试是一个付出就有回报的工作&#xff0c;可能很多人会说软…

摄像头拉流低延迟(90ms内)实践和技术讲解

背景 作为网络摄像头拉流客户端&#xff0c;或者其他类型的流媒体播放而言&#xff0c;低延迟总是我们追求的重点性能要素。有一些低延迟方法可以在推流端设置&#xff0c;但倘若像摄像头这种场景&#xff0c;根本就无法控制摄像头端的自身延迟&#xff0c;只能从接收端动手。…

vs2022 qt 关于lnk2001和2019同时报错的问题

需要像qt中添加模块&#xff0c;这里&#xff0c;缺少qtopenglwidgets模块

前端- 基础 表单标签 - 使用场景及组成

大家都有到银行去办理业务的时候&#xff0c;大多数情况下会填一些 纸质的表之类的东西如下图 而我们在网页中也会经常遇到 像现实生活中在银行填表那样的情景&#xff0c;如下图 &#xff1a; 上示就是 网页中的表单的使用场景了 表单标签 &#xff1a; 为什么需要表单 …

llvm AST consumer 示例

示例源码 Makefile LLVM_CONFIG ? llvm-config #CXX : clang ifndef VERBOSE QUIET : endifSRC_DIR ? $(PWD) LDFLAGS $(shell $(LLVM_CONFIG) --ldflags) COMMON_FLAGS -Wall -Wextra CXXFLAGS $(COMMON_FLAGS) $(shell $(LLVM_CONFIG) --cxxflags) LCXX :$(shell $(L…

P1160 队列安排题解

题目 一个学校里老师要将班上N个同学排成一列&#xff0c;同学被编号为1∼N&#xff0c;他采取如下的方法&#xff1a; 先将1号同学安排进队列&#xff0c;这时队列中只有他一个人&#xff1b; 2∼N号同学依次入列&#xff0c;编号为i的同学入列方式为&#xff1a;老师指定编…

【Linux实践室】Linux常用命令

&#x1f308;个人主页&#xff1a;聆风吟 &#x1f525;系列专栏&#xff1a;Linux实践室、网络奇遇记 &#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 文章目录 一. ⛳️任务描述二. ⛳️相关知识2.1 &#x1f514;Linux文件操作2.1.1 &#x1f47b;创建文件2…

请说说你对Vue模板编译的理解

Vue模板编译是Vue.js框架的核心之一&#xff0c;它负责将Vue模板转换成渲染函数&#xff0c;从而实现模板的解析和渲染。要深入了解Vue模板编译&#xff0c;我们需要从编译过程、作用、特点等方面进行详细解析。 1. Vue模板编译的作用 Vue模板编译的主要作用是将Vue模板字符串…

软件测试 - 测试用例基本理论

1. 概念 为了特定的目的(该目的是检验代码是否满足用户需求)而设计的文档&#xff0c;文档包含测试输入、执行条件、预期结果等。文档的形式一般是excel表格。 比如说我们买了一台电脑&#xff0c;新买的笔记本检查完外观之后第一步需要查看电脑是否能够正常开机&#xff0c;…

DevOps中集成自动化测试的具体案例

在DevOps中集成自动化测试的具体案例可以从多个角度进行分析,包括金融行业、分布式系统、大型企业等不同领域的实践。以下是几个具体的案例: 金融行业的DevOps实践:在金融行业中,DevOps被广泛应用于提升软件开发和运营的效率。例如,通过解析后台接口代码日志格式,自动化生…