diff --git a/multipart/multipart.py b/multipart/multipart.py index 9c4bafd..935daa3 100644 --- a/multipart/multipart.py +++ b/multipart/multipart.py @@ -1620,7 +1620,9 @@ def _on_end() -> None: is_file = False def on_part_begin(): - pass + # Reset headers in case this isn't the first part. + nonlocal headers + headers = {} def on_part_data(data: bytes, start: int, end: int) -> None: nonlocal writer diff --git a/tests/test_data/http/mixed_plain_and_base64_encoding.http b/tests/test_data/http/mixed_plain_and_base64_encoding.http new file mode 100644 index 0000000..9de1a3b --- /dev/null +++ b/tests/test_data/http/mixed_plain_and_base64_encoding.http @@ -0,0 +1,23 @@ +----boundary +Content-Type: text/plain; charset="UTF-8" +Content-Disposition: form-data; name=field1 +Content-Transfer-Encoding: base64 + +VGVzdCAxMjM= +----boundary +Content-Type: text/plain; charset="UTF-8" +Content-Disposition: form-data; name=field2 + +This is a test. +----boundary +Content-Type: text/plain; charset="UTF-8" +Content-Disposition: form-data; name=field3 +Content-Transfer-Encoding: base64 + +VGVzdCBzdHJpbmcuCg== +----boundary +Content-Type: text/plain; charset="UTF-8" +Content-Disposition: form-data; name=field4 + +This is also a test. +----boundary-- \ No newline at end of file diff --git a/tests/test_data/http/mixed_plain_and_base64_encoding.yaml b/tests/test_data/http/mixed_plain_and_base64_encoding.yaml new file mode 100644 index 0000000..31bfe77 --- /dev/null +++ b/tests/test_data/http/mixed_plain_and_base64_encoding.yaml @@ -0,0 +1,18 @@ +boundary: --boundary +expected: + - name: field1 + type: field + data: !!binary | + VGVzdCAxMjM= + - name: field2 + type: field + data: !!binary | + VGhpcyBpcyBhIHRlc3Qu + - name: field3 + type: field + data: !!binary | + VGVzdCBzdHJpbmcuCg== + - name: field4 + type: field + data: !!binary | + VGhpcyBpcyBhbHNvIGEgdGVzdC4=