Failed Conditions
Push — master ( 072e31...fa6436 )
by Florent
10s
created

RFC3394Test::testWrap128BitsKeyDataWith128BitKEK()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 10
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 10
rs 9.4285
cc 1
eloc 7
nc 1
nop 0
1
<?php
2
3
/*
4
 * The MIT License (MIT)
5
 *
6
 * Copyright (c) 2014-2016 Spomky-Labs
7
 *
8
 * This software may be modified and distributed under the terms
9
 * of the MIT license.  See the LICENSE file for details.
10
 */
11
12
namespace AESKW\Tests;
13
14
use AESKW\A128KW;
15
use AESKW\A192KW;
16
use AESKW\A256KW;
17
use PHPUnit\Framework\TestCase;
18
19
/**
20
 * These tests come from the RFC3394.
21
 *
22
 * @see https://www.ietf.org/rfc/rfc3394.txt#4
23
 */
24
final class RFC3394Test extends TestCase
25
{
26
    public function testWrap128BitsKeyDataWith128BitKEK()
27
    {
28
        $kek = hex2bin('000102030405060708090A0B0C0D0E0F');
29
        $data = hex2bin('00112233445566778899AABBCCDDEEFF');
30
31
        $wrapped = A128KW::wrap($kek, $data);
32
        $this->assertEquals(hex2bin('1FA68B0A8112B447AEF34BD8FB5A7B829D3E862371D2CFE5'), $wrapped);
33
        $unwrapped = A128KW::unwrap($kek, $wrapped);
34
        $this->assertEquals($data, $unwrapped);
35
    }
36
37
    public function testWrap128BitsKeyDataWith192BitKEK()
38
    {
39
        $kek = hex2bin('000102030405060708090A0B0C0D0E0F1011121314151617');
40
        $data = hex2bin('00112233445566778899AABBCCDDEEFF');
41
42
        $wrapped = A192KW::wrap($kek, $data);
43
        $this->assertEquals(hex2bin('96778B25AE6CA435F92B5B97C050AED2468AB8A17AD84E5D'), $wrapped);
44
        $unwrapped = A192KW::unwrap($kek, $wrapped);
45
        $this->assertEquals($data, $unwrapped);
46
    }
47
48
    public function testWrap128BitsKeyDataWith256BitKEK()
49
    {
50
        $kek = hex2bin('000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F');
51
        $data = hex2bin('00112233445566778899AABBCCDDEEFF');
52
53
        $wrapped = A256KW::wrap($kek, $data);
54
        $this->assertEquals(hex2bin('64E8C3F9CE0F5BA263E9777905818A2A93C8191E7D6E8AE7'), $wrapped);
55
        $unwrapped = A256KW::unwrap($kek, $wrapped);
56
        $this->assertEquals($data, $unwrapped);
57
    }
58
59
    public function testWrap192BitsKeyDataWith192BitKEK()
60
    {
61
        $kek = hex2bin('000102030405060708090A0B0C0D0E0F1011121314151617');
62
        $data = hex2bin('00112233445566778899AABBCCDDEEFF0001020304050607');
63
64
        $wrapped = A192KW::wrap($kek, $data);
65
        $this->assertEquals(hex2bin('031D33264E15D33268F24EC260743EDCE1C6C7DDEE725A936BA814915C6762D2'), $wrapped);
66
        $unwrapped = A192KW::unwrap($kek, $wrapped);
67
        $this->assertEquals($data, $unwrapped);
68
    }
69
70
    public function testWrap192BitsKeyDataWith256BitKEK()
71
    {
72
        $kek = hex2bin('000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F');
73
        $data = hex2bin('00112233445566778899AABBCCDDEEFF0001020304050607');
74
75
        $wrapped = A256KW::wrap($kek, $data);
76
        $this->assertEquals(hex2bin('A8F9BC1612C68B3FF6E6F4FBE30E71E4769C8B80A32CB8958CD5D17D6B254DA1'), $wrapped);
77
        $unwrapped = A256KW::unwrap($kek, $wrapped);
78
        $this->assertEquals($data, $unwrapped);
79
    }
80
81
    public function testWrap256BitsKeyDataWith256BitKEK()
82
    {
83
        $kek = hex2bin('000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F');
84
        $data = hex2bin('00112233445566778899AABBCCDDEEFF000102030405060708090A0B0C0D0E0F');
85
86
        $wrapped = A256KW::wrap($kek, $data);
87
        $this->assertEquals(hex2bin('28C9F404C4B810F4CBCCB35CFB87F8263F5786E2D80ED326CBC7F0E71A99F43BFB988B9B7A02DD21'), $wrapped);
88
        $unwrapped = A256KW::unwrap($kek, $wrapped);
89
        $this->assertEquals($data, $unwrapped);
90
    }
91
}
92