| // Protocol Buffers - Google's data interchange format |
| // Copyright 2015 Google Inc. All rights reserved. |
| // |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file or at |
| // https://developers.google.com/open-source/licenses/bsd |
| |
| #import <Foundation/Foundation.h> |
| #import <XCTest/XCTest.h> |
| |
| #import "GPBDictionary.h" |
| #import "GPBTestUtilities.h" |
| #import "objectivec/Tests/UnittestRuntimeProto2.pbobjc.h" |
| |
| // Disable clang-format for the macros. |
| // clang-format off |
| |
| // 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. |
| |
| #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:^(__unused BOOL aKey, __unused uint32_t aValue, __unused BOOL *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:^(__unused BOOL aKey, __unused uint32_t aValue, BOOL *stop) { |
| 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 |
| |
| //%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Int32, int32_t, 200, 201) |
| // This block of code is generated, do not edit it directly. |
| |
| #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:^(__unused BOOL aKey, __unused int32_t aValue, __unused BOOL *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:^(__unused BOOL aKey, __unused int32_t aValue, BOOL *stop) { |
| 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 |
| |
| //%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(UInt64, uint64_t, 300U, 301U) |
| // This block of code is generated, do not edit it directly. |
| |
| #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:^(__unused BOOL aKey, __unused uint64_t aValue, __unused BOOL *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:^(__unused BOOL aKey, __unused uint64_t aValue, BOOL *stop) { |
| 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 |
| |
| //%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Int64, int64_t, 400, 401) |
| // This block of code is generated, do not edit it directly. |
| |
| #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:^(__unused BOOL aKey, __unused int64_t aValue, __unused BOOL *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:^(__unused BOOL aKey, __unused int64_t aValue, BOOL *stop) { |
| 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 |
| |
| //%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Bool, BOOL, NO, YES) |
| // This block of code is generated, do not edit it directly. |
| |
| #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:^(__unused BOOL aKey, __unused BOOL aValue, __unused BOOL *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:^(__unused BOOL aKey, __unused BOOL aValue, BOOL *stop) { |
| 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 |
| |
| //%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Float, float, 500.f, 501.f) |
| // This block of code is generated, do not edit it directly. |
| |
| #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:^(__unused BOOL aKey, __unused float aValue, __unused BOOL *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:^(__unused BOOL aKey, __unused float aValue, BOOL *stop) { |
| 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 |
| |
| //%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(Double, double, 600., 601.) |
| // This block of code is generated, do not edit it directly. |
| |
| #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:^(__unused BOOL aKey, __unused double aValue, __unused BOOL *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:^(__unused BOOL aKey, __unused double aValue, BOOL *stop) { |
| 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 |
| |
| //%PDDM-EXPAND TESTS_FOR_BOOL_KEY_OBJECT_VALUE(Object, NSString*, @"abc", @"def") |
| // This block of code is generated, do not edit it directly. |
| |
| #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:^(__unused BOOL aKey, __unused NSString* aObject, __unused BOOL *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:^(__unused BOOL aKey, __unused NSString* aObject, BOOL *stop) { |
| 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 |
| |
| //%PDDM-EXPAND-END (8 expansions) |
| |
| |