Sybren A. Stüvel | 3200f89 | 2011-07-31 20:47:49 +0200 | [diff] [blame] | 1 | '''Tests block operations.''' |
| 2 | |
Yesudeep Mangalapilly | 5802431 | 2011-08-11 01:48:25 +0530 | [diff] [blame] | 3 | try: |
| 4 | from StringIO import StringIO |
| 5 | except ImportError: |
| 6 | from io import StringIO |
Yesudeep Mangalapilly | aed6e86 | 2011-08-11 01:59:50 +0530 | [diff] [blame^] | 7 | import unittest2 |
Sybren A. Stüvel | 3200f89 | 2011-07-31 20:47:49 +0200 | [diff] [blame] | 8 | |
| 9 | import rsa |
Sybren A. Stüvel | 61becf6 | 2011-07-31 20:56:13 +0200 | [diff] [blame] | 10 | from rsa import bigfile, varblock, pkcs1 |
Sybren A. Stüvel | 3200f89 | 2011-07-31 20:47:49 +0200 | [diff] [blame] | 11 | |
Yesudeep Mangalapilly | aed6e86 | 2011-08-11 01:59:50 +0530 | [diff] [blame^] | 12 | class BigfileTest(unittest2.TestCase): |
Sybren A. Stüvel | 3200f89 | 2011-07-31 20:47:49 +0200 | [diff] [blame] | 13 | |
| 14 | def test_encrypt_decrypt_bigfile(self): |
| 15 | |
| 16 | # Expected block size + 11 bytes padding |
| 17 | pub_key, priv_key = rsa.newkeys((6 + 11) * 8) |
| 18 | |
| 19 | # Encrypt the file |
| 20 | message = '123456Sybren' |
| 21 | infile = StringIO(message) |
| 22 | outfile = StringIO() |
| 23 | |
| 24 | bigfile.encrypt_bigfile(infile, outfile, pub_key) |
| 25 | |
| 26 | # Test |
| 27 | crypto = outfile.getvalue() |
| 28 | |
| 29 | cryptfile = StringIO(crypto) |
| 30 | clearfile = StringIO() |
| 31 | |
| 32 | bigfile.decrypt_bigfile(cryptfile, clearfile, priv_key) |
| 33 | self.assertEquals(clearfile.getvalue(), message) |
| 34 | |
| 35 | # We have 2x6 bytes in the message, so that should result in two |
| 36 | # bigfile. |
| 37 | cryptfile.seek(0) |
| 38 | varblocks = list(varblock.yield_varblocks(cryptfile)) |
| 39 | self.assertEqual(2, len(varblocks)) |
| 40 | |
Sybren A. Stüvel | 61becf6 | 2011-07-31 20:56:13 +0200 | [diff] [blame] | 41 | |
| 42 | def test_sign_verify_bigfile(self): |
| 43 | |
| 44 | # Large enough to store MD5-sum and ASN.1 code for MD5 |
| 45 | pub_key, priv_key = rsa.newkeys((34 + 11) * 8) |
| 46 | |
| 47 | # Sign the file |
| 48 | msgfile = StringIO('123456Sybren') |
| 49 | signature = pkcs1.sign(msgfile, priv_key, 'MD5') |
| 50 | |
| 51 | # Check the signature |
| 52 | msgfile.seek(0) |
| 53 | pkcs1.verify(msgfile, signature, pub_key) |
| 54 | |
| 55 | # Alter the message, re-check |
| 56 | msgfile = StringIO('123456sybren') |
| 57 | self.assertRaises(pkcs1.VerificationError, |
| 58 | pkcs1.verify, msgfile, signature, pub_key) |
| 59 | |