summaryrefslogtreecommitdiffstats
path: root/apps/comments/tests
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2018-11-08 11:54:41 +0100
committerJoas Schilling <coding@schilljs.com>2018-11-08 12:10:09 +0100
commit1b4f1b9a63ef9278fbf84d67878c6a483c76e50d (patch)
tree240935fdbadb810d25194b4acca344b4457080d0 /apps/comments/tests
parent78fd8ab0fd362fd5d568dfc5b47a02158e62d51c (diff)
downloadnextcloud-server-1b4f1b9a63ef9278fbf84d67878c6a483c76e50d.tar.gz
nextcloud-server-1b4f1b9a63ef9278fbf84d67878c6a483c76e50d.zip
Populate the mention-notification with the actual message
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'apps/comments/tests')
-rw-r--r--apps/comments/tests/Unit/Notification/NotifierTest.php79
1 files changed, 71 insertions, 8 deletions
diff --git a/apps/comments/tests/Unit/Notification/NotifierTest.php b/apps/comments/tests/Unit/Notification/NotifierTest.php
index 07dcbfdd849..6eceed44919 100644
--- a/apps/comments/tests/Unit/Notification/NotifierTest.php
+++ b/apps/comments/tests/Unit/Notification/NotifierTest.php
@@ -93,13 +93,15 @@ class NotifierTest extends TestCase {
public function testPrepareSuccess() {
$fileName = 'Gre\'thor.odp';
$displayName = 'Huraga';
- $message = 'Huraga mentioned you in a comment on “Gre\'thor.odp”';
+ $message = '@Huraga mentioned you in a comment on “Gre\'thor.odp”';
/** @var IUser|\PHPUnit_Framework_MockObject_MockObject $user */
$user = $this->createMock(IUser::class);
$user->expects($this->once())
->method('getDisplayName')
->willReturn($displayName);
+ /** @var IUser|\PHPUnit_Framework_MockObject_MockObject $you */
+ $you = $this->createMock(IUser::class);
/** @var Node|\PHPUnit_Framework_MockObject_MockObject $node */
$node = $this->createMock(Node::class);
@@ -107,6 +109,10 @@ class NotifierTest extends TestCase {
->expects($this->atLeastOnce())
->method('getName')
->willReturn($fileName);
+ $node
+ ->expects($this->atLeastOnce())
+ ->method('getPath')
+ ->willReturn('/you/files/' . $fileName);
$userFolder = $this->createMock(Folder::class);
$this->folder->expects($this->once())
@@ -118,7 +124,7 @@ class NotifierTest extends TestCase {
->with('678')
->willReturn([$node]);
- $this->notification->expects($this->once())
+ $this->notification->expects($this->exactly(2))
->method('getUser')
->willReturn('you');
$this->notification
@@ -145,6 +151,16 @@ class NotifierTest extends TestCase {
->willReturnSelf();
$this->notification
->expects($this->once())
+ ->method('setRichMessage')
+ ->with('Hi {mention-user1}!', ['mention-user1' => ['type' => 'user', 'id' => 'you', 'name' => 'Your name']])
+ ->willReturnSelf();
+ $this->notification
+ ->expects($this->once())
+ ->method('setParsedMessage')
+ ->with('Hi @Your name!')
+ ->willReturnSelf();
+ $this->notification
+ ->expects($this->once())
->method('setIcon')
->with('absolute-image-path')
->willReturnSelf();
@@ -171,17 +187,32 @@ class NotifierTest extends TestCase {
->expects($this->any())
->method('getActorType')
->willReturn('users');
+ $this->comment
+ ->expects($this->any())
+ ->method('getMessage')
+ ->willReturn('Hi @you!');
+ $this->comment
+ ->expects($this->any())
+ ->method('getMentions')
+ ->willReturn([['type' => 'user', 'id' => 'you']]);
$this->commentsManager
->expects($this->once())
->method('get')
->willReturn($this->comment);
+ $this->commentsManager
+ ->expects($this->once())
+ ->method('resolveDisplayName')
+ ->with('user', 'you')
+ ->willReturn('Your name');
$this->userManager
- ->expects($this->once())
+ ->expects($this->exactly(2))
->method('get')
- ->with('huraga')
- ->willReturn($user);
+ ->willReturnMap([
+ ['huraga', $user],
+ ['you', $you],
+ ]);
$this->notifier->prepare($this->notification, $this->lc);
}
@@ -190,12 +221,19 @@ class NotifierTest extends TestCase {
$fileName = 'Gre\'thor.odp';
$message = 'You were mentioned on “Gre\'thor.odp”, in a comment by a user that has since been deleted';
+ /** @var IUser|\PHPUnit_Framework_MockObject_MockObject $you */
+ $you = $this->createMock(IUser::class);
+
/** @var Node|\PHPUnit_Framework_MockObject_MockObject $node */
$node = $this->createMock(Node::class);
$node
->expects($this->atLeastOnce())
->method('getName')
->willReturn($fileName);
+ $node
+ ->expects($this->atLeastOnce())
+ ->method('getPath')
+ ->willReturn('/you/files/' . $fileName);
$userFolder = $this->createMock(Folder::class);
$this->folder->expects($this->once())
@@ -207,7 +245,7 @@ class NotifierTest extends TestCase {
->with('678')
->willReturn([$node]);
- $this->notification->expects($this->once())
+ $this->notification->expects($this->exactly(2))
->method('getUser')
->willReturn('you');
$this->notification
@@ -234,6 +272,16 @@ class NotifierTest extends TestCase {
->willReturnSelf();
$this->notification
->expects($this->once())
+ ->method('setRichMessage')
+ ->with('Hi {mention-user1}!', ['mention-user1' => ['type' => 'user', 'id' => 'you', 'name' => 'Your name']])
+ ->willReturnSelf();
+ $this->notification
+ ->expects($this->once())
+ ->method('setParsedMessage')
+ ->with('Hi @Your name!')
+ ->willReturnSelf();
+ $this->notification
+ ->expects($this->once())
->method('setIcon')
->with('absolute-image-path')
->willReturnSelf();
@@ -260,15 +308,30 @@ class NotifierTest extends TestCase {
->expects($this->any())
->method('getActorType')
->willReturn(ICommentsManager::DELETED_USER);
+ $this->comment
+ ->expects($this->any())
+ ->method('getMessage')
+ ->willReturn('Hi @you!');
+ $this->comment
+ ->expects($this->any())
+ ->method('getMentions')
+ ->willReturn([['type' => 'user', 'id' => 'you']]);
$this->commentsManager
->expects($this->once())
->method('get')
->willReturn($this->comment);
+ $this->commentsManager
+ ->expects($this->once())
+ ->method('resolveDisplayName')
+ ->with('user', 'you')
+ ->willReturn('Your name');
$this->userManager
- ->expects($this->never())
- ->method('get');
+ ->expects($this->once())
+ ->method('get')
+ ->with('you')
+ ->willReturn($you);
$this->notifier->prepare($this->notification, $this->lc);
}