FIRStorageTokenAuthorizerTests.m 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. // Copyright 2017 Google
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #import "FIRStorageTestHelpers.h"
  15. @interface FIRStorageTokenAuthorizerTests : XCTestCase
  16. @property(strong, nonatomic) GTMSessionFetcher *fetcher;
  17. @property(strong, nonatomic) id mockApp;
  18. @end
  19. @implementation FIRStorageTokenAuthorizerTests
  20. - (void)setUp {
  21. [super setUp];
  22. NSURLRequest *fetchRequest = [NSURLRequest requestWithURL:[FIRStorageTestHelpers objectURL]];
  23. self.fetcher = [GTMSessionFetcher fetcherWithRequest:fetchRequest];
  24. self.mockApp = OCMClassMock([FIRApp class]);
  25. OCMStub([self.mockApp getTokenImplementation])
  26. .andReturn(^{
  27. });
  28. FIRTokenCallback mockCallback =
  29. [OCMArg invokeBlockWithArgs:kFIRStorageTestAuthToken, [NSNull null], nil];
  30. OCMStub([self.mockApp getTokenForcingRefresh:NO withCallback:mockCallback]);
  31. GTMSessionFetcherService *fetcherService = [[GTMSessionFetcherService alloc] init];
  32. self.fetcher.authorizer =
  33. [[FIRStorageTokenAuthorizer alloc] initWithApp:self.mockApp fetcherService:fetcherService];
  34. }
  35. - (void)tearDown {
  36. self.fetcher = nil;
  37. self.mockApp = nil;
  38. [super tearDown];
  39. }
  40. - (void)testSuccessfulAuth {
  41. XCTestExpectation *expectation = [self expectationWithDescription:@"testSuccessfulAuth"];
  42. self.fetcher.testBlock = ^(GTMSessionFetcher *fetcher, GTMSessionFetcherTestResponse response) {
  43. #pragma clang diagnostic push
  44. #pragma clang diagnostic ignored "-Warc-retain-cycles"
  45. XCTAssertTrue([self.fetcher.authorizer isAuthorizedRequest:fetcher.request]);
  46. #pragma clang diagnostic pop
  47. NSHTTPURLResponse *httpResponse =
  48. [[NSHTTPURLResponse alloc] initWithURL:fetcher.request.URL
  49. statusCode:200
  50. HTTPVersion:kHTTPVersion
  51. headerFields:nil];
  52. response(httpResponse, nil, nil);
  53. };
  54. [self.fetcher beginFetchWithCompletionHandler:^(NSData *_Nullable data,
  55. NSError *_Nullable error) {
  56. NSDictionary<NSString *, NSString *> *headers = self.fetcher.request.allHTTPHeaderFields;
  57. NSString *authHeader = [headers objectForKey:@"Authorization"];
  58. NSString *firebaseToken =
  59. [NSString stringWithFormat:kFIRStorageAuthTokenFormat, kFIRStorageTestAuthToken];
  60. XCTAssertEqualObjects(authHeader, firebaseToken);
  61. [expectation fulfill];
  62. }];
  63. [FIRStorageTestHelpers waitForExpectation:self];
  64. }
  65. - (void)testUnsuccessfulAuth {
  66. XCTestExpectation *expectation = [self expectationWithDescription:@"testUnsuccessfulAuth"];
  67. NSError *authError = [NSError errorWithDomain:FIRStorageErrorDomain
  68. code:FIRStorageErrorCodeUnauthenticated
  69. userInfo:nil];
  70. id unsuccessfulApp = OCMClassMock([FIRApp class]);
  71. OCMStub([unsuccessfulApp getTokenImplementation])
  72. .andReturn(^{
  73. });
  74. FIRTokenCallback mockCallback = [OCMArg invokeBlockWithArgs:[NSNull null], authError, nil];
  75. OCMStub([unsuccessfulApp getTokenForcingRefresh:NO withCallback:mockCallback]);
  76. GTMSessionFetcherService *fetcherService = [[GTMSessionFetcherService alloc] init];
  77. self.fetcher.authorizer =
  78. [[FIRStorageTokenAuthorizer alloc] initWithApp:unsuccessfulApp fetcherService:fetcherService];
  79. self.fetcher.testBlock = ^(GTMSessionFetcher *fetcher, GTMSessionFetcherTestResponse response) {
  80. #pragma clang diagnostic push
  81. #pragma clang diagnostic ignored "-Warc-retain-cycles"
  82. XCTAssertEqual([self.fetcher.authorizer isAuthorizedRequest:fetcher.request], NO);
  83. #pragma cland diagnostic pop
  84. NSHTTPURLResponse *httpResponse =
  85. [[NSHTTPURLResponse alloc] initWithURL:fetcher.request.URL
  86. statusCode:401
  87. HTTPVersion:kHTTPVersion
  88. headerFields:nil];
  89. response(httpResponse, nil, authError);
  90. };
  91. [self.fetcher beginFetchWithCompletionHandler:^(NSData *_Nullable data,
  92. NSError *_Nullable error) {
  93. NSDictionary<NSString *, NSString *> *headers = self.fetcher.request.allHTTPHeaderFields;
  94. NSString *authHeader = [headers objectForKey:@"Authorization"];
  95. XCTAssertNil(authHeader);
  96. XCTAssertEqualObjects(error.domain, FIRStorageErrorDomain);
  97. XCTAssertEqual(error.code, FIRStorageErrorCodeUnauthenticated);
  98. [expectation fulfill];
  99. }];
  100. [FIRStorageTestHelpers waitForExpectation:self];
  101. }
  102. - (void)testSuccessfulUnauthenticatedAuth {
  103. XCTestExpectation *expectation =
  104. [self expectationWithDescription:@"testSuccessfulUnauthenticatedAuth"];
  105. // Note that self.mockApp is left with null properties--this simulates no token present
  106. self.mockApp = OCMClassMock([FIRApp class]);
  107. GTMSessionFetcherService *fetcherService = [[GTMSessionFetcherService alloc] init];
  108. self.fetcher.authorizer =
  109. [[FIRStorageTokenAuthorizer alloc] initWithApp:self.mockApp fetcherService:fetcherService];
  110. self.fetcher.testBlock = ^(GTMSessionFetcher *fetcher, GTMSessionFetcherTestResponse response) {
  111. #pragma clang diagnostic push
  112. #pragma clang diagnostic ignored "-Warc-retain-cycles"
  113. XCTAssertFalse([self.fetcher.authorizer isAuthorizedRequest:fetcher.request]);
  114. #pragma cland diagnostic pop
  115. NSHTTPURLResponse *httpResponse =
  116. [[NSHTTPURLResponse alloc] initWithURL:fetcher.request.URL
  117. statusCode:200
  118. HTTPVersion:kHTTPVersion
  119. headerFields:nil];
  120. response(httpResponse, nil, nil);
  121. };
  122. [self.fetcher beginFetchWithCompletionHandler:^(NSData *_Nullable data,
  123. NSError *_Nullable error) {
  124. NSDictionary<NSString *, NSString *> *headers = self.fetcher.request.allHTTPHeaderFields;
  125. NSString *authHeader = [headers objectForKey:@"Authorization"];
  126. XCTAssertNil(authHeader);
  127. XCTAssertNil(error);
  128. [expectation fulfill];
  129. }];
  130. [FIRStorageTestHelpers waitForExpectation:self];
  131. }
  132. - (void)testIsAuthorizing {
  133. XCTestExpectation *expectation = [self expectationWithDescription:@"testIsAuthorizing"];
  134. self.fetcher.testBlock = ^(GTMSessionFetcher *fetcher, GTMSessionFetcherTestResponse response) {
  135. XCTAssertFalse([fetcher.authorizer isAuthorizingRequest:fetcher.request]);
  136. NSHTTPURLResponse *httpResponse =
  137. [[NSHTTPURLResponse alloc] initWithURL:fetcher.request.URL
  138. statusCode:200
  139. HTTPVersion:kHTTPVersion
  140. headerFields:nil];
  141. response(httpResponse, nil, nil);
  142. };
  143. [self.fetcher
  144. beginFetchWithCompletionHandler:^(NSData *_Nullable data, NSError *_Nullable error) {
  145. [expectation fulfill];
  146. }];
  147. [FIRStorageTestHelpers waitForExpectation:self];
  148. }
  149. - (void)testStopAuthorizingNoop {
  150. XCTestExpectation *expectation = [self expectationWithDescription:@"testStopAuthorizingNoop"];
  151. self.fetcher.testBlock = ^(GTMSessionFetcher *fetcher, GTMSessionFetcherTestResponse response) {
  152. // Since both of these are noops, we expect that invoking them
  153. // will still result in successful authentication
  154. [fetcher.authorizer stopAuthorization];
  155. [fetcher.authorizer stopAuthorizationForRequest:fetcher.request];
  156. NSHTTPURLResponse *httpResponse =
  157. [[NSHTTPURLResponse alloc] initWithURL:fetcher.request.URL
  158. statusCode:200
  159. HTTPVersion:kHTTPVersion
  160. headerFields:nil];
  161. response(httpResponse, nil, nil);
  162. };
  163. [self.fetcher beginFetchWithCompletionHandler:^(NSData *_Nullable data,
  164. NSError *_Nullable error) {
  165. NSDictionary<NSString *, NSString *> *headers = self.fetcher.request.allHTTPHeaderFields;
  166. NSString *authHeader = [headers objectForKey:@"Authorization"];
  167. NSString *firebaseToken =
  168. [NSString stringWithFormat:kFIRStorageAuthTokenFormat, kFIRStorageTestAuthToken];
  169. XCTAssertEqualObjects(authHeader, firebaseToken);
  170. [expectation fulfill];
  171. }];
  172. [FIRStorageTestHelpers waitForExpectation:self];
  173. }
  174. - (void)testEmail {
  175. XCTestExpectation *expectation = [self expectationWithDescription:@"testEmail"];
  176. self.fetcher.testBlock = ^(GTMSessionFetcher *fetcher, GTMSessionFetcherTestResponse response) {
  177. XCTAssertNil([fetcher.authorizer userEmail]);
  178. NSHTTPURLResponse *httpResponse =
  179. [[NSHTTPURLResponse alloc] initWithURL:fetcher.request.URL
  180. statusCode:200
  181. HTTPVersion:kHTTPVersion
  182. headerFields:nil];
  183. response(httpResponse, nil, nil);
  184. };
  185. [self.fetcher
  186. beginFetchWithCompletionHandler:^(NSData *_Nullable data, NSError *_Nullable error) {
  187. [expectation fulfill];
  188. }];
  189. [FIRStorageTestHelpers waitForExpectation:self];
  190. }
  191. @end