| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "net/cert/jwk_serializer.h" | 5 #include "net/cert/jwk_serializer.h" |
| 6 | 6 |
| 7 #include "base/base64.h" | 7 #include "base/base64.h" |
| 8 #include "base/values.h" | 8 #include "base/values.h" |
| 9 #include "testing/gtest/include/gtest/gtest.h" | 9 #include "testing/gtest/include/gtest/gtest.h" |
| 10 | 10 |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 68 base::DictionaryValue public_key_jwk; | 68 base::DictionaryValue public_key_jwk; |
| 69 | 69 |
| 70 EXPECT_FALSE(JwkSerializer::ConvertSpkiFromDerToJwk(spki, &public_key_jwk)); | 70 EXPECT_FALSE(JwkSerializer::ConvertSpkiFromDerToJwk(spki, &public_key_jwk)); |
| 71 EXPECT_TRUE(public_key_jwk.empty()); | 71 EXPECT_TRUE(public_key_jwk.empty()); |
| 72 | 72 |
| 73 // Test the result of a "normal" point on this curve. | 73 // Test the result of a "normal" point on this curve. |
| 74 spki.set(reinterpret_cast<const char*>(kSpkiEc), sizeof(kSpkiEc)); | 74 spki.set(reinterpret_cast<const char*>(kSpkiEc), sizeof(kSpkiEc)); |
| 75 EXPECT_TRUE(JwkSerializer::ConvertSpkiFromDerToJwk(spki, &public_key_jwk)); | 75 EXPECT_TRUE(JwkSerializer::ConvertSpkiFromDerToJwk(spki, &public_key_jwk)); |
| 76 | 76 |
| 77 std::string string_value; | 77 std::string string_value; |
| 78 EXPECT_TRUE(public_key_jwk.GetString("alg", &string_value)); | 78 EXPECT_TRUE(public_key_jwk.GetString("kty", &string_value)); |
| 79 EXPECT_STREQ("EC", string_value.c_str()); | 79 EXPECT_STREQ("EC", string_value.c_str()); |
| 80 EXPECT_TRUE(public_key_jwk.GetString("crv", &string_value)); | 80 EXPECT_TRUE(public_key_jwk.GetString("crv", &string_value)); |
| 81 EXPECT_STREQ("P-256", string_value.c_str()); | 81 EXPECT_STREQ("P-256", string_value.c_str()); |
| 82 | 82 |
| 83 EXPECT_TRUE(public_key_jwk.GetString("x", &string_value)); | 83 EXPECT_TRUE(public_key_jwk.GetString("x", &string_value)); |
| 84 std::string decoded_coordinate; | 84 std::string decoded_coordinate; |
| 85 EXPECT_TRUE(base::Base64Decode(string_value, &decoded_coordinate)); | 85 EXPECT_TRUE(base::Base64Decode(string_value, &decoded_coordinate)); |
| 86 EXPECT_EQ(kEcCoordinateSize, decoded_coordinate.size()); | 86 EXPECT_EQ(kEcCoordinateSize, decoded_coordinate.size()); |
| 87 EXPECT_EQ(0, | 87 EXPECT_EQ(0, |
| 88 memcmp(decoded_coordinate.data(), | 88 memcmp(decoded_coordinate.data(), |
| 89 kSpkiEc + sizeof(kP256SpkiPrefix), | 89 kSpkiEc + sizeof(kP256SpkiPrefix), |
| 90 kEcCoordinateSize)); | 90 kEcCoordinateSize)); |
| 91 | 91 |
| 92 EXPECT_TRUE(public_key_jwk.GetString("y", &string_value)); | 92 EXPECT_TRUE(public_key_jwk.GetString("y", &string_value)); |
| 93 EXPECT_TRUE(base::Base64Decode(string_value, &decoded_coordinate)); | 93 EXPECT_TRUE(base::Base64Decode(string_value, &decoded_coordinate)); |
| 94 EXPECT_EQ(kEcCoordinateSize, decoded_coordinate.size()); | 94 EXPECT_EQ(kEcCoordinateSize, decoded_coordinate.size()); |
| 95 EXPECT_EQ(0, | 95 EXPECT_EQ(0, |
| 96 memcmp(decoded_coordinate.data(), | 96 memcmp(decoded_coordinate.data(), |
| 97 kSpkiEc + sizeof(kP256SpkiPrefix) + kEcCoordinateSize, | 97 kSpkiEc + sizeof(kP256SpkiPrefix) + kEcCoordinateSize, |
| 98 kEcCoordinateSize)); | 98 kEcCoordinateSize)); |
| 99 | 99 |
| 100 // Test the result of a corner case: leading 0s in the x, y coordinates are | 100 // Test the result of a corner case: leading 0s in the x, y coordinates are |
| 101 // not trimmed, but the point is fixed-length encoded. | 101 // not trimmed, but the point is fixed-length encoded. |
| 102 spki.set(reinterpret_cast<const char*>(kSpkiEcWithZeroXY), | 102 spki.set(reinterpret_cast<const char*>(kSpkiEcWithZeroXY), |
| 103 sizeof(kSpkiEcWithZeroXY)); | 103 sizeof(kSpkiEcWithZeroXY)); |
| 104 EXPECT_TRUE(JwkSerializer::ConvertSpkiFromDerToJwk(spki, &public_key_jwk)); | 104 EXPECT_TRUE(JwkSerializer::ConvertSpkiFromDerToJwk(spki, &public_key_jwk)); |
| 105 | 105 |
| 106 EXPECT_TRUE(public_key_jwk.GetString("alg", &string_value)); | 106 EXPECT_TRUE(public_key_jwk.GetString("kty", &string_value)); |
| 107 EXPECT_STREQ("EC", string_value.c_str()); | 107 EXPECT_STREQ("EC", string_value.c_str()); |
| 108 EXPECT_TRUE(public_key_jwk.GetString("crv", &string_value)); | 108 EXPECT_TRUE(public_key_jwk.GetString("crv", &string_value)); |
| 109 EXPECT_STREQ("P-256", string_value.c_str()); | 109 EXPECT_STREQ("P-256", string_value.c_str()); |
| 110 | 110 |
| 111 EXPECT_TRUE(public_key_jwk.GetString("x", &string_value)); | 111 EXPECT_TRUE(public_key_jwk.GetString("x", &string_value)); |
| 112 EXPECT_TRUE(base::Base64Decode(string_value, &decoded_coordinate)); | 112 EXPECT_TRUE(base::Base64Decode(string_value, &decoded_coordinate)); |
| 113 EXPECT_EQ(kEcCoordinateSize, decoded_coordinate.size()); | 113 EXPECT_EQ(kEcCoordinateSize, decoded_coordinate.size()); |
| 114 EXPECT_EQ(0, | 114 EXPECT_EQ(0, |
| 115 memcmp(decoded_coordinate.data(), | 115 memcmp(decoded_coordinate.data(), |
| 116 kSpkiEcWithZeroXY + sizeof(kP256SpkiPrefix), | 116 kSpkiEcWithZeroXY + sizeof(kP256SpkiPrefix), |
| (...skipping 23 matching lines...) Expand all Loading... |
| 140 // but even a valid SPKI is non-convertible via the stub OpenSSL | 140 // but even a valid SPKI is non-convertible via the stub OpenSSL |
| 141 // implementation. | 141 // implementation. |
| 142 spki.set(reinterpret_cast<const char*>(kSpkiEc), sizeof(kSpkiEc)); | 142 spki.set(reinterpret_cast<const char*>(kSpkiEc), sizeof(kSpkiEc)); |
| 143 EXPECT_FALSE(JwkSerializer::ConvertSpkiFromDerToJwk(spki, &public_key_jwk)); | 143 EXPECT_FALSE(JwkSerializer::ConvertSpkiFromDerToJwk(spki, &public_key_jwk)); |
| 144 EXPECT_TRUE(public_key_jwk.empty()); | 144 EXPECT_TRUE(public_key_jwk.empty()); |
| 145 } | 145 } |
| 146 | 146 |
| 147 #endif // !defined(USE_OPENSSL) | 147 #endif // !defined(USE_OPENSSL) |
| 148 | 148 |
| 149 } // namespace net | 149 } // namespace net |
| OLD | NEW |