mirror of
https://github.com/saymrwulf/cryptography.git
synced 2026-05-14 20:37:55 +00:00
* Raize padding block_size limit to what is allowed by the specs. * Add tests for raising padding limits. * Amend C code for padding check to use uint16_t instead of uint8_t. * Fix test to work in Python 3. * Fix typo. * Fix another typo. * Fix return type of the padding checks. * Change hypothesis test on padding. * Update comment.
32 lines
1 KiB
Python
32 lines
1 KiB
Python
# This file is dual licensed under the terms of the Apache License, Version
|
|
# 2.0, and the BSD License. See the LICENSE file in the root of this repository
|
|
# for complete details.
|
|
|
|
from hypothesis import given
|
|
from hypothesis.strategies import binary, integers
|
|
|
|
from cryptography.hazmat.primitives.padding import ANSIX923, PKCS7
|
|
|
|
|
|
@given(integers(min_value=1, max_value=255), binary())
|
|
def test_pkcs7(block_size, data):
|
|
# Generate in [1, 31] so we can easily get block_size in bits by
|
|
# multiplying by 8.
|
|
p = PKCS7(block_size=block_size * 8)
|
|
padder = p.padder()
|
|
unpadder = p.unpadder()
|
|
|
|
padded = padder.update(data) + padder.finalize()
|
|
|
|
assert unpadder.update(padded) + unpadder.finalize() == data
|
|
|
|
|
|
@given(integers(min_value=1, max_value=255), binary())
|
|
def test_ansix923(block_size, data):
|
|
a = ANSIX923(block_size=block_size * 8)
|
|
padder = a.padder()
|
|
unpadder = a.unpadder()
|
|
|
|
padded = padder.update(data) + padder.finalize()
|
|
|
|
assert unpadder.update(padded) + unpadder.finalize() == data
|