You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
session-ios/Signal/test/network/rtp/zrtp/EC25AgreerTest.m

46 lines
1.6 KiB
Matlab

#import <XCTest/XCTest.h>
12 years ago
#import "TestUtil.h"
@interface EC25AgreerTest : XCTestCase
12 years ago
@end
@implementation EC25AgreerTest
-(void) testKeyExchangeMatchesPeerButNotOthers {
12 years ago
EC25KeyAgreementProtocol* protocol = [EC25KeyAgreementProtocol protocol];
id<KeyAgreementParticipant> ec1 = [protocol generateParticipantWithNewKeys];
id<KeyAgreementParticipant> ec2 = [protocol generateParticipantWithNewKeys];
id<KeyAgreementParticipant> ec3 = [protocol generateParticipantWithNewKeys];
NSData* pub_1 = ec1.getPublicKeyData;
NSData* pub_2 = ec2.getPublicKeyData;
12 years ago
NSData* shared_1 = [ec1 calculateKeyAgreementAgainstRemotePublicKey:pub_2];
NSData* shared_2 = [ec2 calculateKeyAgreementAgainstRemotePublicKey:pub_1];
test([shared_1 isEqualToData:shared_2]);
NSData* shared_3 = [ec3 calculateKeyAgreementAgainstRemotePublicKey:pub_1];
test(![shared_3 isEqualToData:shared_1]);
}
-(void) testKeyExchangeSucceedsConsistently {
EC25KeyAgreementProtocol* protocol = [EC25KeyAgreementProtocol protocol];
for (int i = 0; i < 1000; i++) {
id<KeyAgreementParticipant> ec1 = [protocol generateParticipantWithNewKeys];
id<KeyAgreementParticipant> ec2 = [protocol generateParticipantWithNewKeys];
NSData* pub_1 = ec1.getPublicKeyData;
NSData* pub_2 = ec2.getPublicKeyData;
NSData* shared_1 = [ec1 calculateKeyAgreementAgainstRemotePublicKey:pub_2];
NSData* shared_2 = [ec2 calculateKeyAgreementAgainstRemotePublicKey:pub_1];
test([shared_1 isEqualToData:shared_2]);
}
}
12 years ago
@end