如何从vcrpy二进制响应字符串中提取未压缩的文本



我正在使用vcrpy对我的应用程序进行自动http模拟测试。这很有效。然而,我的嘲讽包括编码"gzip"one_answers"deflate",这意味着vcrpy录制的响应是二进制格式的。这里有一个例子:

interactions:
- request:
    body: null
    headers:
      Accept: ['*/*']
      Accept-Encoding: ['gzip, deflate']
      Authorization: [Basic Y2hlc3RlcjpiYWRnZXI=]
      Connection: [keep-alive]
      User-Agent: [python-requests/2.9.1]
    method: GET
    uri: http://localhost:8153/go/compare/DeployProduction/14/with/15
  response:
    body:
      string: !!binary |
        H4sIAAAAAAAAAO08bXPbNpPf8ytQ9q6yp+Y7KZGKrU7quG1mEscXO7276XQ0IAlKjCmCQ0KW9TxP
        /vstAJIiJUpxkkvS3tmTiSRisVjsG3YXIE6/e/76/Oa/ry7QbzevXk6enM7ZIkX3izQrz5Q5Y/lY
        11erlbayNVrMdNP3ff2ewygcluBo8gTB3ylLWErk93O6yHFB0FWSkzTJSImu8IwgFf1Kn5zqFeCT
        U2i6RREJlrMzJcZpSRQ0L0h8pugzquOyJKzUcZ6nSYhZQjPVCG0PE9saObHthJbjE2L79tCPhhY2
        ImxZlhEH2Hbt0PB8NyCBZ8RO6NsksoZDi1haWJYKWpAowWcKTlMFFSQ9U0q2Tkk5J4QpSJ88jKwc
        M0aKrEtf6EeBEYXG0ByFERmR2A9sO8CmPzR8LyAYEyOwwpHj48COseOaLgmsUehiHAxjOzYfRt+T
        0+9UFV3fPHtzM0Z5QRll65ygOaW3JYppgQALSrJ3JOREIVWtu1xcPn94hzIskpxtsaEswr3CCYwA
        pjUMh8Qf+iZIY2hGpu063iiyTOyDUPxRbFrRyPJHxHRBIiChKIij2LfMUWxo70plcqrLcUEK3/2R

(省略附加输出)

我读过关于解压缩zlib的文章,但它没有解决解码二进制yaml的问题。

为了查看原始文本并验证测试结果,我如何将这些二进制字符串转换为原始格式?

yaml文件中的主体字符串是base64编码的,但当您加载它时,您将获得原始字节流。如果你很好奇,请阅读如何解码base64字符串,尽管这不是必要的。

如果前三个字节是x1fx8bx08,那么您就知道您有一个gzip字节流。如果你想手动解码,请阅读此处,但vcr有一个包装器方法,它也会在解码正文后更新一些标头信息。此函数为vcr.filters.decode_response()

为了用一个例子来演示这一点,我将使用文件\tests\fixtures\wild\domain_redirect.yaml。有两个交互,其中第二个包含编码数据。

import yaml
from vcr.filters import decode_response 
with open('domain_redirect.yaml', 'r') as f:
    doc = yaml.load(f)
response = doc['interactions'][1]['response']
decoded = decode_response(response)
print(decoded['body']['string'])

最新更新