mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-12-23 22:55:00 +00:00
Move BITValidateEmail to BITHockeyHelper named bit_validateEmail and add some tests
This commit is contained in:
@@ -30,6 +30,7 @@
|
||||
#import "BITAuthenticator_Private.h"
|
||||
#import "HockeySDKPrivate.h"
|
||||
#import "HockeySDK.h"
|
||||
#import "BITHockeyHelper.h"
|
||||
#import "BITHockeyAppClient.h"
|
||||
|
||||
@interface BITAuthenticationViewController ()<UITextFieldDelegate> {
|
||||
@@ -152,7 +153,7 @@
|
||||
if (self.requirePassword && [self.password length] == 0)
|
||||
return NO;
|
||||
|
||||
if (![self.email length] || !BITValidateEmail(self.email))
|
||||
if (![self.email length] || !bit_validateEmail(self.email))
|
||||
return NO;
|
||||
|
||||
return YES;
|
||||
|
||||
@@ -32,6 +32,7 @@
|
||||
#if HOCKEYSDK_FEATURE_FEEDBACK
|
||||
|
||||
#import "HockeySDKPrivate.h"
|
||||
#import "BITHockeyHelper.h"
|
||||
|
||||
#import "BITFeedbackUserDataViewController.h"
|
||||
#import "BITFeedbackManagerPrivate.h"
|
||||
@@ -120,7 +121,7 @@
|
||||
if ([self.manager requireUserEmail] == BITFeedbackUserDataElementRequired && [self.email length] == 0)
|
||||
return NO;
|
||||
|
||||
if ([self.email length] > 0 && !BITValidateEmail(self.email))
|
||||
if ([self.email length] > 0 && !bit_validateEmail(self.email))
|
||||
return NO;
|
||||
|
||||
return YES;
|
||||
|
||||
@@ -34,6 +34,7 @@ NSString *bit_URLEncodedString(NSString *inputString);
|
||||
NSString *bit_URLDecodedString(NSString *inputString);
|
||||
NSString *bit_base64String(NSData * data, unsigned long length);
|
||||
|
||||
BOOL bit_validateEmail(NSString *email);
|
||||
NSString *bit_keychainHockeySDKServiceName(void);
|
||||
|
||||
NSComparisonResult bit_versionCompare(NSString *stringA, NSString *stringB);
|
||||
|
||||
@@ -114,6 +114,20 @@ NSString *bit_base64String(NSData * data, unsigned long length) {
|
||||
return result;
|
||||
}
|
||||
|
||||
BOOL bit_validateEmail(NSString *email) {
|
||||
NSString *emailRegex =
|
||||
@"(?:[a-z0-9!#$%\\&'*+/=?\\^_`{|}~-]+(?:\\.[a-z0-9!#$%\\&'*+/=?\\^_`{|}"
|
||||
@"~-]+)*|\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\"
|
||||
@"x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\")@(?:(?:[a-z0-9](?:[a-"
|
||||
@"z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\\[(?:(?:25[0-5"
|
||||
@"]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-"
|
||||
@"9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21"
|
||||
@"-\\x5a\\x53-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\])";
|
||||
NSPredicate *emailTest = [NSPredicate predicateWithFormat:@"SELF MATCHES[c] %@", emailRegex];
|
||||
|
||||
return [emailTest evaluateWithObject:email];
|
||||
}
|
||||
|
||||
NSString *bit_keychainHockeySDKServiceName(void) {
|
||||
NSString *serviceName = [NSString stringWithFormat:@"%@.HockeySDK", bit_mainBundleIdentifier()];
|
||||
return serviceName;
|
||||
|
||||
@@ -66,7 +66,6 @@
|
||||
NSBundle *BITHockeyBundle(void);
|
||||
NSString *BITHockeyLocalizedString(NSString *stringToken);
|
||||
NSString *BITHockeyMD5(NSString *str);
|
||||
BOOL BITValidateEmail(NSString *email);
|
||||
|
||||
#if __IPHONE_OS_VERSION_MIN_REQUIRED < __IPHONE_6_0
|
||||
|
||||
|
||||
@@ -73,17 +73,3 @@ NSString *BITHockeyMD5(NSString *str) {
|
||||
result[14], result[15]
|
||||
];
|
||||
}
|
||||
|
||||
BOOL BITValidateEmail(NSString *email) {
|
||||
NSString *emailRegex =
|
||||
@"(?:[a-z0-9!#$%\\&'*+/=?\\^_`{|}~-]+(?:\\.[a-z0-9!#$%\\&'*+/=?\\^_`{|}"
|
||||
@"~-]+)*|\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\"
|
||||
@"x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\")@(?:(?:[a-z0-9](?:[a-"
|
||||
@"z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\\[(?:(?:25[0-5"
|
||||
@"]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-"
|
||||
@"9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21"
|
||||
@"-\\x5a\\x53-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\])";
|
||||
NSPredicate *emailTest = [NSPredicate predicateWithFormat:@"SELF MATCHES[c] %@", emailRegex];
|
||||
|
||||
return [emailTest evaluateWithObject:email];
|
||||
}
|
||||
|
||||
@@ -102,6 +102,7 @@
|
||||
1E70A23217F2F982001BB32D /* live_report_empty.plcrash in Resources */ = {isa = PBXBuildFile; fileRef = 1E70A22F17F2F982001BB32D /* live_report_empty.plcrash */; };
|
||||
1E70A23317F2F982001BB32D /* live_report_exception.plcrash in Resources */ = {isa = PBXBuildFile; fileRef = 1E70A23017F2F982001BB32D /* live_report_exception.plcrash */; };
|
||||
1E70A23417F2F982001BB32D /* live_report_signal.plcrash in Resources */ = {isa = PBXBuildFile; fileRef = 1E70A23117F2F982001BB32D /* live_report_signal.plcrash */; };
|
||||
1E70A23617F31B82001BB32D /* BITHockeyHelperTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 1E70A23517F31B82001BB32D /* BITHockeyHelperTests.m */; };
|
||||
1E754E5C1621FBB70070AB92 /* BITCrashManager.h in Headers */ = {isa = PBXBuildFile; fileRef = 1E754E561621FBB70070AB92 /* BITCrashManager.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
||||
1E754E5D1621FBB70070AB92 /* BITCrashManager.m in Sources */ = {isa = PBXBuildFile; fileRef = 1E754E571621FBB70070AB92 /* BITCrashManager.m */; };
|
||||
1E754E5E1621FBB70070AB92 /* BITCrashManagerDelegate.h in Headers */ = {isa = PBXBuildFile; fileRef = 1E754E581621FBB70070AB92 /* BITCrashManagerDelegate.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
||||
@@ -256,6 +257,7 @@
|
||||
1E70A22F17F2F982001BB32D /* live_report_empty.plcrash */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = live_report_empty.plcrash; sourceTree = "<group>"; };
|
||||
1E70A23017F2F982001BB32D /* live_report_exception.plcrash */ = {isa = PBXFileReference; lastKnownFileType = file; path = live_report_exception.plcrash; sourceTree = "<group>"; };
|
||||
1E70A23117F2F982001BB32D /* live_report_signal.plcrash */ = {isa = PBXFileReference; lastKnownFileType = file; path = live_report_signal.plcrash; sourceTree = "<group>"; };
|
||||
1E70A23517F31B82001BB32D /* BITHockeyHelperTests.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = BITHockeyHelperTests.m; sourceTree = "<group>"; };
|
||||
1E71509A15B5C76F004E88FF /* HockeySDK.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = HockeySDK.h; sourceTree = "<group>"; };
|
||||
1E754DC61621BC170070AB92 /* HockeySDK.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = HockeySDK.xcconfig; sourceTree = "<group>"; };
|
||||
1E754E561621FBB70070AB92 /* BITCrashManager.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BITCrashManager.h; sourceTree = "<group>"; };
|
||||
@@ -378,6 +380,7 @@
|
||||
1EFF03E417F2485500A5F13C /* BITCrashManagerTests.m */,
|
||||
E40E0B0817DA19DC005E38C1 /* BITHockeyAppClientTests.m */,
|
||||
E4507E4217F0658F00171A0D /* BITKeychainUtilsTests.m */,
|
||||
1E70A23517F31B82001BB32D /* BITHockeyHelperTests.m */,
|
||||
);
|
||||
path = HockeySDKTests;
|
||||
sourceTree = "<group>";
|
||||
@@ -911,6 +914,7 @@
|
||||
1E5A459E16F0DFC200B55C04 /* BITStoreUpdateManagerTests.m in Sources */,
|
||||
1EFF03E517F2485500A5F13C /* BITCrashManagerTests.m in Sources */,
|
||||
E40E0B0917DA19DC005E38C1 /* BITHockeyAppClientTests.m in Sources */,
|
||||
1E70A23617F31B82001BB32D /* BITHockeyHelperTests.m in Sources */,
|
||||
E48A3DEF17B3EFF100924C3D /* BITAuthenticatorTests.m in Sources */,
|
||||
1EA1170716F53B91001C015C /* BITTestHelper.m in Sources */,
|
||||
E4507E4317F0658F00171A0D /* BITKeychainUtilsTests.m in Sources */,
|
||||
|
||||
58
Support/HockeySDKTests/BITHockeyHelperTests.m
Normal file
58
Support/HockeySDKTests/BITHockeyHelperTests.m
Normal file
@@ -0,0 +1,58 @@
|
||||
//
|
||||
// HockeySDKPrivateTests.m
|
||||
// HockeySDK
|
||||
//
|
||||
// Created by Andreas Linde on 25.09.13.
|
||||
//
|
||||
//
|
||||
|
||||
#import <SenTestingKit/SenTestingKit.h>
|
||||
|
||||
#define HC_SHORTHAND
|
||||
#import <OCHamcrestIOS/OCHamcrestIOS.h>
|
||||
|
||||
#define MOCKITO_SHORTHAND
|
||||
#import <OCMockitoIOS/OCMockitoIOS.h>
|
||||
|
||||
#import "HockeySDK.h"
|
||||
#import "BITHockeyHelper.h"
|
||||
|
||||
|
||||
@interface BITHockeyHelperTests : SenTestCase
|
||||
|
||||
@end
|
||||
|
||||
@implementation BITHockeyHelperTests
|
||||
|
||||
|
||||
- (void)setUp {
|
||||
[super setUp];
|
||||
// Put setup code here; it will be run once, before the first test case.
|
||||
}
|
||||
|
||||
- (void)tearDown {
|
||||
// Put teardown code here; it will be run once, after the last test case.
|
||||
[super tearDown];
|
||||
}
|
||||
|
||||
- (void)testValidateEmail {
|
||||
BOOL result = NO;
|
||||
|
||||
// valid email
|
||||
result = bit_validateEmail(@"mail@test.com");
|
||||
assertThatBool(result, equalToBool(YES));
|
||||
|
||||
// invalid emails
|
||||
|
||||
result = bit_validateEmail(@"mail@test");
|
||||
assertThatBool(result, equalToBool(NO));
|
||||
|
||||
result = bit_validateEmail(@"mail@.com");
|
||||
assertThatBool(result, equalToBool(NO));
|
||||
|
||||
result = bit_validateEmail(@"mail.com");
|
||||
assertThatBool(result, equalToBool(NO));
|
||||
|
||||
}
|
||||
|
||||
@end
|
||||
Reference in New Issue
Block a user