1 // Copyright (c) 2010 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 "net/base/capturing_net_log.h"
6 #include "net/base/net_log.h"
7 #include "net/base/net_log_unittest.h"
8 #include "testing/gtest/include/gtest/gtest.h"
9
10 namespace net {
11
12 namespace {
13
TEST(NetLog,ScopedNetLogEventTest)14 TEST(NetLog, ScopedNetLogEventTest) {
15 CapturingNetLog log(CapturingNetLog::kUnbounded);
16 BoundNetLog net_log(BoundNetLog::Make(&log, NetLog::SOURCE_URL_REQUEST));
17
18 scoped_ptr<ScopedNetLogEvent> net_log_event(
19 new ScopedNetLogEvent(net_log, NetLog::TYPE_REQUEST_ALIVE, NULL));
20
21 CapturingNetLog::EntryList entries;
22 log.GetEntries(&entries);
23 EXPECT_EQ(1u, entries.size());
24 EXPECT_TRUE(LogContainsBeginEvent(entries, 0, NetLog::TYPE_REQUEST_ALIVE));
25
26 net_log_event.reset();
27 log.GetEntries(&entries);
28 EXPECT_EQ(2u, entries.size());
29 EXPECT_TRUE(LogContainsEndEvent(entries, 1, NetLog::TYPE_REQUEST_ALIVE));
30 }
31
32 } // namespace
33
34 } // namespace net
35