| Index: third_party/protobuf/objectivec/Tests/GPBDictionaryTests+Bool.m
|
| diff --git a/third_party/protobuf/objectivec/Tests/GPBDictionaryTests+Bool.m b/third_party/protobuf/objectivec/Tests/GPBDictionaryTests+Bool.m
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..8b1900fef59f3e6edeb2de35c668f277803b4469
|
| --- /dev/null
|
| +++ b/third_party/protobuf/objectivec/Tests/GPBDictionaryTests+Bool.m
|
| @@ -0,0 +1,2418 @@
|
| +// 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 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] 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 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] 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 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] 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 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] 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 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] 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 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] 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 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] 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 objectForKey:YES]);
|
| + [dict enumerateKeysAndObjectsUsingBlock:^(BOOL aKey, id aObject, BOOL *stop) {
|
| + #pragma unused(aKey, aObject, stop)
|
| + XCTFail(@"Shouldn't get here!");
|
| + }];
|
| + [dict release];
|
| +}
|
| +
|
| +- (void)testOne {
|
| + GPBBoolObjectDictionary *dict = [GPBBoolObjectDictionary dictionaryWithObject:@"abc" forKey:YES];
|
| + XCTAssertNotNil(dict);
|
| + XCTAssertEqual(dict.count, 1U);
|
| + XCTAssertEqualObjects([dict objectForKey:YES], @"abc");
|
| + XCTAssertNil([dict objectForKey:NO]);
|
| + [dict enumerateKeysAndObjectsUsingBlock:^(BOOL aKey, id aObject, BOOL *stop) {
|
| + XCTAssertEqual(aKey, YES);
|
| + XCTAssertEqualObjects(aObject, @"abc");
|
| + XCTAssertNotEqual(stop, NULL);
|
| + }];
|
| +}
|
| +
|
| +- (void)testBasics {
|
| + const BOOL kKeys[] = { YES, NO };
|
| + const id kObjects[] = { @"abc", @"def" };
|
| + GPBBoolObjectDictionary *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));
|
| + id *seenObjects = malloc(2 * sizeof(id));
|
| + [dict enumerateKeysAndObjectsUsingBlock:^(BOOL aKey, id aObject, BOOL *stop) {
|
| + XCTAssertLessThan(idx, 2U);
|
| + seenKeys[idx] = aKey;
|
| + seenObjects[idx] = aObject;
|
| + XCTAssertNotEqual(stop, NULL);
|
| + ++idx;
|
| + }];
|
| + for (int i = 0; i < 2; ++i) {
|
| + BOOL foundKey = NO;
|
| + for (int j = 0; (j < 2) && !foundKey; ++j) {
|
| + if (kKeys[i] == seenKeys[j]) {
|
| + foundKey = YES;
|
| + XCTAssertEqualObjects(kObjects[i], seenObjects[j], @"i = %d, j = %d", i, j);
|
| + }
|
| + }
|
| + XCTAssertTrue(foundKey, @"i = %d", i);
|
| + }
|
| + free(seenKeys);
|
| + free(seenObjects);
|
| +
|
| + // Stopping the enumeration.
|
| + idx = 0;
|
| + [dict enumerateKeysAndObjectsUsingBlock:^(BOOL aKey, id aObject, BOOL *stop) {
|
| + #pragma unused(aKey, aObject)
|
| + if (idx == 0) *stop = YES;
|
| + XCTAssertNotEqual(idx, 2U);
|
| + ++idx;
|
| + }];
|
| + [dict release];
|
| +}
|
| +
|
| +- (void)testEquality {
|
| + const BOOL kKeys1[] = { YES, NO };
|
| + const BOOL kKeys2[] = { NO, YES };
|
| + const id kObjects1[] = { @"abc", @"def" };
|
| + const id kObjects2[] = { @"def", @"abc" };
|
| + const id kObjects3[] = { @"def" };
|
| + GPBBoolObjectDictionary *dict1 =
|
| + [[GPBBoolObjectDictionary alloc] initWithObjects:kObjects1
|
| + forKeys:kKeys1
|
| + count:GPBARRAYSIZE(kObjects1)];
|
| + XCTAssertNotNil(dict1);
|
| + GPBBoolObjectDictionary *dict1prime =
|
| + [[GPBBoolObjectDictionary alloc] initWithObjects:kObjects1
|
| + forKeys:kKeys1
|
| + count:GPBARRAYSIZE(kObjects1)];
|
| + XCTAssertNotNil(dict1prime);
|
| + GPBBoolObjectDictionary *dict2 =
|
| + [[GPBBoolObjectDictionary alloc] initWithObjects:kObjects2
|
| + forKeys:kKeys1
|
| + count:GPBARRAYSIZE(kObjects2)];
|
| + XCTAssertNotNil(dict2);
|
| + GPBBoolObjectDictionary *dict3 =
|
| + [[GPBBoolObjectDictionary alloc] initWithObjects:kObjects1
|
| + forKeys:kKeys2
|
| + count:GPBARRAYSIZE(kObjects1)];
|
| + XCTAssertNotNil(dict3);
|
| + GPBBoolObjectDictionary *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 id kObjects[] = { @"abc", @"def" };
|
| + GPBBoolObjectDictionary *dict =
|
| + [[GPBBoolObjectDictionary alloc] initWithObjects:kObjects
|
| + forKeys:kKeys
|
| + count:GPBARRAYSIZE(kObjects)];
|
| + 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 kObjects[] = { @"abc", @"def" };
|
| + GPBBoolObjectDictionary *dict =
|
| + [[GPBBoolObjectDictionary alloc] initWithObjects:kObjects
|
| + forKeys:kKeys
|
| + count:GPBARRAYSIZE(kObjects)];
|
| + 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 setObject:@"abc" forKey:YES];
|
| + XCTAssertEqual(dict.count, 1U);
|
| +
|
| + const BOOL kKeys[] = { NO };
|
| + const id kObjects[] = { @"def" };
|
| + GPBBoolObjectDictionary *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];
|
| +}
|
| +
|
| +- (void)testRemove {
|
| + const BOOL kKeys[] = { YES, NO};
|
| + const id kObjects[] = { @"abc", @"def" };
|
| + GPBBoolObjectDictionary *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 id kObjects[] = { @"abc", @"def" };
|
| + GPBBoolObjectDictionary *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 id kObjects2[] = { @"def", @"abc" };
|
| + GPBBoolObjectDictionary *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)
|
| +
|
| +
|
|
|