| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "content/common/ssl_status_serialization.h" | 5 #include "content/common/ssl_status_serialization.h" |
| 6 | 6 |
| 7 #include "net/ssl/ssl_connection_status_flags.h" | 7 #include "net/ssl/ssl_connection_status_flags.h" |
| 8 #include "testing/gtest/include/gtest/gtest.h" | 8 #include "testing/gtest/include/gtest/gtest.h" |
| 9 | 9 |
| 10 namespace content { | 10 namespace content { |
| 11 | 11 |
| 12 namespace { | 12 namespace { |
| 13 | 13 |
| 14 void SetTestStatus(SSLStatus* status) { | 14 void SetTestStatus(SSLStatus* status) { |
| 15 status->security_style = SECURITY_STYLE_AUTHENTICATED; | 15 status->security_style = SECURITY_STYLE_AUTHENTICATED; |
| 16 status->cert_id = 1; | 16 status->cert_id = 1; |
| 17 status->cert_status = net::CERT_STATUS_DATE_INVALID; | 17 status->cert_status = net::CERT_STATUS_DATE_INVALID; |
| 18 status->security_bits = 80; | 18 status->security_bits = 80; |
| 19 status->key_exchange_info = 23; | 19 status->key_exchange_info = 23; |
| 20 status->connection_status = net::SSL_CONNECTION_VERSION_TLS1_2; | 20 status->connection_status = net::SSL_CONNECTION_VERSION_TLS1_2; |
| 21 status->num_unknown_scts = 0; | 21 status->num_unknown_scts = 0; |
| 22 status->num_invalid_scts = 0; | 22 status->num_scts_invalid_signature = 0; |
| 23 status->num_scts_invalid_timestamp = 0; |
| 23 status->num_valid_scts = 1; | 24 status->num_valid_scts = 1; |
| 24 } | 25 } |
| 25 | 26 |
| 26 bool SSLStatusAreEqual(const SSLStatus& a, const SSLStatus &b) { | 27 bool SSLStatusAreEqual(const SSLStatus& a, const SSLStatus &b) { |
| 27 return a.Equals(b); | 28 return a.Equals(b); |
| 28 } | 29 } |
| 29 | 30 |
| 30 } // namespace | 31 } // namespace |
| 31 | 32 |
| 32 std::ostream& operator<<(std::ostream& os, const SSLStatus& status) { | 33 std::ostream& operator<<(std::ostream& os, const SSLStatus& status) { |
| 33 return os << "Security Style: " << status.security_style | 34 return os << "Security Style: " << status.security_style |
| 34 << "\nCert ID: " << status.cert_id | 35 << "\nCert ID: " << status.cert_id |
| 35 << "\nCert Status: " << status.cert_status | 36 << "\nCert Status: " << status.cert_status |
| 36 << "\nSecurity bits: " << status.security_bits | 37 << "\nSecurity bits: " << status.security_bits |
| 37 << "\nKey exchange info: " << status.key_exchange_info | 38 << "\nKey exchange info: " << status.key_exchange_info |
| 38 << "\nConnection status: " << status.connection_status | 39 << "\nConnection status: " << status.connection_status |
| 39 << "\nContent Status: " << status.content_status | 40 << "\nContent Status: " << status.content_status |
| 40 << "\nNumber of unknown SCTs: " << status.num_unknown_scts | 41 << "\nNumber of unknown SCTs: " << status.num_unknown_scts |
| 41 << "\nNumber of invalid SCTs: " << status.num_invalid_scts | 42 << "\nNumber of SCTs with invalid signature: " |
| 43 << status.num_scts_invalid_signature |
| 44 << "\nNumber of SCTs with invalid timestamp: " |
| 45 << status.num_scts_invalid_timestamp |
| 42 << "\nNumber of valid SCTs: " << status.num_valid_scts; | 46 << "\nNumber of valid SCTs: " << status.num_valid_scts; |
| 43 } | 47 } |
| 44 | 48 |
| 45 // Test that a valid serialized SSLStatus returns true on | 49 // Test that a valid serialized SSLStatus returns true on |
| 46 // deserialization and deserializes correctly. | 50 // deserialization and deserializes correctly. |
| 47 TEST(SSLStatusSerializationTest, DeserializeSerializedStatus) { | 51 TEST(SSLStatusSerializationTest, DeserializeSerializedStatus) { |
| 48 // Serialize dummy data and test that it deserializes properly. | 52 // Serialize dummy data and test that it deserializes properly. |
| 49 SSLStatus status; | 53 SSLStatus status; |
| 50 SetTestStatus(&status); | 54 SetTestStatus(&status); |
| 51 std::string serialized = SerializeSecurityInfo(status); | 55 std::string serialized = SerializeSecurityInfo(status); |
| (...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 103 SetTestStatus(&status); | 107 SetTestStatus(&status); |
| 104 status.security_style = static_cast<SecurityStyle>(100); | 108 status.security_style = static_cast<SecurityStyle>(100); |
| 105 std::string serialized = SerializeSecurityInfo(status); | 109 std::string serialized = SerializeSecurityInfo(status); |
| 106 | 110 |
| 107 SSLStatus invalid_deserialized; | 111 SSLStatus invalid_deserialized; |
| 108 ASSERT_FALSE(DeserializeSecurityInfo(serialized, &invalid_deserialized)); | 112 ASSERT_FALSE(DeserializeSecurityInfo(serialized, &invalid_deserialized)); |
| 109 EXPECT_PRED2(SSLStatusAreEqual, SSLStatus(), invalid_deserialized); | 113 EXPECT_PRED2(SSLStatusAreEqual, SSLStatus(), invalid_deserialized); |
| 110 } | 114 } |
| 111 | 115 |
| 112 } // namespace | 116 } // namespace |
| OLD | NEW |