Python 单双下划线方法在接口自动化中的高级用法(_、__)

开发 前端
今天一起来了解一下python 单双下划线方法在接口自动化中的高级用法吧。

使用单下划线 _ 来封装内部方法

使用场景:

在一个 HTTP 请求客户端类中封装一个内部方法,该方法用于处理请求的响应。

这个方法只应该在类的内部使用,不应该被外部直接调用。

import requests
class HttpClient:
    def __init__(self, base_url):
        self.base_url = base_url
    def _handle_response(self, response):
        if response.status_code != 200:
            raise Exception(f"Request failed with status {response.status_code}")
        return response.json()
    def get(self, endpoint):
        url = f"{self.base_url}/{endpoint}"
        response = requests.get(url)
        return self._handle_response(response)
client = HttpClient("https://api.example.com")
data = client.get("/resources")
print(data)

注意事项:

_handle_response 方法是内部使用的,不应从类外部直接调用。

确保处理所有可能的异常情况。

使用双下划线 __ 来实现初始化逻辑

使用场景:

在接口测试类中,使用 __init__ 方法来设置基本的测试配置,比如 URL、认证信息等。

import requests
class TestAPI:
    def __init__(self, base_url, auth_token):
        self.base_url = base_url
        self.auth_token = auth_token
    def test_get_resources(self):
        headers = {'Authorization': f'Bearer {self.auth_token}'}
        response = requests.get(f"{self.base_url}/resources", headers=headers)
        assert response.status_code == 200
test_api = TestAPI("https://api.example.com", "my-token")
test_api.test_get_resources()

注意事项:

确保 __init__ 方法设置了必要的初始化参数。

注意处理可能的认证失败情况。

使用双下划线 __ 来实现字符串表示

使用场景:

在接口测试结果类中,使用 __str__ 方法来自定义输出格式,便于查看测试结果。

class TestResult:
    def __init__(self, passed, message):
        self.passed = passed
        self.message = message
    def __str__(self):
        status = "Passed" if self.passed else "Failed"
        return f"{status}: {self.message}"
result = TestResult(True, "All tests passed")
print(result)

注意事项:

__str__ 方法应返回易于理解的字符串。

确保测试结果的格式清晰明了。

使用双下划线 __ 来实现布尔值转换

使用场景:

在测试结果类中,使用 __bool__ 方法来判断测试是否通过。

class TestResult:
    def __init__(self, passed, message):
        self.passed = passed
        self.message = message
    def __bool__(self):
        return self.passed
result = TestResult(True, "All tests passed")
assert bool(result), "Test should pass."

注意事项:

__bool__ 方法应返回布尔值。

注意处理边缘情况,如未完成的测试等。

使用单下划线 _ 来封装内部属性

使用场景:

在接口测试类中,使用单下划线 _ 来标记内部使用的属性,如认证信息。

class TestAPI:
    def __init__(self, base_url, auth_token):
        self.base_url = base_url
        self._auth_token = auth_token
    def test_get_resources(self):
        headers = {'Authorization': f'Bearer {self._auth_token}'}
        response = requests.get(f"{self.base_url}/resources", headers=headers)
        assert response.status_code == 200
test_api = TestAPI("https://api.example.com", "my-token")
test_api.test_get_resources()

注意事项:

单下划线 _ 标记的属性不建议从类外部直接访问。

确保在类内部正确使用这些属性。

使用双下划线 __ 来实现类的实例化

使用场景:

在测试框架中,使用 __new__ 方法来控制类的实例化过程,例如,只允许创建一个实例。

class SingletonTestFramework:
    _instance = None
    def __new__(cls, *args, **kwargs):
        if not cls._instance:
            cls._instance = super(SingletonTestFramework, cls).__new__(cls)
        return cls._instance
framework = SingletonTestFramework()
another_framework = SingletonTestFramework()
assert framework is another_framework

注意事项:

__new__ 方法用于控制实例的创建过程。

注意单例模式的实现细节。

使用双下划线 __ 来实现格式化输出

使用场景:

在测试报告类中,使用 __format__ 方法来自定义输出格式。

class TestReport:
    def __init__(self, name, result):
        self.name = name
        self.result = result
    def __format__(self, format_spec):
        if format_spec == "short":
            return f"{self.name}: {self.result}"
        return f"{self.name}: {self.result} (full report)"
report = TestReport("Test Name", "Passed")
print(f"{report:short}")

注意事项:

__format__ 方法应支持不同的格式化选项。

注意处理格式化字符串的解析。

使用双下划线 __ 来实现比较操作

使用场景:

在测试结果类中,使用 __eq__ 方法来自定义相等性比较。

class TestResult:
    def __init__(self, passed, message):
        self.passed = passed
        self.message = message
    def __eq__(self, other):
        if isinstance(other, TestResult):
            return self.passed == other.passed and self.message == other.message
        return False
result1 = TestResult(True, "All tests passed")
result2 = TestResult(True, "All tests passed")
assert result1 == result2

注意事项:

__eq__ 方法应正确比较对象的内容。

注意处理不同类型的对象之间的比较。

使用双下划线 __ 来实现对象的删除

使用场景:

在测试框架中,使用 __del__ 方法来清理资源,如关闭连接。

import requests
class TestFramework:
    def __init__(self, session):
        self.session = session
    def __del__(self):
        self.session.close()
session = requests.Session()
framework = TestFramework(session)
del framework

注意事项:

__del__ 方法用于对象销毁时的资源清理。

注意处理异常情况下的资源释放。

使用双下划线 __ 来实现对象的复制

使用场景:

在测试配置类中,使用 __copy__ 和 __deepcopy__ 方法来自定义浅拷贝和深拷贝行为。

import copy
class TestConfig:
    def __init__(self, name, settings):
        self.name = name
        self.settings = settings
    def __copy__(self):
        return TestConfig(self.name, self.settings.copy())
    def __deepcopy__(self, memo):
        return TestConfig(self.name, copy.deepcopy(self.settings, memo))
config = TestConfig("Test Config", {"key": "value"})
shallow_copy = copy.copy(config)
deep_copy = copy.deepcopy(config)
config.settings["key"] = "changed"
assert config.settings["key"] == "changed"
assert shallow_copy.settings["key"] == "changed"
assert deep_copy.settings["key"] == "value"

注意事项:

__copy__ 和 __deepcopy__ 方法用于自定义复制行为。

注意处理复杂数据结构的复制。

责任编辑:华轩 来源: 测试开发学习交流
相关推荐

2023-11-29 18:11:17

Python代码

2023-11-09 08:55:17

Python双下划线

2021-08-08 22:27:13

Python下划线方法

2010-03-04 10:35:51

Python下划线

2024-02-28 16:04:04

深拷贝Python

2021-07-31 19:21:34

Python下划线数值

2020-09-22 09:41:48

Python下划线开发

2021-12-26 22:55:26

Python下划线编程

2024-04-30 15:05:36

Python接口自动化

2024-08-19 10:21:37

接口Python魔法方法

2024-08-16 22:00:38

2021-10-20 07:36:03

Python构造方法

2013-07-24 19:27:45

iOS开发学习自定义带下划线文本UI

2024-01-08 13:31:00

Rust自动化测试

2022-10-09 11:07:40

物联网如自动化

2024-02-26 00:00:01

​win32WindowsCOM

2020-10-24 11:09:35

Python下划线用法

2021-03-11 14:23:17

云计算混合云工具

2021-03-02 10:55:07

云计算自动化云应用

2022-06-26 09:55:00

接口自动化项目
点赞
收藏

51CTO技术栈公众号