diff options
author | rsesek@chromium.org <rsesek@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-06 02:39:26 +0000 |
---|---|---|
committer | rsesek@chromium.org <rsesek@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-06 02:39:26 +0000 |
commit | ecebcc98e796f701420d7f41f02d04e11bd284bf (patch) | |
tree | a8082cb4f3a0660be60a9c6e5901550e17e48850 | |
parent | 8abe765d6e082259fd79c2c1cb4834733651a677 (diff) | |
download | chromium_src-ecebcc98e796f701420d7f41f02d04e11bd284bf.zip chromium_src-ecebcc98e796f701420d7f41f02d04e11bd284bf.tar.gz chromium_src-ecebcc98e796f701420d7f41f02d04e11bd284bf.tar.bz2 |
This adds adds four macros when compiling using GTEST_OS_MAC:
{ASSERT,EXPECT}_NS{NE,EQ}. These test ObjC objects using |-isEqual:| and
prints failures using the |-description| selector. This allows for better
debugging output with ObjC++ test cases.
BUG=http://code.google.com/p/googletest/issues/detail?id=303
TEST=Covered by unit tests.
Review URL: http://codereview.chromium.org/3028047
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@55180 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/chrome_tests.gypi | 1 | ||||
-rw-r--r-- | testing/gtest.gyp | 2 | ||||
-rw-r--r-- | testing/gtest_mac.h | 48 | ||||
-rw-r--r-- | testing/gtest_mac.mm | 53 | ||||
-rw-r--r-- | testing/gtest_mac_unittest.mm | 47 |
5 files changed, 151 insertions, 0 deletions
diff --git a/chrome/chrome_tests.gypi b/chrome/chrome_tests.gypi index 678420e..039fd05 100644 --- a/chrome/chrome_tests.gypi +++ b/chrome/chrome_tests.gypi @@ -1233,6 +1233,7 @@ 'test/v8_unit_test.cc', 'test/v8_unit_test.h', 'tools/convert_dict/convert_dict_unittest.cc', + '../testing/gtest_mac_unittest.mm', '../third_party/cld/encodings/compact_lang_det/compact_lang_det_unittest_small.cc', # TODO(jcampan): Create a separate unit test for these to allow us to # test views completely decoupled from chrome. diff --git a/testing/gtest.gyp b/testing/gtest.gyp index c8f64e5..a6b28f0 100644 --- a/testing/gtest.gyp +++ b/testing/gtest.gyp @@ -51,6 +51,8 @@ 'conditions': [ ['OS == "mac"', { 'sources': [ + 'gtest_mac.h', + 'gtest_mac.mm', 'platform_test_mac.mm' ], 'link_settings': { diff --git a/testing/gtest_mac.h b/testing/gtest_mac.h new file mode 100644 index 0000000..aa48c94 --- /dev/null +++ b/testing/gtest_mac.h @@ -0,0 +1,48 @@ +// 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. + +#ifndef TESTING_GTEST_MAC_H_ +#define TESTING_GTEST_MAC_H_ + +#include <gtest/internal/gtest-port.h> +#include <gtest/gtest.h> + +#ifdef GTEST_OS_MAC + +#import <Foundation/Foundation.h> + +namespace testing { +namespace internal { + +// This overloaded version allows comparison between ObjC objects that conform +// to the NSObject protocol. Used to implement {ASSERT|EXPECT}_EQ(). +GTEST_API_ AssertionResult CmpHelperNSEQ(const char* expected_expression, + const char* actual_expression, + id<NSObject> expected, + id<NSObject> actual); + +// This overloaded version allows comparison between ObjC objects that conform +// to the NSObject protocol. Used to implement {ASSERT|EXPECT}_NE(). +GTEST_API_ AssertionResult CmpHelperNSNE(const char* expected_expression, + const char* actual_expression, + id<NSObject> expected, + id<NSObject> actual); + +} // namespace internal +} // namespace testing + +// Tests that [expected isEqual:actual]. +#define EXPECT_NSEQ(expected, actual) \ + EXPECT_PRED_FORMAT2(::testing::internal::CmpHelperNSEQ, expected, actual) +#define EXPECT_NSNE(val1, val2) \ + EXPECT_PRED_FORMAT2(::testing::internal::CmpHelperNSNE, val1, val2) + +#define ASSERT_NSEQ(expected, actual) \ + ASSERT_PRED_FORMAT2(::testing::internal::CmpHelperNSEQ, expected, actual) +#define ASSERT_NSNE(val1, val2) \ + ASSERT_PRED_FORMAT2(::testing::internal::CmpHelperNSNE, val1, val2) + +#endif // GTEST_OS_MAC + +#endif // TESTING_GTEST_MAC_H_ diff --git a/testing/gtest_mac.mm b/testing/gtest_mac.mm new file mode 100644 index 0000000..3caacdf --- /dev/null +++ b/testing/gtest_mac.mm @@ -0,0 +1,53 @@ +// 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. + +#import "gtest_mac.h" + +#include <gtest/internal/gtest-port.h> +#include <gtest/internal/gtest-string.h> +#include <gtest/gtest.h> + +#ifdef GTEST_OS_MAC + +#import <Foundation/Foundation.h> + +namespace testing { +namespace internal { + +// This overloaded version allows comparison between ObjC objects that conform +// to the NSObject protocol. Used to implement {ASSERT|EXPECT}_EQ(). +GTEST_API_ AssertionResult CmpHelperNSEQ(const char* expected_expression, + const char* actual_expression, + id<NSObject> expected, + id<NSObject> actual) { + if ([expected isEqual:actual]) { + return AssertionSuccess(); + } + return EqFailure(expected_expression, + actual_expression, + String([[expected description] UTF8String]), + String([[actual description] UTF8String]), + false); +} + +// This overloaded version allows comparison between ObjC objects that conform +// to the NSObject protocol. Used to implement {ASSERT|EXPECT}_NE(). +GTEST_API_ AssertionResult CmpHelperNSNE(const char* expected_expression, + const char* actual_expression, + id<NSObject> expected, + id<NSObject> actual) { + if (![expected isEqual:actual]) { + return AssertionSuccess(); + } + Message msg; + msg << "Expected: (" << expected_expression << ") != (" << actual_expression + << "), actual: " << String([[expected description] UTF8String]) + << " vs " << String([[actual description] UTF8String]); + return AssertionFailure(msg); +} + +} // namespace internal +} // namespace testing + +#endif // GTEST_OS_MAC diff --git a/testing/gtest_mac_unittest.mm b/testing/gtest_mac_unittest.mm new file mode 100644 index 0000000..552beee --- /dev/null +++ b/testing/gtest_mac_unittest.mm @@ -0,0 +1,47 @@ +// 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. + +// Note that while this file is in testing/ and tests GTest macros, it is built +// as part of Chromium's unit_tests target because the project does not build +// or run GTest's internal test suite. + +#import "testing/gtest_mac.h" + +#import <Foundation/Foundation.h> + +#include "base/scoped_nsautorelease_pool.h" +#include "testing/gtest/include/gtest/internal/gtest-port.h" +#include "testing/gtest/include/gtest/gtest.h" + +TEST(GTestMac, ExpectNSEQ) { + base::ScopedNSAutoreleasePool pool; + + EXPECT_NSEQ(@"a", @"a"); + + NSString* s1 = [NSString stringWithUTF8String:"a"]; + NSString* s2 = [NSString stringWithString:@"a"]; + EXPECT_NE(s1, s2); + EXPECT_NSEQ(s1, s2); +} + +TEST(GTestMac, AssertNSEQ) { + base::ScopedNSAutoreleasePool pool; + + NSNumber* n1 = [NSNumber numberWithInt:42]; + NSNumber* n2 = [NSNumber numberWithInt:42]; + EXPECT_NE(n1, n2); + ASSERT_NSEQ(n1, n2); +} + +TEST(GTestMac, ExpectNSNE) { + base::ScopedNSAutoreleasePool pool; + + EXPECT_NSNE([NSNumber numberWithInt:2], [NSNumber numberWithInt:42]); +} + +TEST(GTestMac, AssertNSNE) { + base::ScopedNSAutoreleasePool pool; + + ASSERT_NSNE(@"a", @"b"); +} |