diff options
author | ukai@chromium.org <ukai@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-23 06:40:20 +0000 |
---|---|---|
committer | ukai@chromium.org <ukai@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-23 06:40:20 +0000 |
commit | d11a34ba95bc98cf2c4b6caa2ce6ed469ae229ce (patch) | |
tree | 8fa98acc717a288be407c236b05ec250126483f7 /net/websockets/websocket_throttle_unittest.cc | |
parent | b7e7113680de40698775c7d9b9d33bb02065c114 (diff) | |
download | chromium_src-d11a34ba95bc98cf2c4b6caa2ce6ed469ae229ce.zip chromium_src-d11a34ba95bc98cf2c4b6caa2ce6ed469ae229ce.tar.gz chromium_src-d11a34ba95bc98cf2c4b6caa2ce6ed469ae229ce.tar.bz2 |
Try to fix flaky websocket tests again.
Some websoket layout tests became flaky from r41818.
This is because it adds websocket throttling in WebSocketJob.
Make sure Close() will call OnClose() even if it is waiting resolving or waiting
in throttling queue, so that WebSocketJob is removed from throttling queue
and wake up next WebSocketJob.
r42074 was reverted because failure in SocketStreamMetrics::OnClose
on Linux Builder (Views dbg).
Ignore UMA record if the connection has not been established.
TBR=tyoshino
BUG=38397
TEST=layout tests websocket/tests passes
Review URL: http://codereview.chromium.org/1134004
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@42320 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/websockets/websocket_throttle_unittest.cc')
-rw-r--r-- | net/websockets/websocket_throttle_unittest.cc | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/net/websockets/websocket_throttle_unittest.cc b/net/websockets/websocket_throttle_unittest.cc index d568292..61e5e4b 100644 --- a/net/websockets/websocket_throttle_unittest.cc +++ b/net/websockets/websocket_throttle_unittest.cc @@ -61,8 +61,13 @@ class WebSocketThrottleTest : public PlatformTest { } } - static void SetAddressList(SocketStream* socket, struct addrinfo* head) { + static void MockSocketStreamConnect( + SocketStream* socket, struct addrinfo* head) { socket->CopyAddrInfo(head); + // Add reference to socket as done in SocketStream::Connect(). + // Balanced with Release() in SocketStream::Finish() which will be + // called by SocketStream::DetachDelegate(). + socket->AddRef(); } }; @@ -77,7 +82,7 @@ TEST_F(WebSocketThrottleTest, Throttle) { scoped_refptr<SocketStream> s1 = new SocketStream(GURL("ws://host1/"), w1.get()); w1->InitSocketStream(s1.get()); - WebSocketThrottleTest::SetAddressList(s1, addr); + WebSocketThrottleTest::MockSocketStreamConnect(s1, addr); DeleteAddrInfo(addr); DLOG(INFO) << "socket1"; @@ -97,7 +102,7 @@ TEST_F(WebSocketThrottleTest, Throttle) { scoped_refptr<SocketStream> s2 = new SocketStream(GURL("ws://host2/"), w2.get()); w2->InitSocketStream(s2.get()); - WebSocketThrottleTest::SetAddressList(s2, addr); + WebSocketThrottleTest::MockSocketStreamConnect(s2, addr); DeleteAddrInfo(addr); DLOG(INFO) << "socket2"; @@ -116,7 +121,7 @@ TEST_F(WebSocketThrottleTest, Throttle) { scoped_refptr<SocketStream> s3 = new SocketStream(GURL("ws://host3/"), w3.get()); w3->InitSocketStream(s3.get()); - WebSocketThrottleTest::SetAddressList(s3, addr); + WebSocketThrottleTest::MockSocketStreamConnect(s3, addr); DeleteAddrInfo(addr); DLOG(INFO) << "socket3"; @@ -135,7 +140,7 @@ TEST_F(WebSocketThrottleTest, Throttle) { scoped_refptr<SocketStream> s4 = new SocketStream(GURL("ws://host4/"), w4.get()); w4->InitSocketStream(s4.get()); - WebSocketThrottleTest::SetAddressList(s4, addr); + WebSocketThrottleTest::MockSocketStreamConnect(s4, addr); DeleteAddrInfo(addr); DLOG(INFO) << "socket4"; @@ -153,7 +158,7 @@ TEST_F(WebSocketThrottleTest, Throttle) { scoped_refptr<SocketStream> s5 = new SocketStream(GURL("ws://host5/"), w5.get()); w5->InitSocketStream(s5.get()); - WebSocketThrottleTest::SetAddressList(s5, addr); + WebSocketThrottleTest::MockSocketStreamConnect(s5, addr); DeleteAddrInfo(addr); DLOG(INFO) << "socket5"; @@ -171,7 +176,7 @@ TEST_F(WebSocketThrottleTest, Throttle) { scoped_refptr<SocketStream> s6 = new SocketStream(GURL("ws://host6/"), w6.get()); w6->InitSocketStream(s6.get()); - WebSocketThrottleTest::SetAddressList(s6, addr); + WebSocketThrottleTest::MockSocketStreamConnect(s6, addr); DeleteAddrInfo(addr); DLOG(INFO) << "socket6"; |