protobuf/objectivec/Tests/GPBDictionaryTests+Bool.m
Thomas Van Lenten 1dcc329427 Objective C Second Alpha Drop
- Style fixups in the code.
- map<> serialization fixes and more tests.
- Autocreation of map<> fields (to match repeated fields).
- @@protoc_insertion_point(global_scope|imports).
- Fixup proto2 syntax extension support.
- Move all startup code to +initialize so it happen on class usage and not app startup.
- Have generated headers use forward declarations and move imports into generated code, reduces what is need at compile time to speed up compiled and avoid pointless rippling of rebuilds.
2015-05-22 14:27:31 -04:00

2419 lines
82 KiB
Objective-C

// Protocol Buffers - Google's data interchange format
// Copyright 2015 Google Inc. All rights reserved.
// https://developers.google.com/protocol-buffers/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#import <Foundation/Foundation.h>
#import <XCTest/XCTest.h>
#import "GPBDictionary.h"
#import "GPBTestUtilities.h"
#import "google/protobuf/UnittestRuntimeProto2.pbobjc.h"
// Pull in the macros (using an external file because expanding all tests
// in a single file makes a file that is failing to work with within Xcode.
//%PDDM-IMPORT-DEFINES GPBDictionaryTests.pddm
//%PDDM-EXPAND BOOL_TESTS_FOR_POD_VALUE(UInt32, uint32_t, 100U, 101U)
// This block of code is generated, do not edit it directly.
#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 valueForKey:YES value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, uint32_t aValue, BOOL *stop) {
#pragma unused(aKey, aValue, stop)
XCTFail(@"Shouldn't get here!");
}];
[dict release];
}
- (void)testOne {
GPBBoolUInt32Dictionary *dict = [GPBBoolUInt32Dictionary dictionaryWithValue:100U forKey:YES];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 1U);
uint32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 100U);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, uint32_t aValue, BOOL *stop) {
XCTAssertEqual(aKey, YES);
XCTAssertEqual(aValue, 100U);
XCTAssertNotEqual(stop, NULL);
}];
}
- (void)testBasics {
const BOOL kKeys[] = { YES, NO };
const uint32_t kValues[] = { 100U, 101U };
GPBBoolUInt32Dictionary *dict =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
uint32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 100U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 101U);
__block NSUInteger idx = 0;
BOOL *seenKeys = malloc(2 * sizeof(BOOL));
uint32_t *seenValues = malloc(2 * sizeof(uint32_t));
[dict enumerateKeysAndValuesUsingBlock:^(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 enumerateKeysAndValuesUsingBlock:^(BOOL aKey, uint32_t aValue, BOOL *stop) {
#pragma unused(aKey, aValue)
if (idx == 0) *stop = YES;
XCTAssertNotEqual(idx, 2U);
++idx;
}];
[dict release];
}
- (void)testEquality {
const BOOL kKeys1[] = { YES, NO };
const BOOL kKeys2[] = { NO, YES };
const uint32_t kValues1[] = { 100U, 101U };
const uint32_t kValues2[] = { 101U, 100U };
const uint32_t kValues3[] = { 101U };
GPBBoolUInt32Dictionary *dict1 =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1);
GPBBoolUInt32Dictionary *dict1prime =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1prime);
GPBBoolUInt32Dictionary *dict2 =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues2
forKeys:kKeys1
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
GPBBoolUInt32Dictionary *dict3 =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues1
forKeys:kKeys2
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict3);
GPBBoolUInt32Dictionary *dict4 =
[[GPBBoolUInt32Dictionary alloc] initWithValues: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 save keys, different values; not equal.
XCTAssertNotEqualObjects(dict1, dict2);
// 3 is different keys, samae 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] initWithValues: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] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolUInt32Dictionary *dict2 =
[GPBBoolUInt32Dictionary dictionaryWithDictionary:dict];
XCTAssertNotNil(dict2);
// Should be new pointer, but equal objects.
XCTAssertNotEqual(dict, dict2);
XCTAssertEqualObjects(dict, dict2);
[dict release];
}
- (void)testAdds {
GPBBoolUInt32Dictionary *dict = [GPBBoolUInt32Dictionary dictionary];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
[dict setValue:100U forKey:YES];
XCTAssertEqual(dict.count, 1U);
const BOOL kKeys[] = { NO };
const uint32_t kValues[] = { 101U };
GPBBoolUInt32Dictionary *dict2 =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
uint32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 100U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 101U);
[dict2 release];
}
- (void)testRemove {
const BOOL kKeys[] = { YES, NO};
const uint32_t kValues[] = { 100U, 101U };
GPBBoolUInt32Dictionary *dict =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
uint32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 100U);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
// Remove again does nothing.
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 100U);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict removeAll];
XCTAssertEqual(dict.count, 0U);
XCTAssertFalse([dict valueForKey:YES value:NULL]);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict release];
}
- (void)testInplaceMutation {
const BOOL kKeys[] = { YES, NO };
const uint32_t kValues[] = { 100U, 101U };
GPBBoolUInt32Dictionary *dict =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
uint32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 100U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 101U);
[dict setValue:101U forKey:YES];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 101U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 101U);
[dict setValue:100U forKey:NO];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 101U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 100U);
const BOOL kKeys2[] = { NO, YES };
const uint32_t kValues2[] = { 101U, 100U };
GPBBoolUInt32Dictionary *dict2 =
[[GPBBoolUInt32Dictionary alloc] initWithValues:kValues2
forKeys:kKeys2
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 100U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
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 valueForKey:YES value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, int32_t aValue, BOOL *stop) {
#pragma unused(aKey, aValue, stop)
XCTFail(@"Shouldn't get here!");
}];
[dict release];
}
- (void)testOne {
GPBBoolInt32Dictionary *dict = [GPBBoolInt32Dictionary dictionaryWithValue:200 forKey:YES];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 1U);
int32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 200);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, int32_t aValue, BOOL *stop) {
XCTAssertEqual(aKey, YES);
XCTAssertEqual(aValue, 200);
XCTAssertNotEqual(stop, NULL);
}];
}
- (void)testBasics {
const BOOL kKeys[] = { YES, NO };
const int32_t kValues[] = { 200, 201 };
GPBBoolInt32Dictionary *dict =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
int32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 200);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 201);
__block NSUInteger idx = 0;
BOOL *seenKeys = malloc(2 * sizeof(BOOL));
int32_t *seenValues = malloc(2 * sizeof(int32_t));
[dict enumerateKeysAndValuesUsingBlock:^(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 enumerateKeysAndValuesUsingBlock:^(BOOL aKey, int32_t aValue, BOOL *stop) {
#pragma unused(aKey, aValue)
if (idx == 0) *stop = YES;
XCTAssertNotEqual(idx, 2U);
++idx;
}];
[dict release];
}
- (void)testEquality {
const BOOL kKeys1[] = { YES, NO };
const BOOL kKeys2[] = { NO, YES };
const int32_t kValues1[] = { 200, 201 };
const int32_t kValues2[] = { 201, 200 };
const int32_t kValues3[] = { 201 };
GPBBoolInt32Dictionary *dict1 =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1);
GPBBoolInt32Dictionary *dict1prime =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1prime);
GPBBoolInt32Dictionary *dict2 =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues2
forKeys:kKeys1
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
GPBBoolInt32Dictionary *dict3 =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues1
forKeys:kKeys2
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict3);
GPBBoolInt32Dictionary *dict4 =
[[GPBBoolInt32Dictionary alloc] initWithValues: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 save keys, different values; not equal.
XCTAssertNotEqualObjects(dict1, dict2);
// 3 is different keys, samae 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] initWithValues: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] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolInt32Dictionary *dict2 =
[GPBBoolInt32Dictionary dictionaryWithDictionary:dict];
XCTAssertNotNil(dict2);
// Should be new pointer, but equal objects.
XCTAssertNotEqual(dict, dict2);
XCTAssertEqualObjects(dict, dict2);
[dict release];
}
- (void)testAdds {
GPBBoolInt32Dictionary *dict = [GPBBoolInt32Dictionary dictionary];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
[dict setValue:200 forKey:YES];
XCTAssertEqual(dict.count, 1U);
const BOOL kKeys[] = { NO };
const int32_t kValues[] = { 201 };
GPBBoolInt32Dictionary *dict2 =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
int32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 200);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 201);
[dict2 release];
}
- (void)testRemove {
const BOOL kKeys[] = { YES, NO};
const int32_t kValues[] = { 200, 201 };
GPBBoolInt32Dictionary *dict =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
int32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 200);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
// Remove again does nothing.
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 200);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict removeAll];
XCTAssertEqual(dict.count, 0U);
XCTAssertFalse([dict valueForKey:YES value:NULL]);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict release];
}
- (void)testInplaceMutation {
const BOOL kKeys[] = { YES, NO };
const int32_t kValues[] = { 200, 201 };
GPBBoolInt32Dictionary *dict =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
int32_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 200);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 201);
[dict setValue:201 forKey:YES];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 201);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 201);
[dict setValue:200 forKey:NO];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 201);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 200);
const BOOL kKeys2[] = { NO, YES };
const int32_t kValues2[] = { 201, 200 };
GPBBoolInt32Dictionary *dict2 =
[[GPBBoolInt32Dictionary alloc] initWithValues:kValues2
forKeys:kKeys2
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 200);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
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 valueForKey:YES value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, uint64_t aValue, BOOL *stop) {
#pragma unused(aKey, aValue, stop)
XCTFail(@"Shouldn't get here!");
}];
[dict release];
}
- (void)testOne {
GPBBoolUInt64Dictionary *dict = [GPBBoolUInt64Dictionary dictionaryWithValue:300U forKey:YES];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 1U);
uint64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 300U);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, uint64_t aValue, BOOL *stop) {
XCTAssertEqual(aKey, YES);
XCTAssertEqual(aValue, 300U);
XCTAssertNotEqual(stop, NULL);
}];
}
- (void)testBasics {
const BOOL kKeys[] = { YES, NO };
const uint64_t kValues[] = { 300U, 301U };
GPBBoolUInt64Dictionary *dict =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
uint64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 300U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 301U);
__block NSUInteger idx = 0;
BOOL *seenKeys = malloc(2 * sizeof(BOOL));
uint64_t *seenValues = malloc(2 * sizeof(uint64_t));
[dict enumerateKeysAndValuesUsingBlock:^(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 enumerateKeysAndValuesUsingBlock:^(BOOL aKey, uint64_t aValue, BOOL *stop) {
#pragma unused(aKey, aValue)
if (idx == 0) *stop = YES;
XCTAssertNotEqual(idx, 2U);
++idx;
}];
[dict release];
}
- (void)testEquality {
const BOOL kKeys1[] = { YES, NO };
const BOOL kKeys2[] = { NO, YES };
const uint64_t kValues1[] = { 300U, 301U };
const uint64_t kValues2[] = { 301U, 300U };
const uint64_t kValues3[] = { 301U };
GPBBoolUInt64Dictionary *dict1 =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1);
GPBBoolUInt64Dictionary *dict1prime =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1prime);
GPBBoolUInt64Dictionary *dict2 =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues2
forKeys:kKeys1
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
GPBBoolUInt64Dictionary *dict3 =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues1
forKeys:kKeys2
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict3);
GPBBoolUInt64Dictionary *dict4 =
[[GPBBoolUInt64Dictionary alloc] initWithValues: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 save keys, different values; not equal.
XCTAssertNotEqualObjects(dict1, dict2);
// 3 is different keys, samae 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] initWithValues: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] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolUInt64Dictionary *dict2 =
[GPBBoolUInt64Dictionary dictionaryWithDictionary:dict];
XCTAssertNotNil(dict2);
// Should be new pointer, but equal objects.
XCTAssertNotEqual(dict, dict2);
XCTAssertEqualObjects(dict, dict2);
[dict release];
}
- (void)testAdds {
GPBBoolUInt64Dictionary *dict = [GPBBoolUInt64Dictionary dictionary];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
[dict setValue:300U forKey:YES];
XCTAssertEqual(dict.count, 1U);
const BOOL kKeys[] = { NO };
const uint64_t kValues[] = { 301U };
GPBBoolUInt64Dictionary *dict2 =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
uint64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 300U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 301U);
[dict2 release];
}
- (void)testRemove {
const BOOL kKeys[] = { YES, NO};
const uint64_t kValues[] = { 300U, 301U };
GPBBoolUInt64Dictionary *dict =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
uint64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 300U);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
// Remove again does nothing.
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 300U);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict removeAll];
XCTAssertEqual(dict.count, 0U);
XCTAssertFalse([dict valueForKey:YES value:NULL]);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict release];
}
- (void)testInplaceMutation {
const BOOL kKeys[] = { YES, NO };
const uint64_t kValues[] = { 300U, 301U };
GPBBoolUInt64Dictionary *dict =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
uint64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 300U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 301U);
[dict setValue:301U forKey:YES];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 301U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 301U);
[dict setValue:300U forKey:NO];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 301U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 300U);
const BOOL kKeys2[] = { NO, YES };
const uint64_t kValues2[] = { 301U, 300U };
GPBBoolUInt64Dictionary *dict2 =
[[GPBBoolUInt64Dictionary alloc] initWithValues:kValues2
forKeys:kKeys2
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 300U);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
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 valueForKey:YES value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, int64_t aValue, BOOL *stop) {
#pragma unused(aKey, aValue, stop)
XCTFail(@"Shouldn't get here!");
}];
[dict release];
}
- (void)testOne {
GPBBoolInt64Dictionary *dict = [GPBBoolInt64Dictionary dictionaryWithValue:400 forKey:YES];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 1U);
int64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 400);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, int64_t aValue, BOOL *stop) {
XCTAssertEqual(aKey, YES);
XCTAssertEqual(aValue, 400);
XCTAssertNotEqual(stop, NULL);
}];
}
- (void)testBasics {
const BOOL kKeys[] = { YES, NO };
const int64_t kValues[] = { 400, 401 };
GPBBoolInt64Dictionary *dict =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
int64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 400);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 401);
__block NSUInteger idx = 0;
BOOL *seenKeys = malloc(2 * sizeof(BOOL));
int64_t *seenValues = malloc(2 * sizeof(int64_t));
[dict enumerateKeysAndValuesUsingBlock:^(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 enumerateKeysAndValuesUsingBlock:^(BOOL aKey, int64_t aValue, BOOL *stop) {
#pragma unused(aKey, aValue)
if (idx == 0) *stop = YES;
XCTAssertNotEqual(idx, 2U);
++idx;
}];
[dict release];
}
- (void)testEquality {
const BOOL kKeys1[] = { YES, NO };
const BOOL kKeys2[] = { NO, YES };
const int64_t kValues1[] = { 400, 401 };
const int64_t kValues2[] = { 401, 400 };
const int64_t kValues3[] = { 401 };
GPBBoolInt64Dictionary *dict1 =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1);
GPBBoolInt64Dictionary *dict1prime =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1prime);
GPBBoolInt64Dictionary *dict2 =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues2
forKeys:kKeys1
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
GPBBoolInt64Dictionary *dict3 =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues1
forKeys:kKeys2
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict3);
GPBBoolInt64Dictionary *dict4 =
[[GPBBoolInt64Dictionary alloc] initWithValues: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 save keys, different values; not equal.
XCTAssertNotEqualObjects(dict1, dict2);
// 3 is different keys, samae 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] initWithValues: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] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolInt64Dictionary *dict2 =
[GPBBoolInt64Dictionary dictionaryWithDictionary:dict];
XCTAssertNotNil(dict2);
// Should be new pointer, but equal objects.
XCTAssertNotEqual(dict, dict2);
XCTAssertEqualObjects(dict, dict2);
[dict release];
}
- (void)testAdds {
GPBBoolInt64Dictionary *dict = [GPBBoolInt64Dictionary dictionary];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
[dict setValue:400 forKey:YES];
XCTAssertEqual(dict.count, 1U);
const BOOL kKeys[] = { NO };
const int64_t kValues[] = { 401 };
GPBBoolInt64Dictionary *dict2 =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
int64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 400);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 401);
[dict2 release];
}
- (void)testRemove {
const BOOL kKeys[] = { YES, NO};
const int64_t kValues[] = { 400, 401 };
GPBBoolInt64Dictionary *dict =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
int64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 400);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
// Remove again does nothing.
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 400);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict removeAll];
XCTAssertEqual(dict.count, 0U);
XCTAssertFalse([dict valueForKey:YES value:NULL]);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict release];
}
- (void)testInplaceMutation {
const BOOL kKeys[] = { YES, NO };
const int64_t kValues[] = { 400, 401 };
GPBBoolInt64Dictionary *dict =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
int64_t value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 400);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 401);
[dict setValue:401 forKey:YES];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 401);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 401);
[dict setValue:400 forKey:NO];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 401);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 400);
const BOOL kKeys2[] = { NO, YES };
const int64_t kValues2[] = { 401, 400 };
GPBBoolInt64Dictionary *dict2 =
[[GPBBoolInt64Dictionary alloc] initWithValues:kValues2
forKeys:kKeys2
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 400);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
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 valueForKey:YES value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, BOOL aValue, BOOL *stop) {
#pragma unused(aKey, aValue, stop)
XCTFail(@"Shouldn't get here!");
}];
[dict release];
}
- (void)testOne {
GPBBoolBoolDictionary *dict = [GPBBoolBoolDictionary dictionaryWithValue:NO forKey:YES];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 1U);
BOOL value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, NO);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, BOOL aValue, BOOL *stop) {
XCTAssertEqual(aKey, YES);
XCTAssertEqual(aValue, NO);
XCTAssertNotEqual(stop, NULL);
}];
}
- (void)testBasics {
const BOOL kKeys[] = { YES, NO };
const BOOL kValues[] = { NO, YES };
GPBBoolBoolDictionary *dict =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
BOOL value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, NO);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, YES);
__block NSUInteger idx = 0;
BOOL *seenKeys = malloc(2 * sizeof(BOOL));
BOOL *seenValues = malloc(2 * sizeof(BOOL));
[dict enumerateKeysAndValuesUsingBlock:^(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 enumerateKeysAndValuesUsingBlock:^(BOOL aKey, BOOL aValue, BOOL *stop) {
#pragma unused(aKey, aValue)
if (idx == 0) *stop = YES;
XCTAssertNotEqual(idx, 2U);
++idx;
}];
[dict release];
}
- (void)testEquality {
const BOOL kKeys1[] = { YES, NO };
const BOOL kKeys2[] = { NO, YES };
const BOOL kValues1[] = { NO, YES };
const BOOL kValues2[] = { YES, NO };
const BOOL kValues3[] = { YES };
GPBBoolBoolDictionary *dict1 =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1);
GPBBoolBoolDictionary *dict1prime =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1prime);
GPBBoolBoolDictionary *dict2 =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues2
forKeys:kKeys1
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
GPBBoolBoolDictionary *dict3 =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues1
forKeys:kKeys2
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict3);
GPBBoolBoolDictionary *dict4 =
[[GPBBoolBoolDictionary alloc] initWithValues: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 save keys, different values; not equal.
XCTAssertNotEqualObjects(dict1, dict2);
// 3 is different keys, samae 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] initWithValues: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] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolBoolDictionary *dict2 =
[GPBBoolBoolDictionary dictionaryWithDictionary:dict];
XCTAssertNotNil(dict2);
// Should be new pointer, but equal objects.
XCTAssertNotEqual(dict, dict2);
XCTAssertEqualObjects(dict, dict2);
[dict release];
}
- (void)testAdds {
GPBBoolBoolDictionary *dict = [GPBBoolBoolDictionary dictionary];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
[dict setValue:NO forKey:YES];
XCTAssertEqual(dict.count, 1U);
const BOOL kKeys[] = { NO };
const BOOL kValues[] = { YES };
GPBBoolBoolDictionary *dict2 =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
BOOL value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, NO);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, YES);
[dict2 release];
}
- (void)testRemove {
const BOOL kKeys[] = { YES, NO};
const BOOL kValues[] = { NO, YES };
GPBBoolBoolDictionary *dict =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
BOOL value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, NO);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
// Remove again does nothing.
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, NO);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict removeAll];
XCTAssertEqual(dict.count, 0U);
XCTAssertFalse([dict valueForKey:YES value:NULL]);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict release];
}
- (void)testInplaceMutation {
const BOOL kKeys[] = { YES, NO };
const BOOL kValues[] = { NO, YES };
GPBBoolBoolDictionary *dict =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
BOOL value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, NO);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, YES);
[dict setValue:YES forKey:YES];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, YES);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, YES);
[dict setValue:NO forKey:NO];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, YES);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, NO);
const BOOL kKeys2[] = { NO, YES };
const BOOL kValues2[] = { YES, NO };
GPBBoolBoolDictionary *dict2 =
[[GPBBoolBoolDictionary alloc] initWithValues:kValues2
forKeys:kKeys2
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, NO);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
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 valueForKey:YES value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, float aValue, BOOL *stop) {
#pragma unused(aKey, aValue, stop)
XCTFail(@"Shouldn't get here!");
}];
[dict release];
}
- (void)testOne {
GPBBoolFloatDictionary *dict = [GPBBoolFloatDictionary dictionaryWithValue:500.f forKey:YES];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 1U);
float value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 500.f);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, float aValue, BOOL *stop) {
XCTAssertEqual(aKey, YES);
XCTAssertEqual(aValue, 500.f);
XCTAssertNotEqual(stop, NULL);
}];
}
- (void)testBasics {
const BOOL kKeys[] = { YES, NO };
const float kValues[] = { 500.f, 501.f };
GPBBoolFloatDictionary *dict =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
float value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 500.f);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 501.f);
__block NSUInteger idx = 0;
BOOL *seenKeys = malloc(2 * sizeof(BOOL));
float *seenValues = malloc(2 * sizeof(float));
[dict enumerateKeysAndValuesUsingBlock:^(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 enumerateKeysAndValuesUsingBlock:^(BOOL aKey, float aValue, BOOL *stop) {
#pragma unused(aKey, aValue)
if (idx == 0) *stop = YES;
XCTAssertNotEqual(idx, 2U);
++idx;
}];
[dict release];
}
- (void)testEquality {
const BOOL kKeys1[] = { YES, NO };
const BOOL kKeys2[] = { NO, YES };
const float kValues1[] = { 500.f, 501.f };
const float kValues2[] = { 501.f, 500.f };
const float kValues3[] = { 501.f };
GPBBoolFloatDictionary *dict1 =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1);
GPBBoolFloatDictionary *dict1prime =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1prime);
GPBBoolFloatDictionary *dict2 =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues2
forKeys:kKeys1
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
GPBBoolFloatDictionary *dict3 =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues1
forKeys:kKeys2
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict3);
GPBBoolFloatDictionary *dict4 =
[[GPBBoolFloatDictionary alloc] initWithValues: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 save keys, different values; not equal.
XCTAssertNotEqualObjects(dict1, dict2);
// 3 is different keys, samae 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] initWithValues: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] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolFloatDictionary *dict2 =
[GPBBoolFloatDictionary dictionaryWithDictionary:dict];
XCTAssertNotNil(dict2);
// Should be new pointer, but equal objects.
XCTAssertNotEqual(dict, dict2);
XCTAssertEqualObjects(dict, dict2);
[dict release];
}
- (void)testAdds {
GPBBoolFloatDictionary *dict = [GPBBoolFloatDictionary dictionary];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
[dict setValue:500.f forKey:YES];
XCTAssertEqual(dict.count, 1U);
const BOOL kKeys[] = { NO };
const float kValues[] = { 501.f };
GPBBoolFloatDictionary *dict2 =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
float value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 500.f);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 501.f);
[dict2 release];
}
- (void)testRemove {
const BOOL kKeys[] = { YES, NO};
const float kValues[] = { 500.f, 501.f };
GPBBoolFloatDictionary *dict =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
float value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 500.f);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
// Remove again does nothing.
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 500.f);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict removeAll];
XCTAssertEqual(dict.count, 0U);
XCTAssertFalse([dict valueForKey:YES value:NULL]);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict release];
}
- (void)testInplaceMutation {
const BOOL kKeys[] = { YES, NO };
const float kValues[] = { 500.f, 501.f };
GPBBoolFloatDictionary *dict =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
float value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 500.f);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 501.f);
[dict setValue:501.f forKey:YES];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 501.f);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 501.f);
[dict setValue:500.f forKey:NO];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 501.f);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 500.f);
const BOOL kKeys2[] = { NO, YES };
const float kValues2[] = { 501.f, 500.f };
GPBBoolFloatDictionary *dict2 =
[[GPBBoolFloatDictionary alloc] initWithValues:kValues2
forKeys:kKeys2
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 500.f);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
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 valueForKey:YES value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, double aValue, BOOL *stop) {
#pragma unused(aKey, aValue, stop)
XCTFail(@"Shouldn't get here!");
}];
[dict release];
}
- (void)testOne {
GPBBoolDoubleDictionary *dict = [GPBBoolDoubleDictionary dictionaryWithValue:600. forKey:YES];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 1U);
double value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 600.);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, double aValue, BOOL *stop) {
XCTAssertEqual(aKey, YES);
XCTAssertEqual(aValue, 600.);
XCTAssertNotEqual(stop, NULL);
}];
}
- (void)testBasics {
const BOOL kKeys[] = { YES, NO };
const double kValues[] = { 600., 601. };
GPBBoolDoubleDictionary *dict =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
double value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 600.);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 601.);
__block NSUInteger idx = 0;
BOOL *seenKeys = malloc(2 * sizeof(BOOL));
double *seenValues = malloc(2 * sizeof(double));
[dict enumerateKeysAndValuesUsingBlock:^(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 enumerateKeysAndValuesUsingBlock:^(BOOL aKey, double aValue, BOOL *stop) {
#pragma unused(aKey, aValue)
if (idx == 0) *stop = YES;
XCTAssertNotEqual(idx, 2U);
++idx;
}];
[dict release];
}
- (void)testEquality {
const BOOL kKeys1[] = { YES, NO };
const BOOL kKeys2[] = { NO, YES };
const double kValues1[] = { 600., 601. };
const double kValues2[] = { 601., 600. };
const double kValues3[] = { 601. };
GPBBoolDoubleDictionary *dict1 =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1);
GPBBoolDoubleDictionary *dict1prime =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1prime);
GPBBoolDoubleDictionary *dict2 =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues2
forKeys:kKeys1
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
GPBBoolDoubleDictionary *dict3 =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues1
forKeys:kKeys2
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict3);
GPBBoolDoubleDictionary *dict4 =
[[GPBBoolDoubleDictionary alloc] initWithValues: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 save keys, different values; not equal.
XCTAssertNotEqualObjects(dict1, dict2);
// 3 is different keys, samae 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] initWithValues: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] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolDoubleDictionary *dict2 =
[GPBBoolDoubleDictionary dictionaryWithDictionary:dict];
XCTAssertNotNil(dict2);
// Should be new pointer, but equal objects.
XCTAssertNotEqual(dict, dict2);
XCTAssertEqualObjects(dict, dict2);
[dict release];
}
- (void)testAdds {
GPBBoolDoubleDictionary *dict = [GPBBoolDoubleDictionary dictionary];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
[dict setValue:600. forKey:YES];
XCTAssertEqual(dict.count, 1U);
const BOOL kKeys[] = { NO };
const double kValues[] = { 601. };
GPBBoolDoubleDictionary *dict2 =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
double value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 600.);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 601.);
[dict2 release];
}
- (void)testRemove {
const BOOL kKeys[] = { YES, NO};
const double kValues[] = { 600., 601. };
GPBBoolDoubleDictionary *dict =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
double value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 600.);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
// Remove again does nothing.
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 600.);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict removeAll];
XCTAssertEqual(dict.count, 0U);
XCTAssertFalse([dict valueForKey:YES value:NULL]);
XCTAssertFalse([dict valueForKey:NO value:NULL]);
[dict release];
}
- (void)testInplaceMutation {
const BOOL kKeys[] = { YES, NO };
const double kValues[] = { 600., 601. };
GPBBoolDoubleDictionary *dict =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
double value;
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 600.);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 601.);
[dict setValue:601. forKey:YES];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 601.);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 601.);
[dict setValue:600. forKey:NO];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 601.);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 600.);
const BOOL kKeys2[] = { NO, YES };
const double kValues2[] = { 601., 600. };
GPBBoolDoubleDictionary *dict2 =
[[GPBBoolDoubleDictionary alloc] initWithValues:kValues2
forKeys:kKeys2
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertTrue([dict valueForKey:YES value:NULL]);
XCTAssertTrue([dict valueForKey:YES value:&value]);
XCTAssertEqual(value, 600.);
XCTAssertTrue([dict valueForKey:NO value:NULL]);
XCTAssertTrue([dict valueForKey:NO value:&value]);
XCTAssertEqual(value, 601.);
[dict2 release];
[dict release];
}
@end
//%PDDM-EXPAND TESTS_FOR_BOOL_KEY_OBJECT_VALUE(Object, id, @"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 *dict = [[GPBBoolObjectDictionary alloc] init];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
XCTAssertNil([dict valueForKey:YES]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, id aValue, BOOL *stop) {
#pragma unused(aKey, aValue, stop)
XCTFail(@"Shouldn't get here!");
}];
[dict release];
}
- (void)testOne {
GPBBoolObjectDictionary *dict = [GPBBoolObjectDictionary dictionaryWithValue:@"abc" forKey:YES];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 1U);
XCTAssertEqualObjects([dict valueForKey:YES], @"abc");
XCTAssertNil([dict valueForKey:NO]);
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, id aValue, BOOL *stop) {
XCTAssertEqual(aKey, YES);
XCTAssertEqualObjects(aValue, @"abc");
XCTAssertNotEqual(stop, NULL);
}];
}
- (void)testBasics {
const BOOL kKeys[] = { YES, NO };
const id kValues[] = { @"abc", @"def" };
GPBBoolObjectDictionary *dict =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
XCTAssertEqualObjects([dict valueForKey:YES], @"abc");
XCTAssertEqualObjects([dict valueForKey:NO], @"def");
__block NSUInteger idx = 0;
BOOL *seenKeys = malloc(2 * sizeof(BOOL));
id *seenValues = malloc(2 * sizeof(id));
[dict enumerateKeysAndValuesUsingBlock:^(BOOL aKey, id 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;
XCTAssertEqualObjects(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 enumerateKeysAndValuesUsingBlock:^(BOOL aKey, id aValue, BOOL *stop) {
#pragma unused(aKey, aValue)
if (idx == 0) *stop = YES;
XCTAssertNotEqual(idx, 2U);
++idx;
}];
[dict release];
}
- (void)testEquality {
const BOOL kKeys1[] = { YES, NO };
const BOOL kKeys2[] = { NO, YES };
const id kValues1[] = { @"abc", @"def" };
const id kValues2[] = { @"def", @"abc" };
const id kValues3[] = { @"def" };
GPBBoolObjectDictionary *dict1 =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1);
GPBBoolObjectDictionary *dict1prime =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues1
forKeys:kKeys1
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict1prime);
GPBBoolObjectDictionary *dict2 =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues2
forKeys:kKeys1
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
GPBBoolObjectDictionary *dict3 =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues1
forKeys:kKeys2
count:GPBARRAYSIZE(kValues1)];
XCTAssertNotNil(dict3);
GPBBoolObjectDictionary *dict4 =
[[GPBBoolObjectDictionary alloc] initWithValues: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 save keys, different values; not equal.
XCTAssertNotEqualObjects(dict1, dict2);
// 3 is different keys, samae 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 id kValues[] = { @"abc", @"def" };
GPBBoolObjectDictionary *dict =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolObjectDictionary *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 id kValues[] = { @"abc", @"def" };
GPBBoolObjectDictionary *dict =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
GPBBoolObjectDictionary *dict2 =
[GPBBoolObjectDictionary dictionaryWithDictionary:dict];
XCTAssertNotNil(dict2);
// Should be new pointer, but equal objects.
XCTAssertNotEqual(dict, dict2);
XCTAssertEqualObjects(dict, dict2);
[dict release];
}
- (void)testAdds {
GPBBoolObjectDictionary *dict = [GPBBoolObjectDictionary dictionary];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 0U);
[dict setValue:@"abc" forKey:YES];
XCTAssertEqual(dict.count, 1U);
const BOOL kKeys[] = { NO };
const id kValues[] = { @"def" };
GPBBoolObjectDictionary *dict2 =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertEqualObjects([dict valueForKey:YES], @"abc");
XCTAssertEqualObjects([dict valueForKey:NO], @"def");
[dict2 release];
}
- (void)testRemove {
const BOOL kKeys[] = { YES, NO};
const id kValues[] = { @"abc", @"def" };
GPBBoolObjectDictionary *dict =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertEqualObjects([dict valueForKey:YES], @"abc");
XCTAssertNil([dict valueForKey:NO]);
// Remove again does nothing.
[dict removeValueForKey:NO];
XCTAssertEqual(dict.count, 1U);
XCTAssertEqualObjects([dict valueForKey:YES], @"abc");
XCTAssertNil([dict valueForKey:NO]);
[dict removeAll];
XCTAssertEqual(dict.count, 0U);
XCTAssertNil([dict valueForKey:YES]);
XCTAssertNil([dict valueForKey:NO]);
[dict release];
}
- (void)testInplaceMutation {
const BOOL kKeys[] = { YES, NO };
const id kValues[] = { @"abc", @"def" };
GPBBoolObjectDictionary *dict =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues
forKeys:kKeys
count:GPBARRAYSIZE(kValues)];
XCTAssertNotNil(dict);
XCTAssertEqual(dict.count, 2U);
XCTAssertEqualObjects([dict valueForKey:YES], @"abc");
XCTAssertEqualObjects([dict valueForKey:NO], @"def");
[dict setValue:@"def" forKey:YES];
XCTAssertEqual(dict.count, 2U);
XCTAssertEqualObjects([dict valueForKey:YES], @"def");
XCTAssertEqualObjects([dict valueForKey:NO], @"def");
[dict setValue:@"abc" forKey:NO];
XCTAssertEqual(dict.count, 2U);
XCTAssertEqualObjects([dict valueForKey:YES], @"def");
XCTAssertEqualObjects([dict valueForKey:NO], @"abc");
const BOOL kKeys2[] = { NO, YES };
const id kValues2[] = { @"def", @"abc" };
GPBBoolObjectDictionary *dict2 =
[[GPBBoolObjectDictionary alloc] initWithValues:kValues2
forKeys:kKeys2
count:GPBARRAYSIZE(kValues2)];
XCTAssertNotNil(dict2);
[dict addEntriesFromDictionary:dict2];
XCTAssertEqual(dict.count, 2U);
XCTAssertEqualObjects([dict valueForKey:YES], @"abc");
XCTAssertEqualObjects([dict valueForKey:NO], @"def");
[dict2 release];
[dict release];
}
@end
//%PDDM-EXPAND-END (8 expansions)