diff options
author | sky@chromium.org <sky@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-11-19 18:39:38 +0000 |
---|---|---|
committer | sky@chromium.org <sky@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-11-19 18:39:38 +0000 |
commit | ee3724cc8eb917d0296562fd54d170273d3b8820 (patch) | |
tree | fa10206563156f59ce8548c471e223eaf9be8d99 /app/view_prop_unittest.cc | |
parent | 0f4758f7f597d5f4b608f75aba2cec316d1b62b8 (diff) | |
download | chromium_src-ee3724cc8eb917d0296562fd54d170273d3b8820.zip chromium_src-ee3724cc8eb917d0296562fd54d170273d3b8820.tar.gz chromium_src-ee3724cc8eb917d0296562fd54d170273d3b8820.tar.bz2 |
Converts usage of SetProp/GetProp to a map. Even after making sure we
clean up props we still leak in a handful of cases that are causing
test grief. By and large our usage of properties is for inside the
application, so that a map works fine.
BUG=61528 44991
Review URL: http://codereview.chromium.org/5075003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@66784 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'app/view_prop_unittest.cc')
-rw-r--r-- | app/view_prop_unittest.cc | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/app/view_prop_unittest.cc b/app/view_prop_unittest.cc new file mode 100644 index 0000000..9b81cd5 --- /dev/null +++ b/app/view_prop_unittest.cc @@ -0,0 +1,70 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "testing/gtest/include/gtest/gtest.h" + +#include "app/view_prop.h" +#include "base/scoped_ptr.h" + +typedef testing::Test ViewPropTest; + +static const char* kKey1 = "key_1"; +static const char* kKey2 = "key_2"; + +using app::ViewProp; + +// Test a handful of viewprop assertions. +TEST_F(ViewPropTest, Basic) { + gfx::NativeView nv1 = reinterpret_cast<gfx::NativeView>(1); + gfx::NativeView nv2 = reinterpret_cast<gfx::NativeView>(2); + + void* data1 = reinterpret_cast<void*>(11); + void* data2 = reinterpret_cast<void*>(12); + + // Initial value for a new view/key pair should be NULL. + EXPECT_EQ(NULL, ViewProp::GetValue(nv1, kKey1)); + + { + // Register a value for a view/key pair. + ViewProp prop(nv1, kKey1, data1); + EXPECT_EQ(data1, ViewProp::GetValue(nv1, kKey1)); + } + + // The property fell out of scope, so the value should now be NULL. + EXPECT_EQ(NULL, ViewProp::GetValue(nv1, kKey1)); + + { + // Register a value for a view/key pair. + scoped_ptr<ViewProp> v1(new ViewProp(nv1, kKey1, data1)); + EXPECT_EQ(data1, ViewProp::GetValue(nv1, kKey1)); + + // Register a value for the same view/key pair. + scoped_ptr<ViewProp> v2(new ViewProp(nv1, kKey1, data2)); + // The new value should take over. + EXPECT_EQ(data2, ViewProp::GetValue(nv1, kKey1)); + + // Null out the first ViewProp, which should NULL out the value. + v1.reset(NULL); + EXPECT_EQ(NULL, ViewProp::GetValue(nv1, kKey1)); + } + + // The property fell out of scope, so the value should now be NULL. + EXPECT_EQ(NULL, ViewProp::GetValue(nv1, kKey1)); + + { + // Register a value for a view/key pair. + scoped_ptr<ViewProp> v1(new ViewProp(nv1, kKey1, data1)); + scoped_ptr<ViewProp> v2(new ViewProp(nv2, kKey2, data2)); + EXPECT_EQ(data1, ViewProp::GetValue(nv1, kKey1)); + EXPECT_EQ(data2, ViewProp::GetValue(nv2, kKey2)); + + v1.reset(NULL); + EXPECT_EQ(NULL, ViewProp::GetValue(nv1, kKey1)); + EXPECT_EQ(data2, ViewProp::GetValue(nv2, kKey2)); + + v2.reset(NULL); + EXPECT_EQ(NULL, ViewProp::GetValue(nv1, kKey1)); + EXPECT_EQ(NULL, ViewProp::GetValue(nv2, kKey2)); + } +} |