mirror of https://github.com/oxen-io/session-ios
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.
48 lines
1.7 KiB
Objective-C
48 lines
1.7 KiB
Objective-C
#import <XCTest/XCTest.h>
|
|
#import "TestUtil.h"
|
|
#import "EC25KeyAgreementParticipant.h"
|
|
#import "EC25KeyAgreementProtocol.h"
|
|
|
|
@interface EC25AgreerTest : XCTestCase
|
|
@end
|
|
|
|
@implementation EC25AgreerTest
|
|
|
|
-(void) testKeyExchangeMatchesPeerButNotOthers {
|
|
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];
|
|
|
|
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]);
|
|
}
|
|
}
|
|
|
|
@end
|