'SubRequest' object has no attribute 'parm'
时间: 2023-08-22 10:09:53 浏览: 77
引用<span class="em">1</span><span class="em">2</span>
#### 引用[.reference_title]
- *1* *2* [如何测试pytest设备本身?](https://blog.csdn.net/weixin_39922929/article/details/110534832)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
相关问题
AttributeError: 'SubRequest' object has no attribute 'params'
Error: 'SubRequest' object has no attribute 'params'是一个常见的错误,它通常发生在使用Python的requests库时。这个错误的原因是你试图访问一个不存在的属性或方法。在这种情况下,你试图访问一个名为params的属性,但是这个属性在SubRequest对象中不存在。
解决这个问题的方法是检查你的代码,确保你正在访问正确的属性或方法。如果你确定你的代码没有问题,那么可能是因为你的requests库版本过低,你需要升级到最新版本。
```python
# 示例代码
import requests
url = 'https://www.example.com'
response = requests.get(url)
params = {'key': 'value'}
response = requests.get(url, params=params)
```
self = ChainMap({}, {'im30': 'pax_branch_7.0_3.xx_release', 'im30v2': 'A133_V2_4_T509_pax_branch_release', 'a80': 'pax_branch...3700': 'MTK_android11_pax_branch_user', 'a8300': 'A133_V2_4_pax_branch_release', 'a6650': 'A6650_pax_branch_user'}, {}) key = 'a80s' def __missing__(self, key): > raise KeyError(key) E KeyError: 'a80s' /usr/lib/python3.8/collections/__init__.py:890: KeyError During handling of the above exception, another exception occurred: request = <SubRequest 'upgrade_os_by_fastboot' for <Function test_Antutu_Score_PER1>> get_device_in_config = ('172.16.120.187:6714', '172.16.25.170', 'false', 'A80S', True) get_sn_fastboot_sn = {'1240047508': '241050374620301a044f', '1240193065': '140050344410142b03ce', '1640000442': '1400788643245025084f', '2210000495': 'NRUO65VOT4TWON99', ...} @pytest.fixture(scope='session', autouse=False) def upgrade_os_by_fastboot(request, get_device_in_config, get_sn_fastboot_sn): """ 更新固件 """ _serial, ip, regex, device_name, is_version_test = get_device_in_config # 一些配置参数 # _serial = get_serial logger.info(exec_cmd("adb devices -l")) if util.wait_for_device(_serial, timeout=10 * 60) is False: assert False, "{} device is offline".format(_serial) return # 优先从命令行获取 fastboot_sn = request.config.getoption(CmdOption.DEVICE_FASTBOOT.value) if fastboot_sn is None: fastboot_sn = get_sn_fastboot_sn.get(_serial) if fastboot_sn is None: logger.warning(f"也许你需要在{get_sn_fastboot_sn_map_path()}配置对应的fastboot sn") fastboot_sn = _serial path = os.getcwd() logger.info("upgrade_os_by_fastboot path:%s" % path) logger.info(exec_cmd("rm -rf ./Uniphiz_*")) logger.info(exec_cmd("rm -rf ./PayDroid_*")) logger.info(exec_cmd("rm -rf ./IM30_A80_PayDroid_*")) if is_version_test is False: # CI的日常测试任务 upgrade_result = upgrade_now(_serial, device_name, fastboot_sn, "", "fastboot") else: # CI的版本测试任务 > upgrade_result = upgrade_now_version_test(_serial, device_name, fastboot_sn, "", "fastboot") ../CI_Code_Pull/tests/conftest.py:209: 这是什么错误
这是一个KeyError错误。在你的代码中,`__missing__`方法被调用时,抛出了一个KeyError异常,因为在字典中找不到键为'a80s'的值。
在这段代码中,你定义了一个名为`self`的ChainMap对象,并在其中存储了多个字典。当你使用`self['a80s']`来获取键为'a80s'的值时,由于字典中没有该键,触发了`__missing__`方法。
在`__missing__`方法中,你抛出了一个KeyError异常,该异常表示字典中找不到指定的键。然后,在捕获到这个KeyError异常后,又触发了另一个异常,导致整个错误堆栈。
要解决这个问题,你可以检查一下是否正确设置了ChainMap对象中的字典,并确保你要获取的键存在于其中。也可以考虑在`__missing__`方法中提供一个默认值,以避免抛出异常。