| Alex Gaynor | b301627 | 2016-01-13 09:01:42 -0500 | [diff] [blame] | 1 | # This file is dual licensed under the terms of the Apache License, Version |
| 2 | # 2.0, and the BSD License. See the LICENSE file in the root of this repository |
| 3 | # for complete details. |
| 4 | |
| Paul Kehrer | fec083e | 2018-11-12 08:02:52 -0500 | [diff] [blame] | 5 | from hypothesis import HealthCheck, given, settings |
| Alex Gaynor | 3066bf4 | 2016-01-13 22:22:18 -0500 | [diff] [blame] | 6 | from hypothesis.strategies import binary, integers |
| Alex Gaynor | b301627 | 2016-01-13 09:01:42 -0500 | [diff] [blame] | 7 | |
| Cédric Krier | bf0f464 | 2016-02-26 18:40:20 +0100 | [diff] [blame] | 8 | from cryptography.hazmat.primitives.padding import ANSIX923, PKCS7 |
| Alex Gaynor | b301627 | 2016-01-13 09:01:42 -0500 | [diff] [blame] | 9 | |
| 10 | |
| Paul Kehrer | c33ef91 | 2019-01-15 23:56:42 -0600 | [diff] [blame] | 11 | @settings(suppress_health_check=[HealthCheck.too_slow], deadline=None) |
| Terry Chia | e9b87d5 | 2016-11-15 09:56:02 +0800 | [diff] [blame] | 12 | @given(integers(min_value=1, max_value=255), binary()) |
| Alex Gaynor | 3066bf4 | 2016-01-13 22:22:18 -0500 | [diff] [blame] | 13 | def test_pkcs7(block_size, data): |
| 14 | # Generate in [1, 31] so we can easily get block_size in bits by |
| 15 | # multiplying by 8. |
| 16 | p = PKCS7(block_size=block_size * 8) |
| Alex Gaynor | b301627 | 2016-01-13 09:01:42 -0500 | [diff] [blame] | 17 | padder = p.padder() |
| 18 | unpadder = p.unpadder() |
| 19 | |
| 20 | padded = padder.update(data) + padder.finalize() |
| 21 | |
| 22 | assert unpadder.update(padded) + unpadder.finalize() == data |
| Cédric Krier | bf0f464 | 2016-02-26 18:40:20 +0100 | [diff] [blame] | 23 | |
| 24 | |
| Paul Kehrer | fec083e | 2018-11-12 08:02:52 -0500 | [diff] [blame] | 25 | @settings(suppress_health_check=[HealthCheck.too_slow]) |
| Terry Chia | e9b87d5 | 2016-11-15 09:56:02 +0800 | [diff] [blame] | 26 | @given(integers(min_value=1, max_value=255), binary()) |
| Cédric Krier | bf0f464 | 2016-02-26 18:40:20 +0100 | [diff] [blame] | 27 | def test_ansix923(block_size, data): |
| 28 | a = ANSIX923(block_size=block_size * 8) |
| 29 | padder = a.padder() |
| 30 | unpadder = a.unpadder() |
| 31 | |
| 32 | padded = padder.update(data) + padder.finalize() |
| 33 | |
| 34 | assert unpadder.update(padded) + unpadder.finalize() == data |