|
|
|
// 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)
|
|
|
|
|
|
|
|
|