Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "core/timing/PerformanceResourceTiming.h" | |
| 6 | |
| 7 #include "testing/gtest/include/gtest/gtest.h" | |
| 8 | |
| 9 namespace blink { | |
| 10 | |
| 11 class PerformanceResourceTimingTest : public ::testing::Test { | |
| 12 protected: | |
| 13 AtomicString produceNextHopProtocol( | |
| 14 const AtomicString& alpnNegotiatedProtocol, | |
| 15 const AtomicString& connectionInfo) { | |
| 16 return PerformanceResourceTiming::produceNextHopProtocol( | |
| 17 alpnNegotiatedProtocol, connectionInfo); | |
| 18 } | |
| 19 }; | |
| 20 | |
| 21 TEST_F(PerformanceResourceTimingTest, | |
| 22 TestFallbackToConnectionInfoWhenALPNUnknown) { | |
| 23 AtomicString connectionInfo = "http/1.1"; | |
| 24 AtomicString alpnNegotiatedProtocol = "unknown"; | |
| 25 EXPECT_EQ(produceNextHopProtocol(alpnNegotiatedProtocol, connectionInfo), | |
| 26 connectionInfo); | |
| 27 } | |
| 28 | |
| 29 TEST_F(PerformanceResourceTimingTest, | |
| 30 TestFallbackToHTTPInfoWhenALPNAndConnectionInfoUnknown) { | |
| 31 AtomicString connectionInfo = "unknown"; | |
| 32 AtomicString alpnNegotiatedProtocol = "unknown"; | |
| 33 EXPECT_EQ(produceNextHopProtocol(alpnNegotiatedProtocol, connectionInfo), | |
| 34 "http/1.1"); | |
| 35 } | |
| 36 | |
| 37 TEST_F(PerformanceResourceTimingTest, TestReformatedWhenALPNIsQuicAndSpdy) { | |
| 38 AtomicString connectionInfo = "http/1.1"; | |
| 39 AtomicString alpnNegotiatedProtocol = "quic/1+spdy/3"; | |
| 40 EXPECT_EQ(produceNextHopProtocol(alpnNegotiatedProtocol, connectionInfo), | |
| 41 "http2/+quic/1"); | |
| 42 } | |
| 43 | |
| 44 TEST_F(PerformanceResourceTimingTest, TestReformatedWhenALPNIsQuic) { | |
| 45 AtomicString connectionInfo = "http/1.1"; | |
| 46 AtomicString alpnNegotiatedProtocol = "quic/1+other/123"; | |
|
panicker
2016/10/27 22:05:22
what if this is just "quic/1"? Could we remove the
| |
| 47 EXPECT_EQ(produceNextHopProtocol(alpnNegotiatedProtocol, connectionInfo), | |
| 48 "http2/+quic/1"); | |
| 49 } | |
| 50 | |
| 51 TEST_F(PerformanceResourceTimingTest, TestNoChangeWhenOtherwise) { | |
| 52 AtomicString connectionInfo = "http/1.1"; | |
| 53 AtomicString alpnNegotiatedProtocol = "RandomProtocol"; | |
| 54 EXPECT_EQ(produceNextHopProtocol(alpnNegotiatedProtocol, connectionInfo), | |
| 55 alpnNegotiatedProtocol); | |
| 56 } | |
| 57 } | |
| OLD | NEW |