|
|
|
@ -1,12 +1,12 @@
|
|
|
|
|
//
|
|
|
|
|
// Copyright (c) 2017 Open Whisper Systems. All rights reserved.
|
|
|
|
|
// Copyright (c) 2018 Open Whisper Systems. All rights reserved.
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
#import "NSDate+millisecondTimeStamp.h"
|
|
|
|
|
#import "NSDate+OWS.h"
|
|
|
|
|
#import "OWSDisappearingMessagesFinder.h"
|
|
|
|
|
#import "OWSPrimaryStorage.h"
|
|
|
|
|
#import "TSContactThread.h"
|
|
|
|
|
#import "TSMessage.h"
|
|
|
|
|
#import "TSStorageManager.h"
|
|
|
|
|
#import <XCTest/XCTest.h>
|
|
|
|
|
|
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
@ -24,7 +24,7 @@ NS_ASSUME_NONNULL_BEGIN
|
|
|
|
|
|
|
|
|
|
@property YapDatabaseConnection *dbConnection;
|
|
|
|
|
@property OWSDisappearingMessagesFinder *finder;
|
|
|
|
|
@property TSStorageManager *storageManager;
|
|
|
|
|
@property OWSPrimaryStorage *storageManager;
|
|
|
|
|
@property TSThread *thread;
|
|
|
|
|
@property uint64_t now;
|
|
|
|
|
|
|
|
|
@ -37,7 +37,7 @@ NS_ASSUME_NONNULL_BEGIN
|
|
|
|
|
[super setUp];
|
|
|
|
|
[TSMessage removeAllObjectsInCollection];
|
|
|
|
|
|
|
|
|
|
self.storageManager = [TSStorageManager sharedManager];
|
|
|
|
|
self.storageManager = [OWSPrimaryStorage sharedManager];
|
|
|
|
|
self.dbConnection = self.storageManager.newDatabaseConnection;
|
|
|
|
|
self.thread = [TSContactThread getOrCreateThreadWithContactId:@"fake-thread-id"];
|
|
|
|
|
|
|
|
|
@ -48,50 +48,44 @@ NS_ASSUME_NONNULL_BEGIN
|
|
|
|
|
[OWSDisappearingMessagesFinder blockingRegisterDatabaseExtensions:self.storageManager];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
- (TSMessage *)messageWithBody:(NSString *)body
|
|
|
|
|
expiresInSeconds:(uint32_t)expiresInSeconds
|
|
|
|
|
expireStartedAt:(uint64_t)expireStartedAt
|
|
|
|
|
{
|
|
|
|
|
return [[TSMessage alloc] initMessageWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:body
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:expiresInSeconds
|
|
|
|
|
expireStartedAt:expireStartedAt
|
|
|
|
|
quotedMessage:nil
|
|
|
|
|
contactShare:nil];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
- (void)testExpiredMessages
|
|
|
|
|
{
|
|
|
|
|
TSMessage *expiredMessage1 = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"expiredMessage1"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:1
|
|
|
|
|
expireStartedAt:self.now - 20000];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TSMessage *expiredMessage1 =
|
|
|
|
|
[self messageWithBody:@"expiredMessage1" expiresInSeconds:1 expireStartedAt:self.now - 20000];
|
|
|
|
|
[expiredMessage1 save];
|
|
|
|
|
|
|
|
|
|
TSMessage *expiredMessage2 = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"expiredMessage2"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:2
|
|
|
|
|
expireStartedAt:self.now - 2001];
|
|
|
|
|
TSMessage *expiredMessage2 =
|
|
|
|
|
[self messageWithBody:@"expiredMessage2" expiresInSeconds:2 expireStartedAt:self.now - 2001];
|
|
|
|
|
[expiredMessage2 save];
|
|
|
|
|
|
|
|
|
|
TSMessage *notYetExpiredMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"notYetExpiredMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:20
|
|
|
|
|
expireStartedAt:self.now - 10000];
|
|
|
|
|
TSMessage *notYetExpiredMessage =
|
|
|
|
|
[self messageWithBody:@"notYetExpiredMessage" expiresInSeconds:20 expireStartedAt:self.now - 10000];
|
|
|
|
|
[notYetExpiredMessage save];
|
|
|
|
|
|
|
|
|
|
TSMessage *unreadExpiringMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"unereadExpiringMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:10
|
|
|
|
|
expireStartedAt:0];
|
|
|
|
|
TSMessage *unreadExpiringMessage =
|
|
|
|
|
[self messageWithBody:@"unereadExpiringMessage" expiresInSeconds:10 expireStartedAt:0];
|
|
|
|
|
[unreadExpiringMessage save];
|
|
|
|
|
|
|
|
|
|
TSMessage *unExpiringMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"unexpiringMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:0
|
|
|
|
|
expireStartedAt:0];
|
|
|
|
|
TSMessage *unExpiringMessage = [self messageWithBody:@"unexpiringMessage" expiresInSeconds:0 expireStartedAt:0];
|
|
|
|
|
[unExpiringMessage save];
|
|
|
|
|
|
|
|
|
|
TSMessage *unExpiringMessage2 =
|
|
|
|
|
[[TSMessage alloc] initWithTimestamp:1 inThread:self.thread messageBody:@"unexpiringMessage2"];
|
|
|
|
|
TSMessage *unExpiringMessage2 = [self messageWithBody:@"unexpiringMessage2" expiresInSeconds:0 expireStartedAt:0];
|
|
|
|
|
[unExpiringMessage2 save];
|
|
|
|
|
|
|
|
|
|
__block NSArray<TSMessage *> *actualMessages;
|
|
|
|
@ -105,40 +99,22 @@ NS_ASSUME_NONNULL_BEGIN
|
|
|
|
|
|
|
|
|
|
- (void)testUnstartedExpiredMessagesForThread
|
|
|
|
|
{
|
|
|
|
|
TSMessage *expiredMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"expiredMessage2"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:2
|
|
|
|
|
expireStartedAt:self.now - 2001];
|
|
|
|
|
TSMessage *expiredMessage =
|
|
|
|
|
[self messageWithBody:@"expiredMessage2" expiresInSeconds:2 expireStartedAt:self.now - 2001];
|
|
|
|
|
[expiredMessage save];
|
|
|
|
|
|
|
|
|
|
TSMessage *notYetExpiredMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"notYetExpiredMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:20
|
|
|
|
|
expireStartedAt:self.now - 10000];
|
|
|
|
|
TSMessage *notYetExpiredMessage =
|
|
|
|
|
[self messageWithBody:@"notYetExpiredMessage" expiresInSeconds:20 expireStartedAt:self.now - 10000];
|
|
|
|
|
[notYetExpiredMessage save];
|
|
|
|
|
|
|
|
|
|
TSMessage *unreadExpiringMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"unereadExpiringMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:10
|
|
|
|
|
expireStartedAt:0];
|
|
|
|
|
TSMessage *unreadExpiringMessage =
|
|
|
|
|
[self messageWithBody:@"unereadExpiringMessage" expiresInSeconds:10 expireStartedAt:0];
|
|
|
|
|
[unreadExpiringMessage save];
|
|
|
|
|
|
|
|
|
|
TSMessage *unExpiringMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"unexpiringMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:0
|
|
|
|
|
expireStartedAt:0];
|
|
|
|
|
TSMessage *unExpiringMessage = [self messageWithBody:@"unexpiringMessage" expiresInSeconds:0 expireStartedAt:0];
|
|
|
|
|
[unExpiringMessage save];
|
|
|
|
|
|
|
|
|
|
TSMessage *unExpiringMessage2 =
|
|
|
|
|
[[TSMessage alloc] initWithTimestamp:1 inThread:self.thread messageBody:@"unexpiringMessage2"];
|
|
|
|
|
TSMessage *unExpiringMessage2 = [self messageWithBody:@"unexpiringMessage2" expiresInSeconds:0 expireStartedAt:0];
|
|
|
|
|
[unExpiringMessage2 save];
|
|
|
|
|
|
|
|
|
|
__block NSArray<TSMessage *> *actualMessages;
|
|
|
|
@ -169,40 +145,25 @@ NS_ASSUME_NONNULL_BEGIN
|
|
|
|
|
|
|
|
|
|
XCTAssertNil(self.nextExpirationTimestamp);
|
|
|
|
|
|
|
|
|
|
TSMessage *unExpiringMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"unexpiringMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:0
|
|
|
|
|
expireStartedAt:0];
|
|
|
|
|
TSMessage *unExpiringMessage = [self messageWithBody:@"unexpiringMessage" expiresInSeconds:0 expireStartedAt:0];
|
|
|
|
|
[unExpiringMessage save];
|
|
|
|
|
XCTAssertNil(self.nextExpirationTimestamp);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
- (void)testNextExpirationTimestampNotNilWithUpcomingExpiringMessages
|
|
|
|
|
{
|
|
|
|
|
TSMessage *soonToExpireMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"soonToExpireMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:10
|
|
|
|
|
expireStartedAt:self.now - 9000];
|
|
|
|
|
TSMessage *soonToExpireMessage =
|
|
|
|
|
[self messageWithBody:@"soonToExpireMessage" expiresInSeconds:10 expireStartedAt:self.now - 9000];
|
|
|
|
|
[soonToExpireMessage save];
|
|
|
|
|
|
|
|
|
|
XCTAssertNotNil(self.nextExpirationTimestamp);
|
|
|
|
|
XCTAssertEqual(self.now + 1000, [self.nextExpirationTimestamp unsignedLongLongValue]);
|
|
|
|
|
|
|
|
|
|
// expired message should take precedence
|
|
|
|
|
TSMessage *expiredMessage = [[TSMessage alloc] initWithTimestamp:1
|
|
|
|
|
inThread:self.thread
|
|
|
|
|
messageBody:@"expiredMessage"
|
|
|
|
|
attachmentIds:@[]
|
|
|
|
|
expiresInSeconds:10
|
|
|
|
|
expireStartedAt:self.now - 11000];
|
|
|
|
|
TSMessage *expiredMessage =
|
|
|
|
|
[self messageWithBody:@"expiredMessage" expiresInSeconds:10 expireStartedAt:self.now - 11000];
|
|
|
|
|
[expiredMessage save];
|
|
|
|
|
|
|
|
|
|
//FIXME remove sleep hack in favor of expiringMessage completion handler
|
|
|
|
|
// sleep(2);
|
|
|
|
|
XCTAssertNotNil(self.nextExpirationTimestamp);
|
|
|
|
|
XCTAssertEqual(self.now - 1000, [self.nextExpirationTimestamp unsignedLongLongValue]);
|
|
|
|
|
}
|
|
|
|
|