OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/quic/test_tools/quic_test_utils.h" | 5 #include "net/quic/test_tools/quic_test_utils.h" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 | 8 |
9 #include "base/memory/ptr_util.h" | 9 #include "base/memory/ptr_util.h" |
10 #include "base/sha1.h" | |
11 #include "base/strings/string_number_conversions.h" | 10 #include "base/strings/string_number_conversions.h" |
12 #include "net/quic/core/crypto/crypto_framer.h" | 11 #include "net/quic/core/crypto/crypto_framer.h" |
13 #include "net/quic/core/crypto/crypto_handshake.h" | 12 #include "net/quic/core/crypto/crypto_handshake.h" |
14 #include "net/quic/core/crypto/crypto_utils.h" | 13 #include "net/quic/core/crypto/crypto_utils.h" |
15 #include "net/quic/core/crypto/null_encrypter.h" | 14 #include "net/quic/core/crypto/null_encrypter.h" |
16 #include "net/quic/core/crypto/quic_decrypter.h" | 15 #include "net/quic/core/crypto/quic_decrypter.h" |
17 #include "net/quic/core/crypto/quic_encrypter.h" | 16 #include "net/quic/core/crypto/quic_encrypter.h" |
18 #include "net/quic/core/quic_data_writer.h" | 17 #include "net/quic/core/quic_data_writer.h" |
19 #include "net/quic/core/quic_framer.h" | 18 #include "net/quic/core/quic_framer.h" |
20 #include "net/quic/core/quic_packet_creator.h" | 19 #include "net/quic/core/quic_packet_creator.h" |
21 #include "net/quic/core/quic_utils.h" | 20 #include "net/quic/core/quic_utils.h" |
22 #include "net/quic/test_tools/crypto_test_utils.h" | 21 #include "net/quic/test_tools/crypto_test_utils.h" |
23 #include "net/quic/test_tools/quic_connection_peer.h" | 22 #include "net/quic/test_tools/quic_connection_peer.h" |
24 #include "net/spdy/spdy_frame_builder.h" | 23 #include "net/spdy/spdy_frame_builder.h" |
25 #include "net/tools/quic/quic_per_connection_packet_writer.h" | 24 #include "net/tools/quic/quic_per_connection_packet_writer.h" |
| 25 #include "third_party/boringssl/src/include/openssl/sha.h" |
26 | 26 |
27 using base::StringPiece; | 27 using base::StringPiece; |
28 using std::string; | 28 using std::string; |
29 using testing::Invoke; | 29 using testing::Invoke; |
30 using testing::_; | 30 using testing::_; |
31 | 31 |
32 namespace net { | 32 namespace net { |
33 | 33 |
34 namespace test { | 34 namespace test { |
35 | 35 |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
91 #include "net/quic/core/quic_flags_list.h" | 91 #include "net/quic/core/quic_flags_list.h" |
92 #undef QUIC_FLAG | 92 #undef QUIC_FLAG |
93 } | 93 } |
94 | 94 |
95 QuicFlagSaver::~QuicFlagSaver() { | 95 QuicFlagSaver::~QuicFlagSaver() { |
96 #define QUIC_FLAG(type, flag, value) flag = value; | 96 #define QUIC_FLAG(type, flag, value) flag = value; |
97 #include "net/quic/core/quic_flags_list.h" | 97 #include "net/quic/core/quic_flags_list.h" |
98 #undef QUIC_FLAG | 98 #undef QUIC_FLAG |
99 } | 99 } |
100 | 100 |
| 101 string Sha1Hash(StringPiece data) { |
| 102 char buffer[SHA_DIGEST_LENGTH]; |
| 103 SHA1(reinterpret_cast<const uint8_t*>(data.data()), data.size(), |
| 104 reinterpret_cast<uint8_t*>(buffer)); |
| 105 return string(buffer, arraysize(buffer)); |
| 106 } |
| 107 |
101 uint64_t SimpleRandom::RandUint64() { | 108 uint64_t SimpleRandom::RandUint64() { |
102 unsigned char hash[base::kSHA1Length]; | 109 string hash = |
103 base::SHA1HashBytes(reinterpret_cast<unsigned char*>(&seed_), sizeof(seed_), | 110 Sha1Hash(StringPiece(reinterpret_cast<char*>(&seed_), sizeof(seed_))); |
104 hash); | 111 DCHECK_EQ(static_cast<size_t>(SHA_DIGEST_LENGTH), hash.length()); |
105 memcpy(&seed_, hash, sizeof(seed_)); | 112 memcpy(&seed_, hash.data(), sizeof(seed_)); |
106 return seed_; | 113 return seed_; |
107 } | 114 } |
108 | 115 |
109 void SimpleRandom::RandBytes(void* data, size_t len) { | 116 void SimpleRandom::RandBytes(void* data, size_t len) { |
110 uint8_t* real_data = static_cast<uint8_t*>(data); | 117 uint8_t* real_data = static_cast<uint8_t*>(data); |
111 for (size_t offset = 0; offset < len; offset++) { | 118 for (size_t offset = 0; offset < len; offset++) { |
112 real_data[offset] = RandUint64() & 0xff; | 119 real_data[offset] = RandUint64() & 0xff; |
113 } | 120 } |
114 } | 121 } |
115 | 122 |
(...skipping 767 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
883 // strike register worries that we've just overflowed a uint32_t time. | 890 // strike register worries that we've just overflowed a uint32_t time. |
884 (*server_connection)->AdvanceTime(connection_start_time); | 891 (*server_connection)->AdvanceTime(connection_start_time); |
885 } | 892 } |
886 | 893 |
887 QuicStreamId QuicClientDataStreamId(int i) { | 894 QuicStreamId QuicClientDataStreamId(int i) { |
888 return kClientDataStreamId1 + 2 * i; | 895 return kClientDataStreamId1 + 2 * i; |
889 } | 896 } |
890 | 897 |
891 } // namespace test | 898 } // namespace test |
892 } // namespace net | 899 } // namespace net |
OLD | NEW |