今天,我们要学习的是自动化测试中的配置类封装,使得我们能够更方便的获取配置数据。话不多说,进入正题。
1.conf配置文件
首先我们要知道的是,在一个项目中,好多地方是可以进行动态配置的,那么我们会将配置数据写到统一的文件中,在我们的python项目中,我们会将配置文件写在以“.conf”后缀结尾的文件中。
如上图,我们直接右键-->New-->file一个文件,创建出一个以.conf结尾的文件就可以了。那么在配置文件中我们要怎么写配置数据呢?,直接见下图:
如上图,我们写配置数据,要注意三个概念:
箭头1:是我们的“模块名”,何为模块名呢?就是我们的一个模块,比如说,对于测试用例结果相关的配置,我们的模块名就是"[case_result]",对于日志模块相关的配置,我们的模块名就是“[logging]”,除了这些,还有很多,比如和账号相关的,我们就可以写一个模块名为“[accounts]”。这里要注意的是,模块名必须用中括号“[]”括起来。
写完模块名,我们就可以写模块下相关属性了。
箭头2:属性都是以“属性名 = 值”的形式出现,如图所示:测试用例结果配置中,我们想配置测试用例的两个结果,一个为正确,一个为错误,这边成功用值“Pass”表示,失败用“Fail”表示,如果下次想用1和0表示成功或者失败,那么可以在这边动态的修改值。
箭头3:在配置文件中,我们还可以添加注释,和python文件一样,用#来代表注释,这里要注意的是,我们的注释只能单独开一行,不能够写在配置属性值的后面,如果写在配置属性值的后面,在解析拿值的时候会报错!
关于配置文件,我们先简单的介绍到这里。
2.ConfigParser模块
ConfigParser是python中的configparser库下的类,我们用来处理配置文件。我们通过ConfigParser类的实例去读取某个配置文件,然后通过get去获取配置的相应值,如下:
self.config = ConfigParser()
if self.file_name is None:
"""获取默认路径下的配置文件"""
self.config.read(CONFIG_FILE_PATH, encoding="utf-8")
else:
"""获取指定路径下的配置文件"""
self.config.read(self.file_name, encoding="utf-8")
如上面代码,我们通过ConfigParser实例的read方法,传入配置文件地址,以及编码类型,获取配置信息对象config。获取到configle对象以后,我们通过它就可以获取配置信息的所有数据。比如我们获取上上面所说的测试结果模块的success_result值,代码如下:如图,通过read方法获取到配置文件对象后,我们可以通过get("模块名",“属性名”)获取相应配置属性的值,如果是get()方法,那么获取到的属性值都是字符串类型,我们也可以根据不同的属性值类型用不同的get方法。比如图上我们获取port属性值用的是getInt()方法,结果返回的就是int类型的值,如果属性值是布尔型,我们就可以使用getboolean()方法,如果是float类型,就用getfloat()方法,依此类推。
3.处理配置文件的代码分装
为了对配置文件进行统一处理,我们进行一个封装,因为本身处理配置文件的操作也比较简单,所以封装起来也比较简单,有需要的可以借鉴,代码如下:
from configparser import ConfigParser
from scripts.constant_url import CONFIG_FILE_PATH
class ConfigLoader:
def __init__(self, file_name=None):
self.file_name = file_name
self.config = ConfigParser()
if self.file_name is None:
"""获取默认路径下的配置文件"""
self.config.read(CONFIG_FILE_PATH, encoding="utf-8")
else:
"""获取指定路径下的配置文件"""
self.config.read(self.file_name, encoding="utf-8")
def get_value(self, section, option):
# 通过section,option 来取到配置项的值
return self.config.get(section, option)
def get_boolean(self, section, option):
return self.config.getboolean(section, option)
def get_int(self, section, option):
return self.config.getint(section, option)
def get_float(self, section, option):
return self.config.getfloat(section, option)
def get_eval_data(self, section, option):
"""
获取列表形式的配置值
:param section:
:param option:
:return:
"""
return eval(self.get_value(section, option))
@staticmethod
def write_config_data(config_data, file_name):
"""
保存传入的内容为字典的列表类型的配置数据
:param config_data: 容为字典的列表类型的配置数据
:param file_name: 文件名
"""
config = ConfigParser()
for key in config_data:
config[key] = config_data[key]
with open(file_name, "w") as file:
config.write(file)
总结
由于对于配置文件的操作比较简单,在这里不多进行阐述。打完收工!!