blob: fa213c957be3b9835eb2d97ecfd6cdad5eb6aa40 [file] [log] [blame]
Shawn Willden128ffe02014-08-06 12:31:33 -06001/*
2 * Copyright (C) 2014 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include <UniquePtr.h>
18
19#include <gtest/gtest.h>
20
Shawn Willden128ffe02014-08-06 12:31:33 -060021#include "keymaster_tags.h"
22#include "google_keymaster_utils.h"
23#include "google_softkeymaster.h"
24
25int main(int argc, char** argv) {
26 ::testing::InitGoogleTest(&argc, argv);
27 int result = RUN_ALL_TESTS();
28 return result;
29}
30
31namespace keymaster {
32namespace test {
33
34TEST(GenerateKeyRequest, RoundTrip) {
35 keymaster_key_param_t params[] = {
36 Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
37 Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
38 Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
39 Authorization(TAG_USER_ID, 7),
40 Authorization(TAG_USER_AUTH_ID, 8),
41 Authorization(TAG_APPLICATION_ID, "app_id", 6),
42 Authorization(TAG_AUTH_TIMEOUT, 300),
43 };
44 GenerateKeyRequest req;
45 req.key_description.Reinitialize(params, array_length(params));
46
47 size_t size = req.SerializedSize();
Shawn Willden8d336ae2014-08-09 15:47:05 -060048 EXPECT_EQ(78U, size);
Shawn Willden128ffe02014-08-06 12:31:33 -060049
50 UniquePtr<uint8_t[]> buf(new uint8_t[size]);
Shawn Willden58e1a542014-08-08 21:58:29 -060051 EXPECT_EQ(buf.get() + size, req.Serialize(buf.get(), buf.get() + size));
Shawn Willden128ffe02014-08-06 12:31:33 -060052
53 GenerateKeyRequest deserialized1;
Shawn Willden58e1a542014-08-08 21:58:29 -060054 const uint8_t* p = buf.get();
55 EXPECT_TRUE(deserialized1.Deserialize(&p, p + size));
Shawn Willden128ffe02014-08-06 12:31:33 -060056 EXPECT_EQ(7U, deserialized1.key_description.size());
57
58 // Check a few entries.
59 keymaster_purpose_t purpose;
60 EXPECT_TRUE(deserialized1.key_description.GetTagValue(TAG_PURPOSE, 0, &purpose));
61 EXPECT_EQ(KM_PURPOSE_SIGN, purpose);
62 keymaster_blob_t blob;
63 EXPECT_TRUE(deserialized1.key_description.GetTagValue(TAG_APPLICATION_ID, &blob));
64 EXPECT_EQ(6U, blob.data_length);
65 EXPECT_EQ(0, memcmp(blob.data, "app_id", 6));
66 uint32_t val;
67 EXPECT_TRUE(deserialized1.key_description.GetTagValue(TAG_USER_ID, &val));
68 EXPECT_EQ(7U, val);
69
70 GenerateKeyRequest deserialized2;
71 const uint8_t* p2 = buf.get();
Shawn Willden58e1a542014-08-08 21:58:29 -060072 EXPECT_TRUE(deserialized2.Deserialize(&p2, p2 + size));
Shawn Willden128ffe02014-08-06 12:31:33 -060073 EXPECT_EQ(7U, deserialized2.key_description.size());
74
75 // Check a few entries.
76 EXPECT_TRUE(deserialized2.key_description.GetTagValue(TAG_PURPOSE, 0, &purpose));
77 EXPECT_EQ(KM_PURPOSE_SIGN, purpose);
78 EXPECT_TRUE(deserialized2.key_description.GetTagValue(TAG_APPLICATION_ID, &blob));
79 EXPECT_EQ(6U, blob.data_length);
80 EXPECT_EQ(0, memcmp(blob.data, "app_id", 6));
81 EXPECT_TRUE(deserialized2.key_description.GetTagValue(TAG_USER_ID, &val));
82 EXPECT_EQ(7U, val);
83}
84
85uint8_t TEST_DATA[] = "a key blob";
86
87TEST(GenerateKeyResponse, RoundTrip) {
88 keymaster_key_param_t params[] = {
89 Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
90 Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
91 Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
92 Authorization(TAG_USER_ID, 7),
93 Authorization(TAG_USER_AUTH_ID, 8),
94 Authorization(TAG_APPLICATION_ID, "app_id", 6),
95 Authorization(TAG_AUTH_TIMEOUT, 300),
96 };
97 GenerateKeyResponse rsp;
98 rsp.error = KM_ERROR_OK;
99 rsp.key_blob.key_material = dup_array(TEST_DATA);
100 rsp.key_blob.key_material_size = array_length(TEST_DATA);
101 rsp.enforced.Reinitialize(params, array_length(params));
102
103 size_t size = rsp.SerializedSize();
Shawn Willden8d336ae2014-08-09 15:47:05 -0600104 EXPECT_EQ(117U, size);
Shawn Willden128ffe02014-08-06 12:31:33 -0600105
106 UniquePtr<uint8_t[]> buf(new uint8_t[size]);
Shawn Willden58e1a542014-08-08 21:58:29 -0600107 EXPECT_EQ(buf.get() + size, rsp.Serialize(buf.get(), buf.get() + size));
Shawn Willden128ffe02014-08-06 12:31:33 -0600108
109 GenerateKeyResponse deserialized;
Shawn Willden58e1a542014-08-08 21:58:29 -0600110 const uint8_t* p = buf.get();
111 EXPECT_TRUE(deserialized.Deserialize(&p, p + size));
Shawn Willden128ffe02014-08-06 12:31:33 -0600112 EXPECT_EQ(7U, deserialized.enforced.size());
113
114 EXPECT_EQ(0U, deserialized.unenforced.size());
115 EXPECT_EQ(KM_ERROR_OK, deserialized.error);
116
117 // Check a few entries of enforced.
118 keymaster_purpose_t purpose;
119 EXPECT_TRUE(deserialized.enforced.GetTagValue(TAG_PURPOSE, 0, &purpose));
120 EXPECT_EQ(KM_PURPOSE_SIGN, purpose);
121 keymaster_blob_t blob;
122 EXPECT_TRUE(deserialized.enforced.GetTagValue(TAG_APPLICATION_ID, &blob));
123 EXPECT_EQ(6U, blob.data_length);
124 EXPECT_EQ(0, memcmp(blob.data, "app_id", 6));
125 uint32_t val;
126 EXPECT_TRUE(deserialized.enforced.GetTagValue(TAG_USER_ID, &val));
127 EXPECT_EQ(7U, val);
128}
129
130TEST(GenerateKeyResponse, Error) {
131 keymaster_key_param_t params[] = {
132 Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
133 Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
134 Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
135 Authorization(TAG_USER_ID, 7),
136 Authorization(TAG_USER_AUTH_ID, 8),
137 Authorization(TAG_APPLICATION_ID, "app_id", 6),
138 Authorization(TAG_AUTH_TIMEOUT, 300),
139 };
140 GenerateKeyResponse rsp;
141 rsp.error = KM_ERROR_UNSUPPORTED_ALGORITHM;
142 rsp.key_blob.key_material = dup_array(TEST_DATA);
143 rsp.key_blob.key_material_size = array_length(TEST_DATA);
144 rsp.enforced.Reinitialize(params, array_length(params));
145
146 size_t size = rsp.SerializedSize();
147 EXPECT_EQ(4U, size);
148
149 UniquePtr<uint8_t[]> buf(new uint8_t[size]);
Shawn Willden58e1a542014-08-08 21:58:29 -0600150 EXPECT_EQ(buf.get() + size, rsp.Serialize(buf.get(), buf.get() + size));
Shawn Willden128ffe02014-08-06 12:31:33 -0600151
152 GenerateKeyResponse deserialized;
153 const uint8_t* p = buf.get();
Shawn Willden58e1a542014-08-08 21:58:29 -0600154 EXPECT_TRUE(deserialized.Deserialize(&p, p + size));
Shawn Willden128ffe02014-08-06 12:31:33 -0600155 EXPECT_EQ(KM_ERROR_UNSUPPORTED_ALGORITHM, deserialized.error);
156 EXPECT_EQ(0U, deserialized.enforced.size());
157 EXPECT_EQ(0U, deserialized.unenforced.size());
158 EXPECT_EQ(0U, deserialized.key_blob.key_material_size);
159}
160
161} // namespace test
162} // namespace keymaster