// 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 #include "base/macros.h" #include "base/win/scoped_bstr.h" #include "testing/gtest/include/gtest/gtest.h" namespace base { namespace win { namespace { static const wchar_t kTestString1[] = L"123"; static const wchar_t kTestString2[] = L"456789"; size_t test1_len = arraysize(kTestString1) - 1; size_t test2_len = arraysize(kTestString2) - 1; void DumbBstrTests() { ScopedBstr b; EXPECT_TRUE(b == NULL); EXPECT_EQ(0u, b.Length()); EXPECT_EQ(0u, b.ByteLength()); b.Reset(NULL); EXPECT_TRUE(b == NULL); EXPECT_TRUE(b.Release() == NULL); ScopedBstr b2; b.Swap(b2); EXPECT_TRUE(b2 == NULL); } void GiveMeABstr(BSTR* ret) { *ret = SysAllocString(kTestString1); } void BasicBstrTests() { ScopedBstr b1(kTestString1); EXPECT_EQ(test1_len, b1.Length()); EXPECT_EQ(test1_len * sizeof(kTestString1[0]), b1.ByteLength()); ScopedBstr b2; b1.Swap(b2); EXPECT_EQ(test1_len, b2.Length()); EXPECT_EQ(0u, b1.Length()); EXPECT_EQ(0, lstrcmp(b2, kTestString1)); BSTR tmp = b2.Release(); EXPECT_TRUE(tmp != NULL); EXPECT_EQ(0, lstrcmp(tmp, kTestString1)); EXPECT_TRUE(b2 == NULL); SysFreeString(tmp); GiveMeABstr(b2.Receive()); EXPECT_TRUE(b2 != NULL); b2.Reset(); EXPECT_TRUE(b2.AllocateBytes(100) != NULL); EXPECT_EQ(100u, b2.ByteLength()); EXPECT_EQ(100 / sizeof(kTestString1[0]), b2.Length()); lstrcpy(static_cast(b2), kTestString1); EXPECT_EQ(test1_len, static_cast(lstrlen(b2))); EXPECT_EQ(100 / sizeof(kTestString1[0]), b2.Length()); b2.SetByteLen(lstrlen(b2) * sizeof(kTestString2[0])); EXPECT_EQ(b2.Length(), static_cast(lstrlen(b2))); EXPECT_TRUE(b1.Allocate(kTestString2) != NULL); EXPECT_EQ(test2_len, b1.Length()); b1.SetByteLen((test2_len - 1) * sizeof(kTestString2[0])); EXPECT_EQ(test2_len - 1, b1.Length()); } } // namespace TEST(ScopedBstrTest, ScopedBstr) { DumbBstrTests(); BasicBstrTests(); } } // namespace win } // namespace base