Protocol Buffers - Google's data interchange format (grpc依赖)
https://developers.google.com/protocol-buffers/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2466 lines
83 KiB
2466 lines
83 KiB
// Protocol Buffers - Google's data interchange format |
|
// Copyright 2015 Google Inc. All rights reserved. |
|
// https://developers.google.com/protocol-buffers/ |
|
// |
|
// Redistribution and use in source and binary forms, with or without |
|
// modification, are permitted provided that the following conditions are |
|
// met: |
|
// |
|
// * Redistributions of source code must retain the above copyright |
|
// notice, this list of conditions and the following disclaimer. |
|
// * Redistributions in binary form must reproduce the above |
|
// copyright notice, this list of conditions and the following disclaimer |
|
// in the documentation and/or other materials provided with the |
|
// distribution. |
|
// * Neither the name of Google Inc. nor the names of its |
|
// contributors may be used to endorse or promote products derived from |
|
// this software without specific prior written permission. |
|
// |
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
|
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
|
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
|
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
|
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
|
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
|
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
|
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
|
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|
|
|
#import <Foundation/Foundation.h> |
|
#import <XCTest/XCTest.h> |
|
|
|
#import "GPBDictionary.h" |
|
|
|
#import "GPBTestUtilities.h" |
|
#import "objectivec/Tests/UnittestRuntimeProto2.pbobjc.h" |
|
|
|
// Pull in the macros (using an external file because expanding all tests |
|
// in a single file makes a file that is failing to work with within Xcode. |
|
//%PDDM-IMPORT-DEFINES GPBDictionaryTests.pddm |
|
|
|
//%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(UInt32, uint32_t, 100U, 101U) |
|
// This block of code is generated, do not edit it directly. |
|
// clang-format off |
|
|
|
#pragma mark - Bool -> UInt32 |
|
|
|
@interface GPBBoolUInt32DictionaryTests : XCTestCase |
|
@end |
|
|
|
@implementation GPBBoolUInt32DictionaryTests |
|
|
|
- (void)testEmpty { |
|
GPBBoolUInt32Dictionary *dict = [[GPBBoolUInt32Dictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getUInt32:NULL forKey:YES]); |
|
[dict enumerateKeysAndUInt32sUsingBlock:^(BOOL aKey, uint32_t aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue, stop) |
|
XCTFail(@"Shouldn't get here!"); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testOne { |
|
GPBBoolUInt32Dictionary *dict = [[GPBBoolUInt32Dictionary alloc] init]; |
|
[dict setUInt32:100U forKey:YES]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 1U); |
|
uint32_t value; |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 100U); |
|
XCTAssertFalse([dict getUInt32:NULL forKey:NO]); |
|
[dict enumerateKeysAndUInt32sUsingBlock:^(BOOL aKey, uint32_t aValue, BOOL *stop) { |
|
XCTAssertEqual(aKey, YES); |
|
XCTAssertEqual(aValue, 100U); |
|
XCTAssertNotEqual(stop, NULL); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testBasics { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const uint32_t kValues[] = { 100U, 101U }; |
|
GPBBoolUInt32Dictionary *dict = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
uint32_t value; |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 100U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 101U); |
|
|
|
__block NSUInteger idx = 0; |
|
BOOL *seenKeys = malloc(2 * sizeof(BOOL)); |
|
uint32_t *seenValues = malloc(2 * sizeof(uint32_t)); |
|
[dict enumerateKeysAndUInt32sUsingBlock:^(BOOL aKey, uint32_t aValue, BOOL *stop) { |
|
XCTAssertLessThan(idx, 2U); |
|
seenKeys[idx] = aKey; |
|
seenValues[idx] = aValue; |
|
XCTAssertNotEqual(stop, NULL); |
|
++idx; |
|
}]; |
|
for (int i = 0; i < 2; ++i) { |
|
BOOL foundKey = NO; |
|
for (int j = 0; (j < 2) && !foundKey; ++j) { |
|
if (kKeys[i] == seenKeys[j]) { |
|
foundKey = YES; |
|
XCTAssertEqual(kValues[i], seenValues[j], @"i = %d, j = %d", i, j); |
|
} |
|
} |
|
XCTAssertTrue(foundKey, @"i = %d", i); |
|
} |
|
free(seenKeys); |
|
free(seenValues); |
|
|
|
// Stopping the enumeration. |
|
idx = 0; |
|
[dict enumerateKeysAndUInt32sUsingBlock:^(BOOL aKey, uint32_t aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue) |
|
if (idx == 0) *stop = YES; |
|
XCTAssertNotEqual(idx, 2U); |
|
++idx; |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testEquality { |
|
const BOOL kKeys1[] = { YES, NO }; |
|
const BOOL kKeys2[] = { NO, YES }; |
|
const uint32_t kValues1[] = { 100U, 101U }; |
|
const uint32_t kValues2[] = { 101U, 100U }; |
|
const uint32_t kValues3[] = { 101U }; |
|
GPBBoolUInt32Dictionary *dict1 = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1); |
|
GPBBoolUInt32Dictionary *dict1prime = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1prime); |
|
GPBBoolUInt32Dictionary *dict2 = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues2 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
GPBBoolUInt32Dictionary *dict3 = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues1 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict3); |
|
GPBBoolUInt32Dictionary *dict4 = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues3 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues3)]; |
|
XCTAssertNotNil(dict4); |
|
|
|
// 1/1Prime should be different objects, but equal. |
|
XCTAssertNotEqual(dict1, dict1prime); |
|
XCTAssertEqualObjects(dict1, dict1prime); |
|
// Equal, so they must have same hash. |
|
XCTAssertEqual([dict1 hash], [dict1prime hash]); |
|
|
|
// 2 is same keys, different values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict2); |
|
|
|
// 3 is different keys, same values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict3); |
|
|
|
// 4 Fewer pairs; not equal |
|
XCTAssertNotEqualObjects(dict1, dict4); |
|
|
|
[dict1 release]; |
|
[dict1prime release]; |
|
[dict2 release]; |
|
[dict3 release]; |
|
[dict4 release]; |
|
} |
|
|
|
- (void)testCopy { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const uint32_t kValues[] = { 100U, 101U }; |
|
GPBBoolUInt32Dictionary *dict = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolUInt32Dictionary *dict2 = [dict copy]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new object but equal. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
XCTAssertTrue([dict2 isKindOfClass:[GPBBoolUInt32Dictionary class]]); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testDictionaryFromDictionary { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const uint32_t kValues[] = { 100U, 101U }; |
|
GPBBoolUInt32Dictionary *dict = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolUInt32Dictionary *dict2 = |
|
[[GPBBoolUInt32Dictionary alloc] initWithDictionary:dict]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new pointer, but equal objects. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testAdds { |
|
GPBBoolUInt32Dictionary *dict = [[GPBBoolUInt32Dictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
|
|
XCTAssertEqual(dict.count, 0U); |
|
[dict setUInt32:100U forKey:YES]; |
|
XCTAssertEqual(dict.count, 1U); |
|
|
|
const BOOL kKeys[] = { NO }; |
|
const uint32_t kValues[] = { 101U }; |
|
GPBBoolUInt32Dictionary *dict2 = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
uint32_t value; |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 100U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 101U); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testRemove { |
|
const BOOL kKeys[] = { YES, NO}; |
|
const uint32_t kValues[] = { 100U, 101U }; |
|
GPBBoolUInt32Dictionary *dict = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
[dict removeUInt32ForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
uint32_t value; |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 100U); |
|
XCTAssertFalse([dict getUInt32:NULL forKey:NO]); |
|
|
|
// Remove again does nothing. |
|
[dict removeUInt32ForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 100U); |
|
XCTAssertFalse([dict getUInt32:NULL forKey:NO]); |
|
|
|
[dict removeAll]; |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertFalse([dict getUInt32:NULL forKey:NO]); |
|
[dict release]; |
|
} |
|
|
|
- (void)testInplaceMutation { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const uint32_t kValues[] = { 100U, 101U }; |
|
GPBBoolUInt32Dictionary *dict = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
uint32_t value; |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 100U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 101U); |
|
|
|
[dict setUInt32:101U forKey:YES]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 101U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 101U); |
|
|
|
[dict setUInt32:100U forKey:NO]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 101U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 100U); |
|
|
|
const BOOL kKeys2[] = { NO, YES }; |
|
const uint32_t kValues2[] = { 101U, 100U }; |
|
GPBBoolUInt32Dictionary *dict2 = |
|
[[GPBBoolUInt32Dictionary alloc] initWithUInt32s:kValues2 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 100U); |
|
XCTAssertTrue([dict getUInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 101U); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
@end |
|
|
|
// clang-format on |
|
//%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Int32, int32_t, 200, 201) |
|
// This block of code is generated, do not edit it directly. |
|
// clang-format off |
|
|
|
#pragma mark - Bool -> Int32 |
|
|
|
@interface GPBBoolInt32DictionaryTests : XCTestCase |
|
@end |
|
|
|
@implementation GPBBoolInt32DictionaryTests |
|
|
|
- (void)testEmpty { |
|
GPBBoolInt32Dictionary *dict = [[GPBBoolInt32Dictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getInt32:NULL forKey:YES]); |
|
[dict enumerateKeysAndInt32sUsingBlock:^(BOOL aKey, int32_t aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue, stop) |
|
XCTFail(@"Shouldn't get here!"); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testOne { |
|
GPBBoolInt32Dictionary *dict = [[GPBBoolInt32Dictionary alloc] init]; |
|
[dict setInt32:200 forKey:YES]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 1U); |
|
int32_t value; |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 200); |
|
XCTAssertFalse([dict getInt32:NULL forKey:NO]); |
|
[dict enumerateKeysAndInt32sUsingBlock:^(BOOL aKey, int32_t aValue, BOOL *stop) { |
|
XCTAssertEqual(aKey, YES); |
|
XCTAssertEqual(aValue, 200); |
|
XCTAssertNotEqual(stop, NULL); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testBasics { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const int32_t kValues[] = { 200, 201 }; |
|
GPBBoolInt32Dictionary *dict = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
int32_t value; |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 200); |
|
XCTAssertTrue([dict getInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 201); |
|
|
|
__block NSUInteger idx = 0; |
|
BOOL *seenKeys = malloc(2 * sizeof(BOOL)); |
|
int32_t *seenValues = malloc(2 * sizeof(int32_t)); |
|
[dict enumerateKeysAndInt32sUsingBlock:^(BOOL aKey, int32_t aValue, BOOL *stop) { |
|
XCTAssertLessThan(idx, 2U); |
|
seenKeys[idx] = aKey; |
|
seenValues[idx] = aValue; |
|
XCTAssertNotEqual(stop, NULL); |
|
++idx; |
|
}]; |
|
for (int i = 0; i < 2; ++i) { |
|
BOOL foundKey = NO; |
|
for (int j = 0; (j < 2) && !foundKey; ++j) { |
|
if (kKeys[i] == seenKeys[j]) { |
|
foundKey = YES; |
|
XCTAssertEqual(kValues[i], seenValues[j], @"i = %d, j = %d", i, j); |
|
} |
|
} |
|
XCTAssertTrue(foundKey, @"i = %d", i); |
|
} |
|
free(seenKeys); |
|
free(seenValues); |
|
|
|
// Stopping the enumeration. |
|
idx = 0; |
|
[dict enumerateKeysAndInt32sUsingBlock:^(BOOL aKey, int32_t aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue) |
|
if (idx == 0) *stop = YES; |
|
XCTAssertNotEqual(idx, 2U); |
|
++idx; |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testEquality { |
|
const BOOL kKeys1[] = { YES, NO }; |
|
const BOOL kKeys2[] = { NO, YES }; |
|
const int32_t kValues1[] = { 200, 201 }; |
|
const int32_t kValues2[] = { 201, 200 }; |
|
const int32_t kValues3[] = { 201 }; |
|
GPBBoolInt32Dictionary *dict1 = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1); |
|
GPBBoolInt32Dictionary *dict1prime = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1prime); |
|
GPBBoolInt32Dictionary *dict2 = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues2 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
GPBBoolInt32Dictionary *dict3 = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues1 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict3); |
|
GPBBoolInt32Dictionary *dict4 = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues3 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues3)]; |
|
XCTAssertNotNil(dict4); |
|
|
|
// 1/1Prime should be different objects, but equal. |
|
XCTAssertNotEqual(dict1, dict1prime); |
|
XCTAssertEqualObjects(dict1, dict1prime); |
|
// Equal, so they must have same hash. |
|
XCTAssertEqual([dict1 hash], [dict1prime hash]); |
|
|
|
// 2 is same keys, different values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict2); |
|
|
|
// 3 is different keys, same values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict3); |
|
|
|
// 4 Fewer pairs; not equal |
|
XCTAssertNotEqualObjects(dict1, dict4); |
|
|
|
[dict1 release]; |
|
[dict1prime release]; |
|
[dict2 release]; |
|
[dict3 release]; |
|
[dict4 release]; |
|
} |
|
|
|
- (void)testCopy { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const int32_t kValues[] = { 200, 201 }; |
|
GPBBoolInt32Dictionary *dict = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolInt32Dictionary *dict2 = [dict copy]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new object but equal. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
XCTAssertTrue([dict2 isKindOfClass:[GPBBoolInt32Dictionary class]]); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testDictionaryFromDictionary { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const int32_t kValues[] = { 200, 201 }; |
|
GPBBoolInt32Dictionary *dict = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolInt32Dictionary *dict2 = |
|
[[GPBBoolInt32Dictionary alloc] initWithDictionary:dict]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new pointer, but equal objects. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testAdds { |
|
GPBBoolInt32Dictionary *dict = [[GPBBoolInt32Dictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
|
|
XCTAssertEqual(dict.count, 0U); |
|
[dict setInt32:200 forKey:YES]; |
|
XCTAssertEqual(dict.count, 1U); |
|
|
|
const BOOL kKeys[] = { NO }; |
|
const int32_t kValues[] = { 201 }; |
|
GPBBoolInt32Dictionary *dict2 = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
int32_t value; |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 200); |
|
XCTAssertTrue([dict getInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 201); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testRemove { |
|
const BOOL kKeys[] = { YES, NO}; |
|
const int32_t kValues[] = { 200, 201 }; |
|
GPBBoolInt32Dictionary *dict = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
[dict removeInt32ForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
int32_t value; |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 200); |
|
XCTAssertFalse([dict getInt32:NULL forKey:NO]); |
|
|
|
// Remove again does nothing. |
|
[dict removeInt32ForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 200); |
|
XCTAssertFalse([dict getInt32:NULL forKey:NO]); |
|
|
|
[dict removeAll]; |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getInt32:NULL forKey:YES]); |
|
XCTAssertFalse([dict getInt32:NULL forKey:NO]); |
|
[dict release]; |
|
} |
|
|
|
- (void)testInplaceMutation { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const int32_t kValues[] = { 200, 201 }; |
|
GPBBoolInt32Dictionary *dict = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
int32_t value; |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 200); |
|
XCTAssertTrue([dict getInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 201); |
|
|
|
[dict setInt32:201 forKey:YES]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 201); |
|
XCTAssertTrue([dict getInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 201); |
|
|
|
[dict setInt32:200 forKey:NO]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 201); |
|
XCTAssertTrue([dict getInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 200); |
|
|
|
const BOOL kKeys2[] = { NO, YES }; |
|
const int32_t kValues2[] = { 201, 200 }; |
|
GPBBoolInt32Dictionary *dict2 = |
|
[[GPBBoolInt32Dictionary alloc] initWithInt32s:kValues2 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getInt32:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt32:&value forKey:YES]); |
|
XCTAssertEqual(value, 200); |
|
XCTAssertTrue([dict getInt32:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt32:&value forKey:NO]); |
|
XCTAssertEqual(value, 201); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
@end |
|
|
|
// clang-format on |
|
//%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(UInt64, uint64_t, 300U, 301U) |
|
// This block of code is generated, do not edit it directly. |
|
// clang-format off |
|
|
|
#pragma mark - Bool -> UInt64 |
|
|
|
@interface GPBBoolUInt64DictionaryTests : XCTestCase |
|
@end |
|
|
|
@implementation GPBBoolUInt64DictionaryTests |
|
|
|
- (void)testEmpty { |
|
GPBBoolUInt64Dictionary *dict = [[GPBBoolUInt64Dictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getUInt64:NULL forKey:YES]); |
|
[dict enumerateKeysAndUInt64sUsingBlock:^(BOOL aKey, uint64_t aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue, stop) |
|
XCTFail(@"Shouldn't get here!"); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testOne { |
|
GPBBoolUInt64Dictionary *dict = [[GPBBoolUInt64Dictionary alloc] init]; |
|
[dict setUInt64:300U forKey:YES]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 1U); |
|
uint64_t value; |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 300U); |
|
XCTAssertFalse([dict getUInt64:NULL forKey:NO]); |
|
[dict enumerateKeysAndUInt64sUsingBlock:^(BOOL aKey, uint64_t aValue, BOOL *stop) { |
|
XCTAssertEqual(aKey, YES); |
|
XCTAssertEqual(aValue, 300U); |
|
XCTAssertNotEqual(stop, NULL); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testBasics { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const uint64_t kValues[] = { 300U, 301U }; |
|
GPBBoolUInt64Dictionary *dict = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
uint64_t value; |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 300U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 301U); |
|
|
|
__block NSUInteger idx = 0; |
|
BOOL *seenKeys = malloc(2 * sizeof(BOOL)); |
|
uint64_t *seenValues = malloc(2 * sizeof(uint64_t)); |
|
[dict enumerateKeysAndUInt64sUsingBlock:^(BOOL aKey, uint64_t aValue, BOOL *stop) { |
|
XCTAssertLessThan(idx, 2U); |
|
seenKeys[idx] = aKey; |
|
seenValues[idx] = aValue; |
|
XCTAssertNotEqual(stop, NULL); |
|
++idx; |
|
}]; |
|
for (int i = 0; i < 2; ++i) { |
|
BOOL foundKey = NO; |
|
for (int j = 0; (j < 2) && !foundKey; ++j) { |
|
if (kKeys[i] == seenKeys[j]) { |
|
foundKey = YES; |
|
XCTAssertEqual(kValues[i], seenValues[j], @"i = %d, j = %d", i, j); |
|
} |
|
} |
|
XCTAssertTrue(foundKey, @"i = %d", i); |
|
} |
|
free(seenKeys); |
|
free(seenValues); |
|
|
|
// Stopping the enumeration. |
|
idx = 0; |
|
[dict enumerateKeysAndUInt64sUsingBlock:^(BOOL aKey, uint64_t aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue) |
|
if (idx == 0) *stop = YES; |
|
XCTAssertNotEqual(idx, 2U); |
|
++idx; |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testEquality { |
|
const BOOL kKeys1[] = { YES, NO }; |
|
const BOOL kKeys2[] = { NO, YES }; |
|
const uint64_t kValues1[] = { 300U, 301U }; |
|
const uint64_t kValues2[] = { 301U, 300U }; |
|
const uint64_t kValues3[] = { 301U }; |
|
GPBBoolUInt64Dictionary *dict1 = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1); |
|
GPBBoolUInt64Dictionary *dict1prime = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1prime); |
|
GPBBoolUInt64Dictionary *dict2 = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues2 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
GPBBoolUInt64Dictionary *dict3 = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues1 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict3); |
|
GPBBoolUInt64Dictionary *dict4 = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues3 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues3)]; |
|
XCTAssertNotNil(dict4); |
|
|
|
// 1/1Prime should be different objects, but equal. |
|
XCTAssertNotEqual(dict1, dict1prime); |
|
XCTAssertEqualObjects(dict1, dict1prime); |
|
// Equal, so they must have same hash. |
|
XCTAssertEqual([dict1 hash], [dict1prime hash]); |
|
|
|
// 2 is same keys, different values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict2); |
|
|
|
// 3 is different keys, same values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict3); |
|
|
|
// 4 Fewer pairs; not equal |
|
XCTAssertNotEqualObjects(dict1, dict4); |
|
|
|
[dict1 release]; |
|
[dict1prime release]; |
|
[dict2 release]; |
|
[dict3 release]; |
|
[dict4 release]; |
|
} |
|
|
|
- (void)testCopy { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const uint64_t kValues[] = { 300U, 301U }; |
|
GPBBoolUInt64Dictionary *dict = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolUInt64Dictionary *dict2 = [dict copy]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new object but equal. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
XCTAssertTrue([dict2 isKindOfClass:[GPBBoolUInt64Dictionary class]]); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testDictionaryFromDictionary { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const uint64_t kValues[] = { 300U, 301U }; |
|
GPBBoolUInt64Dictionary *dict = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolUInt64Dictionary *dict2 = |
|
[[GPBBoolUInt64Dictionary alloc] initWithDictionary:dict]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new pointer, but equal objects. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testAdds { |
|
GPBBoolUInt64Dictionary *dict = [[GPBBoolUInt64Dictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
|
|
XCTAssertEqual(dict.count, 0U); |
|
[dict setUInt64:300U forKey:YES]; |
|
XCTAssertEqual(dict.count, 1U); |
|
|
|
const BOOL kKeys[] = { NO }; |
|
const uint64_t kValues[] = { 301U }; |
|
GPBBoolUInt64Dictionary *dict2 = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
uint64_t value; |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 300U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 301U); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testRemove { |
|
const BOOL kKeys[] = { YES, NO}; |
|
const uint64_t kValues[] = { 300U, 301U }; |
|
GPBBoolUInt64Dictionary *dict = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
[dict removeUInt64ForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
uint64_t value; |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 300U); |
|
XCTAssertFalse([dict getUInt64:NULL forKey:NO]); |
|
|
|
// Remove again does nothing. |
|
[dict removeUInt64ForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 300U); |
|
XCTAssertFalse([dict getUInt64:NULL forKey:NO]); |
|
|
|
[dict removeAll]; |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertFalse([dict getUInt64:NULL forKey:NO]); |
|
[dict release]; |
|
} |
|
|
|
- (void)testInplaceMutation { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const uint64_t kValues[] = { 300U, 301U }; |
|
GPBBoolUInt64Dictionary *dict = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
uint64_t value; |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 300U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 301U); |
|
|
|
[dict setUInt64:301U forKey:YES]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 301U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 301U); |
|
|
|
[dict setUInt64:300U forKey:NO]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 301U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 300U); |
|
|
|
const BOOL kKeys2[] = { NO, YES }; |
|
const uint64_t kValues2[] = { 301U, 300U }; |
|
GPBBoolUInt64Dictionary *dict2 = |
|
[[GPBBoolUInt64Dictionary alloc] initWithUInt64s:kValues2 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 300U); |
|
XCTAssertTrue([dict getUInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getUInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 301U); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
@end |
|
|
|
// clang-format on |
|
//%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Int64, int64_t, 400, 401) |
|
// This block of code is generated, do not edit it directly. |
|
// clang-format off |
|
|
|
#pragma mark - Bool -> Int64 |
|
|
|
@interface GPBBoolInt64DictionaryTests : XCTestCase |
|
@end |
|
|
|
@implementation GPBBoolInt64DictionaryTests |
|
|
|
- (void)testEmpty { |
|
GPBBoolInt64Dictionary *dict = [[GPBBoolInt64Dictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getInt64:NULL forKey:YES]); |
|
[dict enumerateKeysAndInt64sUsingBlock:^(BOOL aKey, int64_t aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue, stop) |
|
XCTFail(@"Shouldn't get here!"); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testOne { |
|
GPBBoolInt64Dictionary *dict = [[GPBBoolInt64Dictionary alloc] init]; |
|
[dict setInt64:400 forKey:YES]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 1U); |
|
int64_t value; |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 400); |
|
XCTAssertFalse([dict getInt64:NULL forKey:NO]); |
|
[dict enumerateKeysAndInt64sUsingBlock:^(BOOL aKey, int64_t aValue, BOOL *stop) { |
|
XCTAssertEqual(aKey, YES); |
|
XCTAssertEqual(aValue, 400); |
|
XCTAssertNotEqual(stop, NULL); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testBasics { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const int64_t kValues[] = { 400, 401 }; |
|
GPBBoolInt64Dictionary *dict = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
int64_t value; |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 400); |
|
XCTAssertTrue([dict getInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 401); |
|
|
|
__block NSUInteger idx = 0; |
|
BOOL *seenKeys = malloc(2 * sizeof(BOOL)); |
|
int64_t *seenValues = malloc(2 * sizeof(int64_t)); |
|
[dict enumerateKeysAndInt64sUsingBlock:^(BOOL aKey, int64_t aValue, BOOL *stop) { |
|
XCTAssertLessThan(idx, 2U); |
|
seenKeys[idx] = aKey; |
|
seenValues[idx] = aValue; |
|
XCTAssertNotEqual(stop, NULL); |
|
++idx; |
|
}]; |
|
for (int i = 0; i < 2; ++i) { |
|
BOOL foundKey = NO; |
|
for (int j = 0; (j < 2) && !foundKey; ++j) { |
|
if (kKeys[i] == seenKeys[j]) { |
|
foundKey = YES; |
|
XCTAssertEqual(kValues[i], seenValues[j], @"i = %d, j = %d", i, j); |
|
} |
|
} |
|
XCTAssertTrue(foundKey, @"i = %d", i); |
|
} |
|
free(seenKeys); |
|
free(seenValues); |
|
|
|
// Stopping the enumeration. |
|
idx = 0; |
|
[dict enumerateKeysAndInt64sUsingBlock:^(BOOL aKey, int64_t aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue) |
|
if (idx == 0) *stop = YES; |
|
XCTAssertNotEqual(idx, 2U); |
|
++idx; |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testEquality { |
|
const BOOL kKeys1[] = { YES, NO }; |
|
const BOOL kKeys2[] = { NO, YES }; |
|
const int64_t kValues1[] = { 400, 401 }; |
|
const int64_t kValues2[] = { 401, 400 }; |
|
const int64_t kValues3[] = { 401 }; |
|
GPBBoolInt64Dictionary *dict1 = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1); |
|
GPBBoolInt64Dictionary *dict1prime = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1prime); |
|
GPBBoolInt64Dictionary *dict2 = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues2 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
GPBBoolInt64Dictionary *dict3 = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues1 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict3); |
|
GPBBoolInt64Dictionary *dict4 = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues3 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues3)]; |
|
XCTAssertNotNil(dict4); |
|
|
|
// 1/1Prime should be different objects, but equal. |
|
XCTAssertNotEqual(dict1, dict1prime); |
|
XCTAssertEqualObjects(dict1, dict1prime); |
|
// Equal, so they must have same hash. |
|
XCTAssertEqual([dict1 hash], [dict1prime hash]); |
|
|
|
// 2 is same keys, different values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict2); |
|
|
|
// 3 is different keys, same values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict3); |
|
|
|
// 4 Fewer pairs; not equal |
|
XCTAssertNotEqualObjects(dict1, dict4); |
|
|
|
[dict1 release]; |
|
[dict1prime release]; |
|
[dict2 release]; |
|
[dict3 release]; |
|
[dict4 release]; |
|
} |
|
|
|
- (void)testCopy { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const int64_t kValues[] = { 400, 401 }; |
|
GPBBoolInt64Dictionary *dict = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolInt64Dictionary *dict2 = [dict copy]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new object but equal. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
XCTAssertTrue([dict2 isKindOfClass:[GPBBoolInt64Dictionary class]]); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testDictionaryFromDictionary { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const int64_t kValues[] = { 400, 401 }; |
|
GPBBoolInt64Dictionary *dict = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolInt64Dictionary *dict2 = |
|
[[GPBBoolInt64Dictionary alloc] initWithDictionary:dict]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new pointer, but equal objects. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testAdds { |
|
GPBBoolInt64Dictionary *dict = [[GPBBoolInt64Dictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
|
|
XCTAssertEqual(dict.count, 0U); |
|
[dict setInt64:400 forKey:YES]; |
|
XCTAssertEqual(dict.count, 1U); |
|
|
|
const BOOL kKeys[] = { NO }; |
|
const int64_t kValues[] = { 401 }; |
|
GPBBoolInt64Dictionary *dict2 = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
int64_t value; |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 400); |
|
XCTAssertTrue([dict getInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 401); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testRemove { |
|
const BOOL kKeys[] = { YES, NO}; |
|
const int64_t kValues[] = { 400, 401 }; |
|
GPBBoolInt64Dictionary *dict = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
[dict removeInt64ForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
int64_t value; |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 400); |
|
XCTAssertFalse([dict getInt64:NULL forKey:NO]); |
|
|
|
// Remove again does nothing. |
|
[dict removeInt64ForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 400); |
|
XCTAssertFalse([dict getInt64:NULL forKey:NO]); |
|
|
|
[dict removeAll]; |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getInt64:NULL forKey:YES]); |
|
XCTAssertFalse([dict getInt64:NULL forKey:NO]); |
|
[dict release]; |
|
} |
|
|
|
- (void)testInplaceMutation { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const int64_t kValues[] = { 400, 401 }; |
|
GPBBoolInt64Dictionary *dict = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
int64_t value; |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 400); |
|
XCTAssertTrue([dict getInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 401); |
|
|
|
[dict setInt64:401 forKey:YES]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 401); |
|
XCTAssertTrue([dict getInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 401); |
|
|
|
[dict setInt64:400 forKey:NO]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 401); |
|
XCTAssertTrue([dict getInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 400); |
|
|
|
const BOOL kKeys2[] = { NO, YES }; |
|
const int64_t kValues2[] = { 401, 400 }; |
|
GPBBoolInt64Dictionary *dict2 = |
|
[[GPBBoolInt64Dictionary alloc] initWithInt64s:kValues2 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getInt64:NULL forKey:YES]); |
|
XCTAssertTrue([dict getInt64:&value forKey:YES]); |
|
XCTAssertEqual(value, 400); |
|
XCTAssertTrue([dict getInt64:NULL forKey:NO]); |
|
XCTAssertTrue([dict getInt64:&value forKey:NO]); |
|
XCTAssertEqual(value, 401); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
@end |
|
|
|
// clang-format on |
|
//%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Bool, BOOL, NO, YES) |
|
// This block of code is generated, do not edit it directly. |
|
// clang-format off |
|
|
|
#pragma mark - Bool -> Bool |
|
|
|
@interface GPBBoolBoolDictionaryTests : XCTestCase |
|
@end |
|
|
|
@implementation GPBBoolBoolDictionaryTests |
|
|
|
- (void)testEmpty { |
|
GPBBoolBoolDictionary *dict = [[GPBBoolBoolDictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getBool:NULL forKey:YES]); |
|
[dict enumerateKeysAndBoolsUsingBlock:^(BOOL aKey, BOOL aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue, stop) |
|
XCTFail(@"Shouldn't get here!"); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testOne { |
|
GPBBoolBoolDictionary *dict = [[GPBBoolBoolDictionary alloc] init]; |
|
[dict setBool:NO forKey:YES]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 1U); |
|
BOOL value; |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, NO); |
|
XCTAssertFalse([dict getBool:NULL forKey:NO]); |
|
[dict enumerateKeysAndBoolsUsingBlock:^(BOOL aKey, BOOL aValue, BOOL *stop) { |
|
XCTAssertEqual(aKey, YES); |
|
XCTAssertEqual(aValue, NO); |
|
XCTAssertNotEqual(stop, NULL); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testBasics { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const BOOL kValues[] = { NO, YES }; |
|
GPBBoolBoolDictionary *dict = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
BOOL value; |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, NO); |
|
XCTAssertTrue([dict getBool:NULL forKey:NO]); |
|
XCTAssertTrue([dict getBool:&value forKey:NO]); |
|
XCTAssertEqual(value, YES); |
|
|
|
__block NSUInteger idx = 0; |
|
BOOL *seenKeys = malloc(2 * sizeof(BOOL)); |
|
BOOL *seenValues = malloc(2 * sizeof(BOOL)); |
|
[dict enumerateKeysAndBoolsUsingBlock:^(BOOL aKey, BOOL aValue, BOOL *stop) { |
|
XCTAssertLessThan(idx, 2U); |
|
seenKeys[idx] = aKey; |
|
seenValues[idx] = aValue; |
|
XCTAssertNotEqual(stop, NULL); |
|
++idx; |
|
}]; |
|
for (int i = 0; i < 2; ++i) { |
|
BOOL foundKey = NO; |
|
for (int j = 0; (j < 2) && !foundKey; ++j) { |
|
if (kKeys[i] == seenKeys[j]) { |
|
foundKey = YES; |
|
XCTAssertEqual(kValues[i], seenValues[j], @"i = %d, j = %d", i, j); |
|
} |
|
} |
|
XCTAssertTrue(foundKey, @"i = %d", i); |
|
} |
|
free(seenKeys); |
|
free(seenValues); |
|
|
|
// Stopping the enumeration. |
|
idx = 0; |
|
[dict enumerateKeysAndBoolsUsingBlock:^(BOOL aKey, BOOL aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue) |
|
if (idx == 0) *stop = YES; |
|
XCTAssertNotEqual(idx, 2U); |
|
++idx; |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testEquality { |
|
const BOOL kKeys1[] = { YES, NO }; |
|
const BOOL kKeys2[] = { NO, YES }; |
|
const BOOL kValues1[] = { NO, YES }; |
|
const BOOL kValues2[] = { YES, NO }; |
|
const BOOL kValues3[] = { YES }; |
|
GPBBoolBoolDictionary *dict1 = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1); |
|
GPBBoolBoolDictionary *dict1prime = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1prime); |
|
GPBBoolBoolDictionary *dict2 = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues2 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
GPBBoolBoolDictionary *dict3 = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues1 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict3); |
|
GPBBoolBoolDictionary *dict4 = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues3 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues3)]; |
|
XCTAssertNotNil(dict4); |
|
|
|
// 1/1Prime should be different objects, but equal. |
|
XCTAssertNotEqual(dict1, dict1prime); |
|
XCTAssertEqualObjects(dict1, dict1prime); |
|
// Equal, so they must have same hash. |
|
XCTAssertEqual([dict1 hash], [dict1prime hash]); |
|
|
|
// 2 is same keys, different values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict2); |
|
|
|
// 3 is different keys, same values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict3); |
|
|
|
// 4 Fewer pairs; not equal |
|
XCTAssertNotEqualObjects(dict1, dict4); |
|
|
|
[dict1 release]; |
|
[dict1prime release]; |
|
[dict2 release]; |
|
[dict3 release]; |
|
[dict4 release]; |
|
} |
|
|
|
- (void)testCopy { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const BOOL kValues[] = { NO, YES }; |
|
GPBBoolBoolDictionary *dict = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolBoolDictionary *dict2 = [dict copy]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new object but equal. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
XCTAssertTrue([dict2 isKindOfClass:[GPBBoolBoolDictionary class]]); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testDictionaryFromDictionary { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const BOOL kValues[] = { NO, YES }; |
|
GPBBoolBoolDictionary *dict = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolBoolDictionary *dict2 = |
|
[[GPBBoolBoolDictionary alloc] initWithDictionary:dict]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new pointer, but equal objects. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testAdds { |
|
GPBBoolBoolDictionary *dict = [[GPBBoolBoolDictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
|
|
XCTAssertEqual(dict.count, 0U); |
|
[dict setBool:NO forKey:YES]; |
|
XCTAssertEqual(dict.count, 1U); |
|
|
|
const BOOL kKeys[] = { NO }; |
|
const BOOL kValues[] = { YES }; |
|
GPBBoolBoolDictionary *dict2 = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
BOOL value; |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, NO); |
|
XCTAssertTrue([dict getBool:NULL forKey:NO]); |
|
XCTAssertTrue([dict getBool:&value forKey:NO]); |
|
XCTAssertEqual(value, YES); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testRemove { |
|
const BOOL kKeys[] = { YES, NO}; |
|
const BOOL kValues[] = { NO, YES }; |
|
GPBBoolBoolDictionary *dict = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
[dict removeBoolForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
BOOL value; |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, NO); |
|
XCTAssertFalse([dict getBool:NULL forKey:NO]); |
|
|
|
// Remove again does nothing. |
|
[dict removeBoolForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, NO); |
|
XCTAssertFalse([dict getBool:NULL forKey:NO]); |
|
|
|
[dict removeAll]; |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getBool:NULL forKey:YES]); |
|
XCTAssertFalse([dict getBool:NULL forKey:NO]); |
|
[dict release]; |
|
} |
|
|
|
- (void)testInplaceMutation { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const BOOL kValues[] = { NO, YES }; |
|
GPBBoolBoolDictionary *dict = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
BOOL value; |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, NO); |
|
XCTAssertTrue([dict getBool:NULL forKey:NO]); |
|
XCTAssertTrue([dict getBool:&value forKey:NO]); |
|
XCTAssertEqual(value, YES); |
|
|
|
[dict setBool:YES forKey:YES]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, YES); |
|
XCTAssertTrue([dict getBool:NULL forKey:NO]); |
|
XCTAssertTrue([dict getBool:&value forKey:NO]); |
|
XCTAssertEqual(value, YES); |
|
|
|
[dict setBool:NO forKey:NO]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, YES); |
|
XCTAssertTrue([dict getBool:NULL forKey:NO]); |
|
XCTAssertTrue([dict getBool:&value forKey:NO]); |
|
XCTAssertEqual(value, NO); |
|
|
|
const BOOL kKeys2[] = { NO, YES }; |
|
const BOOL kValues2[] = { YES, NO }; |
|
GPBBoolBoolDictionary *dict2 = |
|
[[GPBBoolBoolDictionary alloc] initWithBools:kValues2 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getBool:NULL forKey:YES]); |
|
XCTAssertTrue([dict getBool:&value forKey:YES]); |
|
XCTAssertEqual(value, NO); |
|
XCTAssertTrue([dict getBool:NULL forKey:NO]); |
|
XCTAssertTrue([dict getBool:&value forKey:NO]); |
|
XCTAssertEqual(value, YES); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
@end |
|
|
|
// clang-format on |
|
//%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Float, float, 500.f, 501.f) |
|
// This block of code is generated, do not edit it directly. |
|
// clang-format off |
|
|
|
#pragma mark - Bool -> Float |
|
|
|
@interface GPBBoolFloatDictionaryTests : XCTestCase |
|
@end |
|
|
|
@implementation GPBBoolFloatDictionaryTests |
|
|
|
- (void)testEmpty { |
|
GPBBoolFloatDictionary *dict = [[GPBBoolFloatDictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getFloat:NULL forKey:YES]); |
|
[dict enumerateKeysAndFloatsUsingBlock:^(BOOL aKey, float aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue, stop) |
|
XCTFail(@"Shouldn't get here!"); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testOne { |
|
GPBBoolFloatDictionary *dict = [[GPBBoolFloatDictionary alloc] init]; |
|
[dict setFloat:500.f forKey:YES]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 1U); |
|
float value; |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 500.f); |
|
XCTAssertFalse([dict getFloat:NULL forKey:NO]); |
|
[dict enumerateKeysAndFloatsUsingBlock:^(BOOL aKey, float aValue, BOOL *stop) { |
|
XCTAssertEqual(aKey, YES); |
|
XCTAssertEqual(aValue, 500.f); |
|
XCTAssertNotEqual(stop, NULL); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testBasics { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const float kValues[] = { 500.f, 501.f }; |
|
GPBBoolFloatDictionary *dict = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
float value; |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 500.f); |
|
XCTAssertTrue([dict getFloat:NULL forKey:NO]); |
|
XCTAssertTrue([dict getFloat:&value forKey:NO]); |
|
XCTAssertEqual(value, 501.f); |
|
|
|
__block NSUInteger idx = 0; |
|
BOOL *seenKeys = malloc(2 * sizeof(BOOL)); |
|
float *seenValues = malloc(2 * sizeof(float)); |
|
[dict enumerateKeysAndFloatsUsingBlock:^(BOOL aKey, float aValue, BOOL *stop) { |
|
XCTAssertLessThan(idx, 2U); |
|
seenKeys[idx] = aKey; |
|
seenValues[idx] = aValue; |
|
XCTAssertNotEqual(stop, NULL); |
|
++idx; |
|
}]; |
|
for (int i = 0; i < 2; ++i) { |
|
BOOL foundKey = NO; |
|
for (int j = 0; (j < 2) && !foundKey; ++j) { |
|
if (kKeys[i] == seenKeys[j]) { |
|
foundKey = YES; |
|
XCTAssertEqual(kValues[i], seenValues[j], @"i = %d, j = %d", i, j); |
|
} |
|
} |
|
XCTAssertTrue(foundKey, @"i = %d", i); |
|
} |
|
free(seenKeys); |
|
free(seenValues); |
|
|
|
// Stopping the enumeration. |
|
idx = 0; |
|
[dict enumerateKeysAndFloatsUsingBlock:^(BOOL aKey, float aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue) |
|
if (idx == 0) *stop = YES; |
|
XCTAssertNotEqual(idx, 2U); |
|
++idx; |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testEquality { |
|
const BOOL kKeys1[] = { YES, NO }; |
|
const BOOL kKeys2[] = { NO, YES }; |
|
const float kValues1[] = { 500.f, 501.f }; |
|
const float kValues2[] = { 501.f, 500.f }; |
|
const float kValues3[] = { 501.f }; |
|
GPBBoolFloatDictionary *dict1 = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1); |
|
GPBBoolFloatDictionary *dict1prime = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1prime); |
|
GPBBoolFloatDictionary *dict2 = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues2 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
GPBBoolFloatDictionary *dict3 = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues1 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict3); |
|
GPBBoolFloatDictionary *dict4 = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues3 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues3)]; |
|
XCTAssertNotNil(dict4); |
|
|
|
// 1/1Prime should be different objects, but equal. |
|
XCTAssertNotEqual(dict1, dict1prime); |
|
XCTAssertEqualObjects(dict1, dict1prime); |
|
// Equal, so they must have same hash. |
|
XCTAssertEqual([dict1 hash], [dict1prime hash]); |
|
|
|
// 2 is same keys, different values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict2); |
|
|
|
// 3 is different keys, same values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict3); |
|
|
|
// 4 Fewer pairs; not equal |
|
XCTAssertNotEqualObjects(dict1, dict4); |
|
|
|
[dict1 release]; |
|
[dict1prime release]; |
|
[dict2 release]; |
|
[dict3 release]; |
|
[dict4 release]; |
|
} |
|
|
|
- (void)testCopy { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const float kValues[] = { 500.f, 501.f }; |
|
GPBBoolFloatDictionary *dict = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolFloatDictionary *dict2 = [dict copy]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new object but equal. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
XCTAssertTrue([dict2 isKindOfClass:[GPBBoolFloatDictionary class]]); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testDictionaryFromDictionary { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const float kValues[] = { 500.f, 501.f }; |
|
GPBBoolFloatDictionary *dict = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolFloatDictionary *dict2 = |
|
[[GPBBoolFloatDictionary alloc] initWithDictionary:dict]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new pointer, but equal objects. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testAdds { |
|
GPBBoolFloatDictionary *dict = [[GPBBoolFloatDictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
|
|
XCTAssertEqual(dict.count, 0U); |
|
[dict setFloat:500.f forKey:YES]; |
|
XCTAssertEqual(dict.count, 1U); |
|
|
|
const BOOL kKeys[] = { NO }; |
|
const float kValues[] = { 501.f }; |
|
GPBBoolFloatDictionary *dict2 = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
float value; |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 500.f); |
|
XCTAssertTrue([dict getFloat:NULL forKey:NO]); |
|
XCTAssertTrue([dict getFloat:&value forKey:NO]); |
|
XCTAssertEqual(value, 501.f); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testRemove { |
|
const BOOL kKeys[] = { YES, NO}; |
|
const float kValues[] = { 500.f, 501.f }; |
|
GPBBoolFloatDictionary *dict = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
[dict removeFloatForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
float value; |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 500.f); |
|
XCTAssertFalse([dict getFloat:NULL forKey:NO]); |
|
|
|
// Remove again does nothing. |
|
[dict removeFloatForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 500.f); |
|
XCTAssertFalse([dict getFloat:NULL forKey:NO]); |
|
|
|
[dict removeAll]; |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getFloat:NULL forKey:YES]); |
|
XCTAssertFalse([dict getFloat:NULL forKey:NO]); |
|
[dict release]; |
|
} |
|
|
|
- (void)testInplaceMutation { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const float kValues[] = { 500.f, 501.f }; |
|
GPBBoolFloatDictionary *dict = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
float value; |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 500.f); |
|
XCTAssertTrue([dict getFloat:NULL forKey:NO]); |
|
XCTAssertTrue([dict getFloat:&value forKey:NO]); |
|
XCTAssertEqual(value, 501.f); |
|
|
|
[dict setFloat:501.f forKey:YES]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 501.f); |
|
XCTAssertTrue([dict getFloat:NULL forKey:NO]); |
|
XCTAssertTrue([dict getFloat:&value forKey:NO]); |
|
XCTAssertEqual(value, 501.f); |
|
|
|
[dict setFloat:500.f forKey:NO]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 501.f); |
|
XCTAssertTrue([dict getFloat:NULL forKey:NO]); |
|
XCTAssertTrue([dict getFloat:&value forKey:NO]); |
|
XCTAssertEqual(value, 500.f); |
|
|
|
const BOOL kKeys2[] = { NO, YES }; |
|
const float kValues2[] = { 501.f, 500.f }; |
|
GPBBoolFloatDictionary *dict2 = |
|
[[GPBBoolFloatDictionary alloc] initWithFloats:kValues2 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getFloat:NULL forKey:YES]); |
|
XCTAssertTrue([dict getFloat:&value forKey:YES]); |
|
XCTAssertEqual(value, 500.f); |
|
XCTAssertTrue([dict getFloat:NULL forKey:NO]); |
|
XCTAssertTrue([dict getFloat:&value forKey:NO]); |
|
XCTAssertEqual(value, 501.f); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
@end |
|
|
|
// clang-format on |
|
//%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Double, double, 600., 601.) |
|
// This block of code is generated, do not edit it directly. |
|
// clang-format off |
|
|
|
#pragma mark - Bool -> Double |
|
|
|
@interface GPBBoolDoubleDictionaryTests : XCTestCase |
|
@end |
|
|
|
@implementation GPBBoolDoubleDictionaryTests |
|
|
|
- (void)testEmpty { |
|
GPBBoolDoubleDictionary *dict = [[GPBBoolDoubleDictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getDouble:NULL forKey:YES]); |
|
[dict enumerateKeysAndDoublesUsingBlock:^(BOOL aKey, double aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue, stop) |
|
XCTFail(@"Shouldn't get here!"); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testOne { |
|
GPBBoolDoubleDictionary *dict = [[GPBBoolDoubleDictionary alloc] init]; |
|
[dict setDouble:600. forKey:YES]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 1U); |
|
double value; |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 600.); |
|
XCTAssertFalse([dict getDouble:NULL forKey:NO]); |
|
[dict enumerateKeysAndDoublesUsingBlock:^(BOOL aKey, double aValue, BOOL *stop) { |
|
XCTAssertEqual(aKey, YES); |
|
XCTAssertEqual(aValue, 600.); |
|
XCTAssertNotEqual(stop, NULL); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testBasics { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const double kValues[] = { 600., 601. }; |
|
GPBBoolDoubleDictionary *dict = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
double value; |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 600.); |
|
XCTAssertTrue([dict getDouble:NULL forKey:NO]); |
|
XCTAssertTrue([dict getDouble:&value forKey:NO]); |
|
XCTAssertEqual(value, 601.); |
|
|
|
__block NSUInteger idx = 0; |
|
BOOL *seenKeys = malloc(2 * sizeof(BOOL)); |
|
double *seenValues = malloc(2 * sizeof(double)); |
|
[dict enumerateKeysAndDoublesUsingBlock:^(BOOL aKey, double aValue, BOOL *stop) { |
|
XCTAssertLessThan(idx, 2U); |
|
seenKeys[idx] = aKey; |
|
seenValues[idx] = aValue; |
|
XCTAssertNotEqual(stop, NULL); |
|
++idx; |
|
}]; |
|
for (int i = 0; i < 2; ++i) { |
|
BOOL foundKey = NO; |
|
for (int j = 0; (j < 2) && !foundKey; ++j) { |
|
if (kKeys[i] == seenKeys[j]) { |
|
foundKey = YES; |
|
XCTAssertEqual(kValues[i], seenValues[j], @"i = %d, j = %d", i, j); |
|
} |
|
} |
|
XCTAssertTrue(foundKey, @"i = %d", i); |
|
} |
|
free(seenKeys); |
|
free(seenValues); |
|
|
|
// Stopping the enumeration. |
|
idx = 0; |
|
[dict enumerateKeysAndDoublesUsingBlock:^(BOOL aKey, double aValue, BOOL *stop) { |
|
#pragma unused(aKey, aValue) |
|
if (idx == 0) *stop = YES; |
|
XCTAssertNotEqual(idx, 2U); |
|
++idx; |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testEquality { |
|
const BOOL kKeys1[] = { YES, NO }; |
|
const BOOL kKeys2[] = { NO, YES }; |
|
const double kValues1[] = { 600., 601. }; |
|
const double kValues2[] = { 601., 600. }; |
|
const double kValues3[] = { 601. }; |
|
GPBBoolDoubleDictionary *dict1 = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1); |
|
GPBBoolDoubleDictionary *dict1prime = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict1prime); |
|
GPBBoolDoubleDictionary *dict2 = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues2 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
GPBBoolDoubleDictionary *dict3 = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues1 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues1)]; |
|
XCTAssertNotNil(dict3); |
|
GPBBoolDoubleDictionary *dict4 = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues3 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kValues3)]; |
|
XCTAssertNotNil(dict4); |
|
|
|
// 1/1Prime should be different objects, but equal. |
|
XCTAssertNotEqual(dict1, dict1prime); |
|
XCTAssertEqualObjects(dict1, dict1prime); |
|
// Equal, so they must have same hash. |
|
XCTAssertEqual([dict1 hash], [dict1prime hash]); |
|
|
|
// 2 is same keys, different values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict2); |
|
|
|
// 3 is different keys, same values; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict3); |
|
|
|
// 4 Fewer pairs; not equal |
|
XCTAssertNotEqualObjects(dict1, dict4); |
|
|
|
[dict1 release]; |
|
[dict1prime release]; |
|
[dict2 release]; |
|
[dict3 release]; |
|
[dict4 release]; |
|
} |
|
|
|
- (void)testCopy { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const double kValues[] = { 600., 601. }; |
|
GPBBoolDoubleDictionary *dict = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolDoubleDictionary *dict2 = [dict copy]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new object but equal. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
XCTAssertTrue([dict2 isKindOfClass:[GPBBoolDoubleDictionary class]]); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testDictionaryFromDictionary { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const double kValues[] = { 600., 601. }; |
|
GPBBoolDoubleDictionary *dict = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolDoubleDictionary *dict2 = |
|
[[GPBBoolDoubleDictionary alloc] initWithDictionary:dict]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new pointer, but equal objects. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testAdds { |
|
GPBBoolDoubleDictionary *dict = [[GPBBoolDoubleDictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
|
|
XCTAssertEqual(dict.count, 0U); |
|
[dict setDouble:600. forKey:YES]; |
|
XCTAssertEqual(dict.count, 1U); |
|
|
|
const BOOL kKeys[] = { NO }; |
|
const double kValues[] = { 601. }; |
|
GPBBoolDoubleDictionary *dict2 = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
double value; |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 600.); |
|
XCTAssertTrue([dict getDouble:NULL forKey:NO]); |
|
XCTAssertTrue([dict getDouble:&value forKey:NO]); |
|
XCTAssertEqual(value, 601.); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testRemove { |
|
const BOOL kKeys[] = { YES, NO}; |
|
const double kValues[] = { 600., 601. }; |
|
GPBBoolDoubleDictionary *dict = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
[dict removeDoubleForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
double value; |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 600.); |
|
XCTAssertFalse([dict getDouble:NULL forKey:NO]); |
|
|
|
// Remove again does nothing. |
|
[dict removeDoubleForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 600.); |
|
XCTAssertFalse([dict getDouble:NULL forKey:NO]); |
|
|
|
[dict removeAll]; |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertFalse([dict getDouble:NULL forKey:YES]); |
|
XCTAssertFalse([dict getDouble:NULL forKey:NO]); |
|
[dict release]; |
|
} |
|
|
|
- (void)testInplaceMutation { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const double kValues[] = { 600., 601. }; |
|
GPBBoolDoubleDictionary *dict = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kValues)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
double value; |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 600.); |
|
XCTAssertTrue([dict getDouble:NULL forKey:NO]); |
|
XCTAssertTrue([dict getDouble:&value forKey:NO]); |
|
XCTAssertEqual(value, 601.); |
|
|
|
[dict setDouble:601. forKey:YES]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 601.); |
|
XCTAssertTrue([dict getDouble:NULL forKey:NO]); |
|
XCTAssertTrue([dict getDouble:&value forKey:NO]); |
|
XCTAssertEqual(value, 601.); |
|
|
|
[dict setDouble:600. forKey:NO]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 601.); |
|
XCTAssertTrue([dict getDouble:NULL forKey:NO]); |
|
XCTAssertTrue([dict getDouble:&value forKey:NO]); |
|
XCTAssertEqual(value, 600.); |
|
|
|
const BOOL kKeys2[] = { NO, YES }; |
|
const double kValues2[] = { 601., 600. }; |
|
GPBBoolDoubleDictionary *dict2 = |
|
[[GPBBoolDoubleDictionary alloc] initWithDoubles:kValues2 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kValues2)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertTrue([dict getDouble:NULL forKey:YES]); |
|
XCTAssertTrue([dict getDouble:&value forKey:YES]); |
|
XCTAssertEqual(value, 600.); |
|
XCTAssertTrue([dict getDouble:NULL forKey:NO]); |
|
XCTAssertTrue([dict getDouble:&value forKey:NO]); |
|
XCTAssertEqual(value, 601.); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
@end |
|
|
|
// clang-format on |
|
//%PDDM-EXPAND TESTS_FOR_BOOL_KEY_OBJECT_VALUE(Object, NSString*, @"abc", @"def") |
|
// This block of code is generated, do not edit it directly. |
|
// clang-format off |
|
|
|
#pragma mark - Bool -> Object |
|
|
|
@interface GPBBoolObjectDictionaryTests : XCTestCase |
|
@end |
|
|
|
@implementation GPBBoolObjectDictionaryTests |
|
|
|
- (void)testEmpty { |
|
GPBBoolObjectDictionary<NSString*> *dict = [[GPBBoolObjectDictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertNil([dict objectForKey:YES]); |
|
[dict enumerateKeysAndObjectsUsingBlock:^(BOOL aKey, NSString* aObject, BOOL *stop) { |
|
#pragma unused(aKey, aObject, stop) |
|
XCTFail(@"Shouldn't get here!"); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testOne { |
|
GPBBoolObjectDictionary<NSString*> *dict = [[GPBBoolObjectDictionary alloc] init]; |
|
[dict setObject:@"abc" forKey:YES]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertEqualObjects([dict objectForKey:YES], @"abc"); |
|
XCTAssertNil([dict objectForKey:NO]); |
|
[dict enumerateKeysAndObjectsUsingBlock:^(BOOL aKey, NSString* aObject, BOOL *stop) { |
|
XCTAssertEqual(aKey, YES); |
|
XCTAssertEqualObjects(aObject, @"abc"); |
|
XCTAssertNotEqual(stop, NULL); |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testBasics { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const NSString* kObjects[] = { @"abc", @"def" }; |
|
GPBBoolObjectDictionary<NSString*> *dict = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kObjects)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertEqualObjects([dict objectForKey:YES], @"abc"); |
|
XCTAssertEqualObjects([dict objectForKey:NO], @"def"); |
|
|
|
__block NSUInteger idx = 0; |
|
BOOL *seenKeys = malloc(2 * sizeof(BOOL)); |
|
NSString* *seenObjects = malloc(2 * sizeof(NSString*)); |
|
[dict enumerateKeysAndObjectsUsingBlock:^(BOOL aKey, NSString* aObject, BOOL *stop) { |
|
XCTAssertLessThan(idx, 2U); |
|
seenKeys[idx] = aKey; |
|
seenObjects[idx] = aObject; |
|
XCTAssertNotEqual(stop, NULL); |
|
++idx; |
|
}]; |
|
for (int i = 0; i < 2; ++i) { |
|
BOOL foundKey = NO; |
|
for (int j = 0; (j < 2) && !foundKey; ++j) { |
|
if (kKeys[i] == seenKeys[j]) { |
|
foundKey = YES; |
|
XCTAssertEqualObjects(kObjects[i], seenObjects[j], @"i = %d, j = %d", i, j); |
|
} |
|
} |
|
XCTAssertTrue(foundKey, @"i = %d", i); |
|
} |
|
free(seenKeys); |
|
free(seenObjects); |
|
|
|
// Stopping the enumeration. |
|
idx = 0; |
|
[dict enumerateKeysAndObjectsUsingBlock:^(BOOL aKey, NSString* aObject, BOOL *stop) { |
|
#pragma unused(aKey, aObject) |
|
if (idx == 0) *stop = YES; |
|
XCTAssertNotEqual(idx, 2U); |
|
++idx; |
|
}]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testEquality { |
|
const BOOL kKeys1[] = { YES, NO }; |
|
const BOOL kKeys2[] = { NO, YES }; |
|
const NSString* kObjects1[] = { @"abc", @"def" }; |
|
const NSString* kObjects2[] = { @"def", @"abc" }; |
|
const NSString* kObjects3[] = { @"def" }; |
|
GPBBoolObjectDictionary<NSString*> *dict1 = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kObjects1)]; |
|
XCTAssertNotNil(dict1); |
|
GPBBoolObjectDictionary<NSString*> *dict1prime = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects1 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kObjects1)]; |
|
XCTAssertNotNil(dict1prime); |
|
GPBBoolObjectDictionary<NSString*> *dict2 = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects2 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kObjects2)]; |
|
XCTAssertNotNil(dict2); |
|
GPBBoolObjectDictionary<NSString*> *dict3 = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects1 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kObjects1)]; |
|
XCTAssertNotNil(dict3); |
|
GPBBoolObjectDictionary<NSString*> *dict4 = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects3 |
|
forKeys:kKeys1 |
|
count:GPBARRAYSIZE(kObjects3)]; |
|
XCTAssertNotNil(dict4); |
|
|
|
// 1/1Prime should be different objects, but equal. |
|
XCTAssertNotEqual(dict1, dict1prime); |
|
XCTAssertEqualObjects(dict1, dict1prime); |
|
// Equal, so they must have same hash. |
|
XCTAssertEqual([dict1 hash], [dict1prime hash]); |
|
|
|
// 2 is same keys, different objects; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict2); |
|
|
|
// 3 is different keys, same objects; not equal. |
|
XCTAssertNotEqualObjects(dict1, dict3); |
|
|
|
// 4 Fewer pairs; not equal |
|
XCTAssertNotEqualObjects(dict1, dict4); |
|
|
|
[dict1 release]; |
|
[dict1prime release]; |
|
[dict2 release]; |
|
[dict3 release]; |
|
[dict4 release]; |
|
} |
|
|
|
- (void)testCopy { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const NSString* kObjects[] = { @"abc", @"def" }; |
|
GPBBoolObjectDictionary<NSString*> *dict = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kObjects)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolObjectDictionary<NSString*> *dict2 = [dict copy]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new object but equal. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
XCTAssertTrue([dict2 isKindOfClass:[GPBBoolObjectDictionary class]]); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testDictionaryFromDictionary { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const NSString* kObjects[] = { @"abc", @"def" }; |
|
GPBBoolObjectDictionary<NSString*> *dict = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kObjects)]; |
|
XCTAssertNotNil(dict); |
|
|
|
GPBBoolObjectDictionary<NSString*> *dict2 = |
|
[[GPBBoolObjectDictionary alloc] initWithDictionary:dict]; |
|
XCTAssertNotNil(dict2); |
|
|
|
// Should be new pointer, but equal objects. |
|
XCTAssertNotEqual(dict, dict2); |
|
XCTAssertEqualObjects(dict, dict2); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testAdds { |
|
GPBBoolObjectDictionary<NSString*> *dict = [[GPBBoolObjectDictionary alloc] init]; |
|
XCTAssertNotNil(dict); |
|
|
|
XCTAssertEqual(dict.count, 0U); |
|
[dict setObject:@"abc" forKey:YES]; |
|
XCTAssertEqual(dict.count, 1U); |
|
|
|
const BOOL kKeys[] = { NO }; |
|
const NSString* kObjects[] = { @"def" }; |
|
GPBBoolObjectDictionary<NSString*> *dict2 = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kObjects)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
XCTAssertEqualObjects([dict objectForKey:YES], @"abc"); |
|
XCTAssertEqualObjects([dict objectForKey:NO], @"def"); |
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
- (void)testRemove { |
|
const BOOL kKeys[] = { YES, NO}; |
|
const NSString* kObjects[] = { @"abc", @"def" }; |
|
GPBBoolObjectDictionary<NSString*> *dict = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kObjects)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
|
|
[dict removeObjectForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertEqualObjects([dict objectForKey:YES], @"abc"); |
|
XCTAssertNil([dict objectForKey:NO]); |
|
|
|
// Remove again does nothing. |
|
[dict removeObjectForKey:NO]; |
|
XCTAssertEqual(dict.count, 1U); |
|
XCTAssertEqualObjects([dict objectForKey:YES], @"abc"); |
|
XCTAssertNil([dict objectForKey:NO]); |
|
|
|
[dict removeAll]; |
|
XCTAssertEqual(dict.count, 0U); |
|
XCTAssertNil([dict objectForKey:YES]); |
|
XCTAssertNil([dict objectForKey:NO]); |
|
[dict release]; |
|
} |
|
|
|
- (void)testInplaceMutation { |
|
const BOOL kKeys[] = { YES, NO }; |
|
const NSString* kObjects[] = { @"abc", @"def" }; |
|
GPBBoolObjectDictionary<NSString*> *dict = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects |
|
forKeys:kKeys |
|
count:GPBARRAYSIZE(kObjects)]; |
|
XCTAssertNotNil(dict); |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertEqualObjects([dict objectForKey:YES], @"abc"); |
|
XCTAssertEqualObjects([dict objectForKey:NO], @"def"); |
|
|
|
[dict setObject:@"def" forKey:YES]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertEqualObjects([dict objectForKey:YES], @"def"); |
|
XCTAssertEqualObjects([dict objectForKey:NO], @"def"); |
|
|
|
[dict setObject:@"abc" forKey:NO]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertEqualObjects([dict objectForKey:YES], @"def"); |
|
XCTAssertEqualObjects([dict objectForKey:NO], @"abc"); |
|
|
|
const BOOL kKeys2[] = { NO, YES }; |
|
const NSString* kObjects2[] = { @"def", @"abc" }; |
|
GPBBoolObjectDictionary<NSString*> *dict2 = |
|
[[GPBBoolObjectDictionary alloc] initWithObjects:kObjects2 |
|
forKeys:kKeys2 |
|
count:GPBARRAYSIZE(kObjects2)]; |
|
XCTAssertNotNil(dict2); |
|
[dict addEntriesFromDictionary:dict2]; |
|
XCTAssertEqual(dict.count, 2U); |
|
XCTAssertEqualObjects([dict objectForKey:YES], @"abc"); |
|
XCTAssertEqualObjects([dict objectForKey:NO], @"def"); |
|
|
|
[dict2 release]; |
|
[dict release]; |
|
} |
|
|
|
@end |
|
|
|
// clang-format on |
|
//%PDDM-EXPAND-END (8 expansions) |
|
|
|
|
|
|