Failed Conditions
Push — master ( 339400...89d9e2 )
by Florent
01:13
created

RFC3394Test::wrap192BitsKeyDataWith256BitKEK()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 10

Duplication

Lines 0
Ratio 0 %

Importance

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