- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用来自 PyPI (https://pypi.python.org/pypi/httmock/) 的 httmock 来捕获 REST 请求并模拟它们。我将在我的单元测试代码中像这样使用它:
with httmock.HTTMock(my_request.token, my_request.put):
payload = {'host-name': 'TestHost'}
content = client.put_request('global/host-name',
payload=payload)
作为 put_request() 的一部分,客户端类将看到没有身份验证 token ,并且将首先向带有用户和密码的 POST 请求获取 token ,然后执行 PUT 请求。有断言来检查过程的结果。
我有大量测试,当我使用 tox 运行它们时,这些测试工作正常。但是,如果我运行完整的 tox 测试套件,我将有大约 30 个测试失败。他们都无法完成身份验证。
我将调试添加到 httmock.py 文件的副本和客户端代码中。我看到的是,在 enter() 处,它接受 requests.Session.send 并保存它,如预期的那样替换为拦截函数。但是,我从来没有看到在这些失败的情况下调用了 _fake_send() (没有看到日志消息)。结果,它没有返回任何内容(不是 token )并且测试失败。
这里是我做的一些带注释的日志记录:
1 DEBUG [drivers.httmock] Have 2 handlers
2 DEBUG [drivers.httmock] Enter requests.sessions
3 DEBUG [client] Authenticating with 'localhost'
4 DEBUG [client] POST: Request for .../api/v1/auth/...
5 DEBUG [client] >>> module drivers.httmock
6 DEBUG [client] POST Took 0.00 seconds to process
7 DEBUG [client] POST: Completed [401]
8 ERROR [client] Failed authentication with localhost [401]
[1] 显示 with 子句注册了两个处理程序。 [2] 在上下文管理器的 dunder enter 中,requests.Session.send 指向正常的模块/函数。 [4] 是调用 requests.request() 之前的客户端。 [5] 显示 requests.Session.send 已经交换到 httmock。我原本希望在 [6] 看到 httmock 尝试处理程序的日志,但我看到的是显示调用已完成的客户端消息。
我查看了请求库,request() 创建了一个 session 并按预期调用了 session.Session.send()。
我不是很肯定,但我认为随着完整套件的运行,tox 将并行运行测试。
有人知道我哪里做错了吗?
最佳答案
发现 httmock 将 session.send() 替换为伪方法,该方法会尝试为上下文管理器定义的各种处理程序。
我的代码调用了 requests.request(),它创建了一个新的 session ,调用了 session.request(),它调用了 session.send(),并且模拟没有拦截 send() 调用。
我的猜测是因为如果使用 requests.* API,requests 会为每次调用启动一个新 session 。发现我的生产代码可以创建一个请求 session ,然后为每次调用使用相同的 session (并使用 session 的 request() 方法而不是 requests.request() 方法)。
一旦完成,这现在可以在完整的 tox 运行中运行,顺便说一下,它使用多个线程来运行测试方法(方法级别的线程)。
关于python - httmock 在运行 tox 时不拦截 requests.send(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22109730/
我很难理解为什么这段代码无法编译: use std::cell::{Ref, RefCell}; struct St { data: RefCell } impl St { pub f
我从Richard Blum的一本书《 C#网络编程》中读到有关套接字的信息。以下摘录指出,不保证Send()方法可以发送所有传递给它的数据。 byte[] data = new byte[1024]
我有以下程序,它必须一次读取 1MB 的文件,将其发送到服务器(每次总是 1MB)并返回哈希码: #include #include #include #include #include #
代码在底部。 第 207 行的 send() 命令本身可以正常工作。但是,当我在第 218 行添加 send() 命令时,第一个命令失败 - 给出错误“地址错误”。我已经确认第二个 send() 命令
标记包含 !Send 的类型背后的原因是什么?字段(如 Rc 或 NonNull )与 Send特征?例如,标准库的 LinkedList 以这种方式工作:它包含 Option>字段并实现 Send特
我是新手,我正在尝试学习 goroutines 中信号函数的一些基本用法。我在 go 中有一个无限循环。通过这个 for 循环,我通过 channel 将值传递给 goroutine。 我也有一个阈值
如果数据是从另一台计算机(首先)“发送”的,我如何设置我的套接字例程以“发送”(首先)或(切换)“接收”? 谢谢 通用代码: -(void) TcpClient{ char buffer[12
这个问题已经有答案了: Java multiple file transfer over socket (3 个回答) 已关闭 4 年前。 我正在使用 Java Socket 将文件发送到服务器,然后
根据以下示例中的类型,Go编译器似乎将执行两个完全不同的语义操作: chanA <-chanB 如果chanA是类型(chan chan <-字符串),则此操作会将本身类型chanB的类型(chan
我正在尝试在 VBA 中使用 WinSock2 从本地主机 TCP 流发送(以及稍后接收)数据。 目前,我主要尝试从此处复制客户端示例,https://msdn.microsoft.com/en-us
我在我的 Mac OS X Yosemite 控制台中看到了这个: AppleEvents: Send port for process has no send right, port=( port:
我知道Clojure的“代理”是ref,带有“操作”的添加工作队列。 Action 是使用ref的值在第一个位置调用的函数,可以将其传递给其他参数。操作将返回ref的新值。因此,“代理”是一种计算re
我无法将任何对象或数组传递给 IPCRenderer。 通过 ipcs 传递对象或数组时出现错误,我什至尝试通过使用 JSON.stringify 转换为字符串来发送,但它会将其转换为空对象字符串。
我正在使用unix scoket进行数据传输(SOCK_STREAM模式) 我需要发送超过100k个字符的字符串。首先,我发送一个字符串的长度-它是sizeof(int)个字节。 length = s
Clojure API 将这两个函数描述为: (send a f & args) - Dispatch an action to an agent. Returns the agent immedia
def send_Button(): try: myMsg = "ME: " + text.get() msg = text.get() con
Ruby 对象都有一个“发送”方法,但是,我正在尝试使用一个 Java 库 ( netty-tools ),它的一个接口(interface)上有一个“发送”方法。 用法应该是 java_obj.se
Feb 8, 2011 11:56:49 AM com.sun.xml.internal.messaging.saaj.client.p2p.HttpSOAPC onnection post SEVE
来自 man 2 send: MSG_MORE (since Linux 2.4.4) (…) Since Linux 2.6, this flag is also supported for UDP
我的网页中可以有一个按钮,用于将预填充的消息发送到特定号码吗? 我正在尝试 intent://send/+391234567890#Intent;scheme=smsto;package=com.wh
我是一名优秀的程序员,十分优秀!