authorization_set_test.cpp revision 58e1a5486219a1be9264d4e863a9dd3e393906c3
15ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden/*
25ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * Copyright (C) 2014 The Android Open Source Project
35ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden *
45ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * Licensed under the Apache License, Version 2.0 (the "License");
55ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * you may not use this file except in compliance with the License.
65ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * You may obtain a copy of the License at
75ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden *
85ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden *      http://www.apache.org/licenses/LICENSE-2.0
95ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden *
105ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * Unless required by applicable law or agreed to in writing, software
115ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * distributed under the License is distributed on an "AS IS" BASIS,
125ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
135ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * See the License for the specific language governing permissions and
145ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden * limitations under the License.
155ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden */
165ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
175ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden#include <gtest/gtest.h>
185ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
195ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden#include "authorization_set.h"
205ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden#include "google_keymaster_utils.h"
215ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
225ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willdenint main(int argc, char** argv) {
235ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ::testing::InitGoogleTest(&argc, argv);
245ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    int result = RUN_ALL_TESTS();
255ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    return result;
265ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
275ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
285ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willdennamespace keymaster {
295ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willdennamespace test {
305ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
315ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Construction, ListProvided) {
325ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
335ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
345ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
355ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
365ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
375ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
385ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
395ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_KEY_SIZE, 256),
405ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
415ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
425ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
435ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(8U, set.size());
445ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
455ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
465ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Lookup, NonRepeated) {
475ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
485ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
495ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
505ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
515ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
525ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
535ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
545ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_KEY_SIZE, 256),
555ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
565ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
575ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
585ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(8U, set.size());
595ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
605ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    int pos = set.find(TAG_ALGORITHM);
615ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ASSERT_NE(-1, pos);
625ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_TAG_ALGORITHM, set[pos].tag);
635ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_ALGORITHM_RSA, set[pos].enumerated);
645ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
655ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    pos = set.find(TAG_MAC_LENGTH);
665ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(-1, pos);
675ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
685ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint32_t int_val = 0;
695ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_USER_ID, &int_val));
705ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(7U, int_val);
715ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
725ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_blob_t blob_val;
735ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_APPLICATION_ID, &blob_val));
745ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(6U, blob_val.data_length);
755ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(0, memcmp(blob_val.data, "my_app", 6));
765ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
775ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
785ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Lookup, Repeated) {
795ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
805ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
815ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
825ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
835ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
845ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
855ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
865ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_KEY_SIZE, 256),
875ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
885ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
895ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
905ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(8U, set.size());
915ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
925ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    int pos = set.find(TAG_PURPOSE);
935ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ASSERT_FALSE(pos == -1);
945ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_TAG_PURPOSE, set[pos].tag);
955ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_PURPOSE_SIGN, set[pos].enumerated);
965ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
975ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    pos = set.find(TAG_PURPOSE, pos);
985ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_TAG_PURPOSE, set[pos].tag);
995ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_PURPOSE_VERIFY, set[pos].enumerated);
1005ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1015ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(-1, set.find(TAG_PURPOSE, pos));
1025ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
1035ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1045ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Lookup, Indexed) {
1055ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
1065ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
1075ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
1085ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
1095ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
1105ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
1115ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
1125ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_KEY_SIZE, 256),
1135ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
1145ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
1155ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
1165ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(8U, set.size());
1175ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1185ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_TAG_PURPOSE, set[0].tag);
1195ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_PURPOSE_SIGN, set[0].enumerated);
1205ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1215ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Lookup beyond end doesn't work, just returns zeros, but doens't blow up either (verify by
1225ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // running under valgrind).
1235ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_TAG_INVALID, set[10].tag);
1245ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
1255ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1265ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Serialization, RoundTrip) {
1275ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
1285ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
1295ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
1305ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
1315ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
1325ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
1335ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
1345ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_KEY_SIZE, 256),
1355ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
1365ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
1375ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
1385ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1395ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    size_t size = set.SerializedSize();
1405ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(size > 0);
1415ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1425ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    UniquePtr<uint8_t[]> buf(new uint8_t[size]);
14358e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(buf.get() + size, set.Serialize(buf.get(), buf.get() + size));
1445ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet deserialized(buf.get(), size);
1455ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
14658e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, deserialized.is_valid());
1475ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1485ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(set.size(), deserialized.size());
1495ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    for (size_t i = 0; i < set.size(); ++i) {
1505ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        EXPECT_EQ(set[i].tag, deserialized[i].tag);
1515ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    }
1525ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1535ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    int pos = deserialized.find(TAG_APPLICATION_ID);
1545ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ASSERT_NE(-1, pos);
1555ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_TAG_APPLICATION_ID, deserialized[pos].tag);
1565ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(6U, deserialized[pos].blob.data_length);
1575ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(0, memcmp(deserialized[pos].blob.data, "my_app", 6));
1585ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
1595ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
16058e1a5486219a1be9264d4e863a9dd3e393906c3Shawn WilldenTEST(Deserialization, Deserialize) {
1615ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
1625ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
1635ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
1645ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
1655ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
1665ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
1675ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
1685ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_KEY_SIZE, 256),
1695ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
1705ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
1715ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
1725ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1735ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    size_t size = set.SerializedSize();
1745ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(size > 0);
1755ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1765ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    UniquePtr<uint8_t[]> buf(new uint8_t[size]);
17758e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(buf.get() + size, set.Serialize(buf.get(), buf.get() + size));
1785ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet deserialized;
1795ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    const uint8_t* p = buf.get();
18058e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_TRUE(deserialized.Deserialize(&p, p + size));
1815ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(p, buf.get() + size);
1825ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
18358e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, deserialized.is_valid());
1845ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1855ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(set.size(), deserialized.size());
1865ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    for (size_t i = 0; i < set.size(); ++i) {
1875ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        EXPECT_EQ(set[i].tag, deserialized[i].tag);
1885ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    }
1895ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1905ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    int pos = deserialized.find(TAG_APPLICATION_ID);
1915ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ASSERT_NE(-1, pos);
1925ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_TAG_APPLICATION_ID, deserialized[pos].tag);
1935ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(6U, deserialized[pos].blob.data_length);
1945ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(0, memcmp(deserialized[pos].blob.data, "my_app", 6));
1955ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
1965ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
1975ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Deserialization, TooShortBuffer) {
1985ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint8_t buf[] = {0, 0, 0};
1995ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet deserialized(buf, array_length(buf));
2005ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(AuthorizationSet::MALFORMED_DATA, deserialized.is_valid());
2015ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2025ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    const uint8_t* p = buf;
20358e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_FALSE(deserialized.Deserialize(&p, p + array_length(buf)));
2045ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(AuthorizationSet::MALFORMED_DATA, deserialized.is_valid());
2055ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
2065ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2075ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Deserialization, InvalidLengthField) {
2085ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
2095ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
2105ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
2115ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
2125ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
2135ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
2145ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
2155ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_KEY_SIZE, 256),
2165ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
2175ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
2185ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
2195ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2205ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    size_t size = set.SerializedSize();
2215ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(size > 0);
2225ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2235ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    UniquePtr<uint8_t[]> buf(new uint8_t[size]);
22458e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(buf.get() + size, set.Serialize(buf.get(), buf.get() + size));
2255ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    *reinterpret_cast<uint32_t*>(buf.get()) = 9;
2265ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2275ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet deserialized(buf.get(), size);
2285ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(AuthorizationSet::MALFORMED_DATA, deserialized.is_valid());
2295ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2305ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    const uint8_t* p = buf.get();
23158e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_FALSE(deserialized.Deserialize(&p, p + size));
2325ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(AuthorizationSet::MALFORMED_DATA, deserialized.is_valid());
2335ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
2345ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2355ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Deserialization, MalformedIndirectData) {
2365ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
2375ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
2385ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_DATA, "foo", 3),
2395ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
2405ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
2415ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    size_t size = set.SerializedSize();
2425ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2435ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    UniquePtr<uint8_t[]> buf(new uint8_t[size]);
24458e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(buf.get() + size, set.Serialize(buf.get(), buf.get() + size));
2455ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2465ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t* ptr =
2475ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        reinterpret_cast<keymaster_key_param_t*>(buf.get() + sizeof(uint32_t));
2485ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2495ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Check that the offsets we expect are present.
2505ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(0, ptr[0].blob.data);
2515ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(6U, ptr[0].blob.data_length);
2525ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(6, reinterpret_cast<ptrdiff_t>(ptr[1].blob.data));
2535ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(3U, ptr[1].blob.data_length);
2545ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(9U, size - sizeof(uint32_t) * 2 - sizeof(*ptr) * 2);
2555ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2565ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Check that deserialization works.
2575ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet deserialized1(buf.get(), size);
25858e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, deserialized1.is_valid());
2595ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2605ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    const uint8_t* p = buf.get();
26158e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_TRUE(deserialized1.Deserialize(&p, p + size));
26258e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, deserialized1.is_valid());
2635ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2645ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    //
2655ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Now mess them up in various ways:
2665ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    //
2675ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2685ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Make one point past the end.
2695ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    (*reinterpret_cast<long*>(&(ptr[1].blob.data)))++;
2705ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet deserialized2;
2715ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    p = buf.get();
27258e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    deserialized2.Deserialize(&p, p + size);
2735ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(AuthorizationSet::BOUNDS_CHECKING_FAILURE, deserialized2.is_valid());
2745ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2755ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    p = buf.get();
27658e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_FALSE(deserialized2.Deserialize(&p, p + size));
2775ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(AuthorizationSet::BOUNDS_CHECKING_FAILURE, deserialized2.is_valid());
2785ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2795ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    (*reinterpret_cast<long*>(&(ptr[1].blob.data)))--;
2805ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2815ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Make a gap between the blobs.
2825ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ptr[0].blob.data_length--;
2835ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet deserialized3(buf.get(), size);
2845ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(AuthorizationSet::MALFORMED_DATA, deserialized3.is_valid());
2855ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2865ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    p = buf.get();
28758e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    deserialized3.Deserialize(&p, p + size);
2885ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(AuthorizationSet::MALFORMED_DATA, deserialized3.is_valid());
2895ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2905ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ptr[0].blob.data_length++;
2915ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
2925ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Make them overlap.  We don't currently detect this.  We should.
2935ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ptr[0].blob.data_length++;
2945ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    (*reinterpret_cast<long*>(&(ptr[1].blob.data)))--;
2955ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    ptr[1].blob.data_length--;
2965ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet deserialized4(buf.get(), size);
29758e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, deserialized4.is_valid());
2985ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
2995ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3005ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Growable, SuccessfulRoundTrip) {
3015ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t elems_buf[20];
3025ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint8_t data_buf[200];
3035ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3045ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet growable;
3055ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA)));
3065ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(1U, growable.size());
3075ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3085ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY)));
3095ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(2U, growable.size());
3105ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3115ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN)));
3125ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(3U, growable.size());
3135ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3145ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_APPLICATION_ID, "data", 4)));
3155ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(4U, growable.size());
3165ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3175ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    size_t serialize_size = growable.SerializedSize();
3185ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    UniquePtr<uint8_t[]> serialized(new uint8_t[serialize_size]);
31958e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(serialized.get() + serialize_size,
32058e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden              growable.Serialize(serialized.get(), serialized.get() + serialize_size));
3215ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
3225ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3235ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Growable, InsufficientElemBuf) {
3245ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t elems_buf[1];
3255ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint8_t data_buf[200];
3265ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3275ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet growable;
32858e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, growable.is_valid());
3295ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3305ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // First insertion fits.
3315ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA)));
3325ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(1U, growable.size());
33358e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, growable.is_valid());
3345ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3355ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Second does too.
3365ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_RSA_PUBLIC_EXPONENT, 3)));
3375ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(2U, growable.size());
3385ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
3395ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3405ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(Growable, InsufficientIndirectBuf) {
3415ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t elems_buf[3];
3425ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint8_t data_buf[10];
3435ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3445ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet growable;
34558e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, growable.is_valid());
3465ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3475ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA)));
3485ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(1U, growable.size());
34958e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, growable.is_valid());
3505ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3515ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_APPLICATION_ID, "1234567890", 10)));
3525ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(2U, growable.size());
35358e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, growable.is_valid());
3545ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3555ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_APPLICATION_DATA, "1", 1)));
3565ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(3U, growable.size());
35758e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, growable.is_valid());
3585ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3595ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Can still add another entry without indirect data.  Now it's full.
3605ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(growable.push_back(Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN)));
3615ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(4U, growable.size());
36258e1a5486219a1be9264d4e863a9dd3e393906c3Shawn Willden    EXPECT_EQ(AuthorizationSet::OK, growable.is_valid());
3635ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
3645ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3655ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(GetValue, GetInt) {
3665ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
3675ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
3685ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
3695ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
3705ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
3715ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
3725ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
3735ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
3745ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
3755ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
3765ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3775ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint32_t val;
3785ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_USER_ID, &val));
3795ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(7U, val);
3805ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3815ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Find one that isn't there
3825ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_FALSE(set.GetTagValue(TAG_KEY_SIZE, &val));
3835ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
3845ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3855ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(GetValue, GetIntRep) {
3865ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
3875ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
3885ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
3895ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
3905ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
3915ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
3925ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
3935ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
3945ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
3955ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
3965ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
3975ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint32_t val;
3985ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_USER_AUTH_ID, 0, &val));
3995ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(8U, val);
4005ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4015ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Find one that isn't there
4025ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_FALSE(set.GetTagValue(TAG_USER_AUTH_ID, 1, &val));
4035ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
4045ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4055ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(GetValue, GetLong) {
4065ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params1[] = {
4075ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN), Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
4085ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
4095ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        keymaster_param_long(TAG_RSA_PUBLIC_EXPONENT, 3),
4105ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
4115ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set1(params1, array_length(params1));
4125ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4135ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params2[] = {
4145ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN), Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
4155ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
4165ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
4175ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set2(params2, array_length(params2));
4185ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4195ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint64_t val;
4205ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set1.GetTagValue(TAG_RSA_PUBLIC_EXPONENT, &val));
4215ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(3U, val);
4225ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4235ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Find one that isn't there
4245ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_FALSE(set2.GetTagValue(TAG_RSA_PUBLIC_EXPONENT, &val));
4255ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
4265ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4275ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(GetValue, GetEnum) {
4285ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
4295ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
4305ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
4315ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
4325ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
4335ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
4345ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
4355ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
4365ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
4375ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
4385ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4395ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_algorithm_t val;
4405ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_ALGORITHM, &val));
4415ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_ALGORITHM_RSA, val);
4425ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4435ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Find one that isn't there
4445ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_padding_t val2;
4455ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_FALSE(set.GetTagValue(TAG_PADDING, &val2));
4465ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
4475ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4485ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(GetValue, GetEnumRep) {
4495ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
4505ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
4515ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
4525ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
4535ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
4545ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
4555ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
4565ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
4575ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
4585ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
4595ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4605ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_purpose_t val;
4615ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_PURPOSE, 0, &val));
4625ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_PURPOSE_SIGN, val);
4635ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_PURPOSE, 1, &val));
4645ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(KM_PURPOSE_VERIFY, val);
4655ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4665ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Find one that isn't there
4675ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_FALSE(set.GetTagValue(TAG_PURPOSE, 2, &val));
4685ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
4695ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4705ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(GetValue, GetDate) {
4715ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
4725ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ACTIVE_DATETIME, 10),
4735ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
4745ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
4755ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
4765ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
4775ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
4785ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
4795ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
4805ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
4815ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4825ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    uint64_t val;
4835ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_ACTIVE_DATETIME, &val));
4845ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(10U, val);
4855ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4865ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Find one that isn't there
4875ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_FALSE(set.GetTagValue(TAG_USAGE_EXPIRE_DATETIME, &val));
4885ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
4895ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
4905ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn WilldenTEST(GetValue, GetBlob) {
4915ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_key_param_t params[] = {
4925ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ACTIVE_DATETIME, 10),
4935ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
4945ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
4955ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_ID, 7),
4965ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_USER_AUTH_ID, 8),
4975ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_APPLICATION_ID, "my_app", 6),
4985ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden        Authorization(TAG_AUTH_TIMEOUT, 300),
4995ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    };
5005ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    AuthorizationSet set(params, array_length(params));
5015ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
5025ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    keymaster_blob_t val;
5035ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_TRUE(set.GetTagValue(TAG_APPLICATION_ID, &val));
5045ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(6U, val.data_length);
5055ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_EQ(0, memcmp(val.data, "my_app", 6));
5065ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
5075ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    // Find one that isn't there
5085ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden    EXPECT_FALSE(set.GetTagValue(TAG_APPLICATION_DATA, &val));
5095ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}
5105ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden
5115ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}  // namespace test
5125ada7b6c525d2bfd5b556a698ccb11db23e052bbShawn Willden}  // namespace keymaster
513