Chromium Code Reviews| Index: content/browser/streams/stream_unittest.cc |
| diff --git a/content/browser/streams/stream_unittest.cc b/content/browser/streams/stream_unittest.cc |
| index e0346e5a76e9525f8376c9dc433a3cacebd0599d..71670b4f3e45a8bfab131e86e546de08eb970842 100644 |
| --- a/content/browser/streams/stream_unittest.cc |
| +++ b/content/browser/streams/stream_unittest.cc |
| @@ -302,4 +302,32 @@ TEST_F(StreamTest, UnderMemoryUsageLimit) { |
| EXPECT_EQ(stream.get(), registry_->GetStream(url).get()); |
| } |
| +TEST_F(StreamTest, Flush) { |
| + TestStreamWriter writer; |
| + TestStreamReader reader; |
| + |
| + GURL url("blob://stream"); |
| + scoped_refptr<Stream> stream(new Stream(registry_.get(), &writer, url)); |
| + EXPECT_TRUE(stream->SetReadObserver(&reader)); |
| + |
| + // If the written data size is smaller than ByteStreamWriter's (total size / |
| + // kFractionBufferBeforeSending), StreamReadObserver::OnDataAvailable is not |
| + // called |
|
tyoshino (SeeGerritForStatus)
2014/11/26 05:59:49
period
horo
2014/11/26 06:06:29
Done.
|
| + const int kBufferSize = 1; |
| + scoped_refptr<net::IOBuffer> buffer(NewIOBuffer(kBufferSize)); |
| + writer.Write(stream.get(), buffer, kBufferSize); |
| + |
| + // Run loop to make |reader| consume the data. |
| + base::MessageLoop::current()->RunUntilIdle(); |
| + EXPECT_EQ(0, reader.buffer()->capacity()); |
| + |
| + stream->Flush(); |
| + |
| + // Run loop to make |reader| consume the data. |
| + base::MessageLoop::current()->RunUntilIdle(); |
| + EXPECT_EQ(kBufferSize, reader.buffer()->capacity()); |
| + |
| + EXPECT_EQ(stream.get(), registry_->GetStream(url).get()); |
| +} |
| + |
| } // namespace content |