Commit 6ec27f0d authored by Thomas Van Lenten's avatar Thomas Van Lenten

Add an explicit test using secure coding for added safety.

parent 829bb1d7
...@@ -338,14 +338,38 @@ ...@@ -338,14 +338,38 @@
} }
- (void)testCoding { - (void)testCoding {
GPBMessage *original = [self mergeResult];
NSData *data = NSData *data =
[NSKeyedArchiver archivedDataWithRootObject:[self mergeResult]]; [NSKeyedArchiver archivedDataWithRootObject:original];
id unarchivedObject = [NSKeyedUnarchiver unarchiveObjectWithData:data]; id unarchivedObject = [NSKeyedUnarchiver unarchiveObjectWithData:data];
XCTAssertEqualObjects(unarchivedObject, [self mergeResult]); XCTAssertEqualObjects(unarchivedObject, original);
// Intentionally doing a pointer comparison. // Intentionally doing a pointer comparison.
XCTAssertNotEqual(unarchivedObject, [self mergeResult]); XCTAssertNotEqual(unarchivedObject, original);
}
- (void)testSecureCoding {
GPBMessage *original = [self mergeResult];
NSString *key = @"testing123";
NSMutableData *data = [NSMutableData data];
NSKeyedArchiver *archiver = [[NSKeyedArchiver alloc] initForWritingWithMutableData:data];
[archiver setRequiresSecureCoding:YES];
[archiver encodeObject:obj forKey:key];
[archiver finishEncoding];
NSKeyedUnarchiver *unarchiver = [[NSKeyedUnarchiver alloc] initForReadingWithData:data];
[unarchiver setRequiresSecureCoding:YES];
id unarchivedObject = [unarchiver decodeObjectOfClass:[GPBMessage class]
forKey:key];
[unarchiver finishDecoding];
XCTAssertEqualObjects(unarchivedObject, original);
// Intentionally doing a pointer comparison.
XCTAssertNotEqual(unarchivedObject, original);
} }
- (void)testObjectReset { - (void)testObjectReset {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment