From 2ada1f50eeb53d0f1bab5a5daf888440be97d25e Mon Sep 17 00:00:00 2001 From: Antonis Lilis Date: Fri, 15 Mar 2024 16:23:14 +0200 Subject: [PATCH] Checks for null email and account --- .../unified/UnrepliedCommentsUtils.kt | 10 +- .../unified/UnrepliedCommentsUtilsTest.kt | 118 ++++++++++++++++++ 2 files changed, 123 insertions(+), 5 deletions(-) create mode 100644 WordPress/src/test/java/org/wordpress/android/ui/comments/unified/UnrepliedCommentsUtilsTest.kt diff --git a/WordPress/src/main/java/org/wordpress/android/ui/comments/unified/UnrepliedCommentsUtils.kt b/WordPress/src/main/java/org/wordpress/android/ui/comments/unified/UnrepliedCommentsUtils.kt index 6bf811ae637f..4c8cdfb89b94 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/comments/unified/UnrepliedCommentsUtils.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/comments/unified/UnrepliedCommentsUtils.kt @@ -40,17 +40,17 @@ class UnrepliedCommentsUtils @Inject constructor( return topLevelComments } - private fun isMyComment(comment: CommentEntity): Boolean { - val myEmail: String + fun isMyComment(comment: CommentEntity): Boolean { + val myEmail: String? val selectedSite = selectedSiteRepository.getSelectedSite() ?: return false // if site is self hosted, we want to use email associate with it, even if we are logged into wpcom myEmail = if (!selectedSite.isUsingWpComRestApi) { selectedSite.email } else { - val account: AccountModel = accountStore.account - account.email + val account: AccountModel? = accountStore.account + account?.email } - return comment.authorEmail == myEmail + return myEmail != null && comment.authorEmail == myEmail } } diff --git a/WordPress/src/test/java/org/wordpress/android/ui/comments/unified/UnrepliedCommentsUtilsTest.kt b/WordPress/src/test/java/org/wordpress/android/ui/comments/unified/UnrepliedCommentsUtilsTest.kt new file mode 100644 index 000000000000..7bfca6d0dd0a --- /dev/null +++ b/WordPress/src/test/java/org/wordpress/android/ui/comments/unified/UnrepliedCommentsUtilsTest.kt @@ -0,0 +1,118 @@ +package org.wordpress.android.ui.comments.unified + +import kotlinx.coroutines.ExperimentalCoroutinesApi +import org.junit.Assert.assertFalse +import org.junit.Before +import org.junit.Test +import org.junit.runner.RunWith +import org.mockito.Mock +import org.mockito.Mockito.mock +import org.mockito.junit.MockitoJUnitRunner +import org.mockito.kotlin.whenever +import org.wordpress.android.BaseUnitTest +import org.wordpress.android.fluxc.model.AccountModel +import org.wordpress.android.fluxc.model.SiteModel +import org.wordpress.android.fluxc.persistence.comments.CommentsDao.CommentEntity +import org.wordpress.android.fluxc.store.AccountStore +import org.wordpress.android.ui.mysite.SelectedSiteRepository +import kotlin.test.assertTrue + +@ExperimentalCoroutinesApi +@RunWith(MockitoJUnitRunner::class) +class UnrepliedCommentsUtilsTest : BaseUnitTest() { + @Mock + private lateinit var accountStore: AccountStore + + @Mock + private lateinit var selectedSiteRepository: SelectedSiteRepository + + private lateinit var utils: UnrepliedCommentsUtils + + @Before + fun setup() { + utils = UnrepliedCommentsUtils(accountStore, selectedSiteRepository) + } + + @Test + fun `WHEN the selected site cannot be retrieved THEN return false`() { + val comment: CommentEntity = mock() + whenever(selectedSiteRepository.getSelectedSite()).thenReturn(null) + + val result = utils.isMyComment(comment) + + assertFalse(result) + } + + @Test + fun `WHEN a comment's author email matches a non-wpcom site's email THEN return true`() { + val authorEmail = "author@email.com" + val comment: CommentEntity = mock() + val site: SiteModel = mock() + whenever(comment.authorEmail).thenReturn(authorEmail) + whenever(selectedSiteRepository.getSelectedSite()).thenReturn(site) + whenever(site.isUsingWpComRestApi).thenReturn(false) + whenever(site.email).thenReturn(authorEmail) + + val result = utils.isMyComment(comment) + + assertTrue(result) + } + + @Test + fun `WHEN a non-wpcom site's email is null THEN return false`() { + val comment: CommentEntity = mock() + val site: SiteModel = mock() + whenever(selectedSiteRepository.getSelectedSite()).thenReturn(site) + whenever(site.isUsingWpComRestApi).thenReturn(false) + whenever(site.email).thenReturn(null) + + val result = utils.isMyComment(comment) + + assertFalse(result) + } + + @Test + fun `WHEN a comment's author email matches a wpcom account email THEN return true`() { + val authorEmail = "author@email.com" + val comment: CommentEntity = mock() + val site: SiteModel = mock() + val account: AccountModel = mock() + whenever(comment.authorEmail).thenReturn(authorEmail) + whenever(selectedSiteRepository.getSelectedSite()).thenReturn(site) + whenever(site.isUsingWpComRestApi).thenReturn(true) + whenever(accountStore.account).thenReturn(account) + whenever(account.email).thenReturn(authorEmail) + + val result = utils.isMyComment(comment) + + assertTrue(result) + } + + @Test + fun `WHEN a wpcom account fails to be retrieved THEN return false`() { + val comment: CommentEntity = mock() + val site: SiteModel = mock() + whenever(selectedSiteRepository.getSelectedSite()).thenReturn(site) + whenever(site.isUsingWpComRestApi).thenReturn(true) + whenever(accountStore.account).thenReturn(null) + + val result = utils.isMyComment(comment) + + assertFalse(result) + } + + @Test + fun `WHEN a wpcom account email is null THEN return false`() { + val comment: CommentEntity = mock() + val site: SiteModel = mock() + val account: AccountModel = mock() + whenever(selectedSiteRepository.getSelectedSite()).thenReturn(site) + whenever(site.isUsingWpComRestApi).thenReturn(true) + whenever(accountStore.account).thenReturn(account) + whenever(account.email).thenReturn(null) + + val result = utils.isMyComment(comment) + + assertFalse(result) + } +}