FIRCLSReportUploaderTests.m 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. // Copyright 2019 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 <XCTest/XCTest.h>
  15. #import "Crashlytics/Crashlytics/Controllers/FIRCLSManagerData.h"
  16. #import "Crashlytics/Crashlytics/Controllers/FIRCLSReportUploader_Private.h"
  17. #import "Crashlytics/Crashlytics/Components/FIRCLSApplication.h"
  18. #import "Crashlytics/Crashlytics/DataCollection/FIRCLSDataCollectionArbiter.h"
  19. #import "Crashlytics/Crashlytics/DataCollection/FIRCLSDataCollectionToken.h"
  20. #import "Crashlytics/Crashlytics/Helpers/FIRCLSDefines.h"
  21. #import "Crashlytics/Crashlytics/Models/FIRCLSFileManager.h"
  22. #import "Crashlytics/Crashlytics/Models/FIRCLSInternalReport.h"
  23. #import "Crashlytics/Crashlytics/Models/FIRCLSSettings.h"
  24. #import "Crashlytics/Shared/FIRCLSConstants.h"
  25. #import "Crashlytics/UnitTests/Mocks/FABMockApplicationIdentifierModel.h"
  26. #import "Crashlytics/UnitTests/Mocks/FIRAppFake.h"
  27. #import "Crashlytics/UnitTests/Mocks/FIRCLSMockSettings.h"
  28. #import "Crashlytics/UnitTests/Mocks/FIRCLSTempMockFileManager.h"
  29. #import "Crashlytics/UnitTests/Mocks/FIRMockGDTCoreTransport.h"
  30. #import "Crashlytics/UnitTests/Mocks/FIRMockInstallations.h"
  31. NSString *const TestEndpoint = @"https://reports.crashlytics.com";
  32. @interface FIRCLSReportUploaderTests : XCTestCase
  33. @property(nonatomic, strong) FIRCLSReportUploader *uploader;
  34. @property(nonatomic, strong) FIRCLSTempMockFileManager *fileManager;
  35. @property(nonatomic, strong) NSOperationQueue *queue;
  36. @property(nonatomic, strong) FIRCLSManagerData *managerData;
  37. // Add mock prefix to names as there are naming conflicts with FIRCLSReportUploaderDelegate
  38. @property(nonatomic, strong) FIRMockGDTCORTransport *mockDataTransport;
  39. @property(nonatomic, strong) FIRCLSMockSettings *mockSettings;
  40. @end
  41. @implementation FIRCLSReportUploaderTests
  42. - (void)setUp {
  43. [super setUp];
  44. FABMockApplicationIdentifierModel *appIDModel = [[FABMockApplicationIdentifierModel alloc] init];
  45. self.queue = [NSOperationQueue new];
  46. self.mockSettings = [[FIRCLSMockSettings alloc] initWithFileManager:self.fileManager
  47. appIDModel:appIDModel];
  48. self.mockDataTransport = [[FIRMockGDTCORTransport alloc] initWithMappingID:@"1206"
  49. transformers:nil
  50. target:kGDTCORTargetCSH];
  51. self.mockDataTransport.sendDataEvent_wasWritten = YES;
  52. self.fileManager = [[FIRCLSTempMockFileManager alloc] init];
  53. id fakeApp = [[FIRAppFake alloc] init];
  54. FIRCLSDataCollectionArbiter *dataArbiter =
  55. [[FIRCLSDataCollectionArbiter alloc] initWithApp:fakeApp withAppInfo:@{}];
  56. FIRMockInstallations *mockInstallations =
  57. [[FIRMockInstallations alloc] initWithFID:@"test_token"];
  58. // Allow nil values only in tests
  59. #pragma clang diagnostic push
  60. #pragma clang diagnostic ignored "-Wnonnull"
  61. self.managerData = [[FIRCLSManagerData alloc] initWithGoogleAppID:@"someGoogleAppId"
  62. googleTransport:self.mockDataTransport
  63. installations:mockInstallations
  64. analytics:nil
  65. fileManager:self.fileManager
  66. dataArbiter:dataArbiter
  67. settings:self.mockSettings
  68. onDemandModel:nil];
  69. #pragma clang diagnostic pop
  70. self.uploader = [[FIRCLSReportUploader alloc] initWithManagerData:_managerData];
  71. }
  72. - (void)tearDown {
  73. self.uploader = nil;
  74. [super tearDown];
  75. }
  76. #pragma mark - Tests
  77. - (void)testPrepareReport {
  78. NSString *path = [self.fileManager.activePath stringByAppendingPathComponent:@"pkg_uuid"];
  79. FIRCLSInternalReport *report = [[FIRCLSInternalReport alloc] initWithPath:path];
  80. self.fileManager.moveItemAtPathResult = [NSNumber numberWithInt:1];
  81. [self.uploader prepareAndSubmitReport:report
  82. dataCollectionToken:FIRCLSDataCollectionToken.validToken
  83. asUrgent:YES
  84. withProcessing:YES];
  85. // Verify with the last move operation is from processing -> prepared
  86. XCTAssertTrue(
  87. [self.fileManager.moveItemAtPath_destDir containsString:self.fileManager.preparedPath]);
  88. }
  89. - (void)testUploadPackagedReportWithPath {
  90. [self runUploadPackagedReportWithUrgency:NO];
  91. }
  92. - (void)testUrgentUploadPackagedReportWithPath {
  93. [self runUploadPackagedReportWithUrgency:YES];
  94. }
  95. - (void)testUrgentWaitUntillUpload {
  96. self.mockDataTransport.async = YES;
  97. [self runUploadPackagedReportWithUrgency:YES];
  98. XCTAssertNotNil(self.mockDataTransport.sendDataEvent_event);
  99. }
  100. - (void)testUrgentWaitUntillUploadWithError {
  101. self.mockDataTransport.async = YES;
  102. self.mockDataTransport.sendDataEvent_error = [[NSError alloc] initWithDomain:@"domain"
  103. code:1
  104. userInfo:nil];
  105. [self.uploader uploadPackagedReportAtPath:[self packagePath]
  106. dataCollectionToken:FIRCLSDataCollectionToken.validToken
  107. asUrgent:YES];
  108. XCTAssertNotNil(self.mockDataTransport.sendDataEvent_event);
  109. }
  110. - (void)testUrgentWaitUntillUploadWithWritingError {
  111. self.mockDataTransport.async = YES;
  112. self.mockDataTransport.sendDataEvent_wasWritten = NO;
  113. [self.uploader uploadPackagedReportAtPath:[self packagePath]
  114. dataCollectionToken:FIRCLSDataCollectionToken.validToken
  115. asUrgent:YES];
  116. XCTAssertNotNil(self.mockDataTransport.sendDataEvent_event);
  117. }
  118. - (void)testUploadPackagedReportWithoutDataCollectionToken {
  119. [self.uploader uploadPackagedReportAtPath:[self packagePath] dataCollectionToken:nil asUrgent:NO];
  120. // Ensure we don't hand off an event to GDT
  121. XCTAssertNil(self.mockDataTransport.sendDataEvent_event);
  122. }
  123. - (void)testUploadPackagedReportNotGDTWritten {
  124. self.mockDataTransport.sendDataEvent_wasWritten = NO;
  125. [self.uploader uploadPackagedReportAtPath:[self packagePath] dataCollectionToken:nil asUrgent:NO];
  126. // Did not delete report
  127. XCTAssertNil(self.fileManager.removedItemAtPath_path);
  128. }
  129. - (void)testUploadPackagedReportGDTError {
  130. self.mockDataTransport.sendDataEvent_error = [[NSError alloc] initWithDomain:@"domain"
  131. code:1
  132. userInfo:nil];
  133. [self.uploader uploadPackagedReportAtPath:[self packagePath] dataCollectionToken:nil asUrgent:NO];
  134. // Did not delete report
  135. XCTAssertNil(self.fileManager.removedItemAtPath_path);
  136. }
  137. #pragma mark - Helper functions
  138. - (NSString *)packagePath {
  139. return [self.fileManager.preparedPath stringByAppendingPathComponent:@"pkg_uuid"];
  140. }
  141. - (void)runUploadPackagedReportWithUrgency:(BOOL)urgent {
  142. [self.uploader uploadPackagedReportAtPath:[self packagePath]
  143. dataCollectionToken:FIRCLSDataCollectionToken.validToken
  144. asUrgent:urgent];
  145. XCTAssertNotNil(self.mockDataTransport.sendDataEvent_event);
  146. XCTAssertEqualObjects(self.fileManager.removedItemAtPath_path, [self packagePath]);
  147. }
  148. @end