Chromium Code Reviews| Index: extensions/browser/api/cast_channel/cast_auth_util_unittest.cc |
| diff --git a/extensions/browser/api/cast_channel/cast_auth_util_unittest.cc b/extensions/browser/api/cast_channel/cast_auth_util_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7a838e05808ff3e7881f71605d8d2983bdb787cf |
| --- /dev/null |
| +++ b/extensions/browser/api/cast_channel/cast_auth_util_unittest.cc |
| @@ -0,0 +1,94 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include <string> |
| +#include "base/base64.h" |
|
Ryan Sleevi
2014/10/17 19:53:21
STYLE: newline between lines 5 and 6
vadimgo
2014/10/20 23:35:28
Done.
|
| +#include "extensions/browser/api/cast_channel/cast_auth_util.h" |
|
Ryan Sleevi
2014/10/17 19:53:21
STYLE: Per http://google-styleguide.googlecode.com
vadimgo
2014/10/20 23:35:28
Done.
|
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace extensions { |
| +namespace core_api { |
| +namespace cast_channel { |
| +class CastChannelAuthorityKeysTest : public testing::Test { |
|
Ryan Sleevi
2014/10/17 19:53:21
STYLE: Newline between lines 10, 11, 12, 13
vadimgo
2014/10/20 23:35:28
Done.
|
| + public: |
| + CastChannelAuthorityKeysTest() {} |
| + virtual ~CastChannelAuthorityKeysTest() {} |
| + |
| + protected: |
| + void ExpectKeysLoaded(); |
| + AuthorityKeysStore authority_keys_store_; |
| +}; |
| + |
| +static const net::SHA256HashValue kFingerprintValid1 = { { |
| + 0x52, 0x9D, 0x9C, 0xD6, 0x7F, 0xE5, 0xEB, 0x69, 0x8E, 0x70, 0xDD, 0x26, |
| + 0xD7, 0xD8, 0xF1, 0x26, 0x59, 0xF1, 0xE6, 0xE5, 0x23, 0x48, 0xBF, 0x6A, |
| + 0x5C, 0xF7, 0x16, 0xE1, 0x3F, 0x41, 0x0E, 0x73 |
| +} }; |
| + |
| +static const net::SHA256HashValue kFingerprintValid2 = { { |
| + 0xA2, 0x48, 0xC2, 0xE8, 0x54, 0xE6, 0x56, 0xA5, 0x6D, 0xE8, 0x23, 0x1F, |
| + 0x1E, 0xE1, 0x75, 0x6F, 0xDB, 0xE4, 0x07, 0xF9, 0xFE, 0xD4, 0x65, 0x0D, |
| + 0x60, 0xCC, 0x5A, 0xCB, 0x65, 0x11, 0xC7, 0x20 |
| +} }; |
| + |
| +static const net::SHA256HashValue kFingerprintInvalid = { { |
| + 0x00, 0x9D, 0x9C, 0xD6, 0x7F, 0xE5, 0xEB, 0x69, 0x8E, 0x70, 0xDD, 0x26, |
| + 0xD7, 0xD8, 0xF1, 0x26, 0x59, 0xF1, 0xE6, 0xE5, 0x23, 0x48, 0xBF, 0x6A, |
| + 0x5C, 0xF7, 0x16, 0xE1, 0x3F, 0x41, 0x0E, 0x73 |
| +} }; |
| + |
| +void CastChannelAuthorityKeysTest::ExpectKeysLoaded() { |
| + const SECItem* key = authority_keys_store_.GetDefaultICAPublicKey(); |
| + EXPECT_NE(static_cast<SECItem*>(NULL), key); |
| + |
| + key = |
| + authority_keys_store_.GetICAPublicKeyFromFingerprint(kFingerprintValid1); |
|
Ryan Sleevi
2014/10/17 19:53:21
did git gl format do this? Doesn't seem right.
vadimgo
2014/10/20 23:35:28
Yes, "git cl format" formatted this.
|
| + EXPECT_NE(static_cast<SECItem*>(NULL), key); |
| + |
| + key = |
| + authority_keys_store_.GetICAPublicKeyFromFingerprint(kFingerprintInvalid); |
| + EXPECT_EQ(static_cast<SECItem*>(NULL), key); |
|
Ryan Sleevi
2014/10/17 19:53:21
This is a non-_nss file, you should not be using N
vadimgo
2014/10/20 23:35:27
Done.
|
| +} |
| + |
| +TEST_F(CastChannelAuthorityKeysTest, TestDefaultKeys) { |
| + ExpectKeysLoaded(); |
| +} |
| + |
| +TEST_F(CastChannelAuthorityKeysTest, TestInvalidProtobuf) { |
| + std::string keys = "test"; |
| + EXPECT_EQ(authority_keys_store_.Load(keys), false); |
| + |
| + const SECItem* key = authority_keys_store_.GetDefaultICAPublicKey(); |
| + EXPECT_EQ(static_cast<SECItem*>(NULL), key); |
| +} |
| + |
| +TEST_F(CastChannelAuthorityKeysTest, TestValidProtobuf) { |
| + std::string keys = |
| + "CrMCCiBSnZzWf+XraY5w3SbX2PEmWfHm5SNIv2pc9xbhP0EOcxKOAjCCAQoCggEBALwigL" |
| + "2A9johADuudl41fz3DZFxVlIY0LwWHKM33aYwXs1CnuIL638dDLdZ+q6BvtxNygKRHFcEg" |
| + "mVDN7BRiCVukmM3SQbY2Tv/oLjIwSoGoQqNsmzNuyrL1U2bgJ1OGGoUepzk/SneO+1RmZv" |
| + "tYVMBeOcf1UAYL4IrUzuFqVR+LFwDmaaMn5gglaTwSnY0FLNYuojHetFJQ1iBJ3nGg+a0g" |
| + "QBLx3SXr1ea4NvTWj3/KQ9zXEFvmP1GKhbPz//YDLcsjT5ytGOeTBYysUpr3TOmZer5ufk" |
| + "0K48YcqZP6OqWRXRy9ZuvMYNyGdMrP+JIcmH1X+mFHnquAt+RIgCqSxRsCAwEAAQqzAgog" |
| + "okjC6FTmVqVt6CMfHuF1b9vkB/n+1GUNYMxay2URxyASjgIwggEKAoIBAQCwDl4HOt+kX2" |
| + "j3Icdk27Z27+6Lk/j2G4jhk7cX8BUeflJVdzwCjXtKbNO91sGccsizFc8RwfVGxNUgR/sw" |
| + "9ORhDGjwXqs3jpvhvIHDcIp41oM0MpwZYuvknO3jZGxBHZzSi0hMI5CVs+dS6gVXzGCzuh" |
| + "TkugA55EZVdM5ajnpnI9poCvrEhB60xaGianMfbsguL5qeqLEO/Yemj009SwXVNVp0TbyO" |
| + "gkSW9LWVYE6l3yc9QVwHo7Q1WrOe8gUkys0xWg0mTNTT/VDhNOlMgVgwssd63YGJptQ6OI" |
| + "QDtzSedz//eAdbmcGyHzVWbjo8DCXhV/aKfknAzIMRNeeRbS5lAgMBAAE="; |
| + |
| + std::string decoded_keys; |
| + EXPECT_EQ(base::Base64Decode(keys, &decoded_keys), true); |
| + EXPECT_EQ(authority_keys_store_.Load(decoded_keys), true); |
| + |
| + ExpectKeysLoaded(); |
| + |
| + const SECItem* key = |
| + authority_keys_store_.GetICAPublicKeyFromFingerprint(kFingerprintValid2); |
| + EXPECT_NE(static_cast<SECItem*>(NULL), key); |
| +} |
| + |
| +} // namespace cast_channel |
| +} // namespace core_api |
| +} // namespace extensions |