From 8c00aa65da7ce633b33ba0b81ec38ae13a14cadd Mon Sep 17 00:00:00 2001 From: Amine Date: Tue, 31 Dec 2024 15:23:26 +0100 Subject: [PATCH] test: items displaying. --- .../readerforselfossv2/android/CommonTests.kt | 20 +++++ .../android/HomeActivityTest.kt | 31 ++------ .../android/SettingsActivityTest.kt | 6 +- .../android/SourcesActivityTest.kt | 74 ++++++++++++------- .../readerforselfossv2/android/helpers.kt | 9 +++ 5 files changed, 83 insertions(+), 57 deletions(-) diff --git a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/CommonTests.kt b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/CommonTests.kt index 3a233d2..b0e4cad 100644 --- a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/CommonTests.kt +++ b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/CommonTests.kt @@ -2,6 +2,7 @@ package bou.amine.apps.readerforselfossv2.android import android.content.Context import androidx.annotation.ArrayRes +import androidx.test.espresso.Espresso.onData import androidx.test.espresso.Espresso.onView import androidx.test.espresso.action.ViewActions.click import androidx.test.espresso.action.ViewActions.replaceText @@ -14,6 +15,7 @@ import androidx.test.espresso.matcher.ViewMatchers.isNotChecked import androidx.test.espresso.matcher.ViewMatchers.withId import androidx.test.espresso.matcher.ViewMatchers.withText import org.hamcrest.CoreMatchers.allOf +import org.hamcrest.Matchers.hasToString fun performLogin(someUrl: String? = null) { onView(withId(R.id.urlView)).perform(click()).perform( @@ -86,4 +88,22 @@ fun testPreferencesFromArray( openSettingItem() onView(withText(res)).check(matches(allOf(isDisplayed(), isChecked()))) } +} + +fun testAddSourceWithUrl(url: String, sourceName: String) { + onView(withId(R.id.fab)) + .perform(click()) + onView(withId(R.id.nameInput)) + .perform(click()).perform(typeTextIntoFocusedView(sourceName)) + onView(withId(R.id.sourceUri)) + .perform(click()) + .perform(typeTextIntoFocusedView(url)) + onView(withId(R.id.tags)) + .perform(click()).perform(typeTextIntoFocusedView("tag1,tag2,tag3")) + onView(withId(R.id.spoutsSpinner)) + .perform(click()) + onData(hasToString("RSS Feed")).perform(click()) + onView(withId(R.id.saveBtn)) + .perform(click()) + onView(withText(sourceName)).check(matches(isDisplayed())) } \ No newline at end of file diff --git a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/HomeActivityTest.kt b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/HomeActivityTest.kt index e95b84c..eb76219 100644 --- a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/HomeActivityTest.kt +++ b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/HomeActivityTest.kt @@ -1,9 +1,6 @@ package bou.amine.apps.readerforselfossv2.android -import android.content.Context -import androidx.test.core.app.ApplicationProvider import androidx.test.espresso.Espresso.onView -import androidx.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu import androidx.test.espresso.action.ViewActions import androidx.test.espresso.action.ViewActions.click import androidx.test.espresso.assertion.ViewAssertions.matches @@ -47,9 +44,7 @@ class HomeActivityTest { isClickable() ) ) - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - ) + openMenu() onView(withText(R.string.readAll)).check(matches(isDisplayed())) onView(withText(R.string.menu_home_sources)).check(matches(isDisplayed())) onView(withText(R.string.title_activity_settings)).check(matches(isDisplayed())) @@ -78,43 +73,31 @@ class HomeActivityTest { ).check(matches(isDisplayed())) onView(isRoot()).perform(ViewActions.pressBack()) - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - ) + openMenu() onView(withText(R.string.readAll)).perform(click()) onView(withText(R.string.markall_dialog_message)).check(matches(isDisplayed())) onView(isRoot()).perform(ViewActions.pressBack()) - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - ) + openMenu() onView(withText(R.string.menu_home_sources)).perform(click()) onView(withId(R.id.fab)).check(matches(isDisplayed())) onView(isRoot()).perform(ViewActions.pressBack()) - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - ) + openMenu() onView(withText(R.string.title_activity_settings)).perform(click()) onView(withText(R.string.pref_header_general)).check(matches(isDisplayed())) onView(isRoot()).perform(ViewActions.pressBack()) - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - ) + openMenu() onView(withText(R.string.menu_home_refresh)).perform(click()) onView(withText(R.string.refresh_dialog_message)).check(matches(isDisplayed())) onView(isRoot()).perform(ViewActions.pressBack()) - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - ) + openMenu() /*onView(withText(R.string.issue_tracker_link)).perform(click()) onView(withText(R.string.markall_dialog_message)).check(matches(isDisplayed())) onView(isRoot()).perform(ViewActions.pressBack()) - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - )*/ + openMenu()*/ onView(withText(R.string.action_disconnect)).perform(click()) onView(withText(R.string.confirm_disconnect_title)).check(matches(isDisplayed())) diff --git a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/SettingsActivityTest.kt b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/SettingsActivityTest.kt index 202301d..69101c6 100644 --- a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/SettingsActivityTest.kt +++ b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/SettingsActivityTest.kt @@ -1,9 +1,7 @@ package bou.amine.apps.readerforselfossv2.android import android.content.Context -import androidx.test.core.app.ApplicationProvider import androidx.test.espresso.Espresso.onView -import androidx.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu import androidx.test.espresso.action.ViewActions.click import androidx.test.espresso.assertion.ViewAssertions.matches import androidx.test.espresso.matcher.ViewMatchers.isDisplayed @@ -33,9 +31,7 @@ class SettingsActivityTest { context = activity.window.context } loginAndInitHome() - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - ) + openMenu() onView(withText(R.string.title_activity_settings)).perform(click()) } diff --git a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/SourcesActivityTest.kt b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/SourcesActivityTest.kt index 8a3088b..f7e0a57 100644 --- a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/SourcesActivityTest.kt +++ b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/SourcesActivityTest.kt @@ -1,19 +1,20 @@ package bou.amine.apps.readerforselfossv2.android -import android.content.Context -import androidx.test.core.app.ApplicationProvider +import androidx.test.espresso.AmbiguousViewMatcherException import androidx.test.espresso.Espresso.onView -import androidx.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu +import androidx.test.espresso.action.ViewActions import androidx.test.espresso.action.ViewActions.click -import androidx.test.espresso.action.ViewActions.scrollCompletelyTo -import androidx.test.espresso.action.ViewActions.typeTextIntoFocusedView +import androidx.test.espresso.action.ViewActions.swipeDown +import androidx.test.espresso.assertion.ViewAssertions.doesNotExist import androidx.test.espresso.assertion.ViewAssertions.matches import androidx.test.espresso.matcher.ViewMatchers.isDisplayed +import androidx.test.espresso.matcher.ViewMatchers.isRoot import androidx.test.espresso.matcher.ViewMatchers.withId import androidx.test.espresso.matcher.ViewMatchers.withText import androidx.test.ext.junit.rules.ActivityScenarioRule import androidx.test.ext.junit.runners.AndroidJUnit4 import androidx.test.filters.LargeTest +import org.junit.After import org.junit.Before import org.junit.Rule import org.junit.Test @@ -23,7 +24,6 @@ import java.util.UUID @RunWith(AndroidJUnit4::class) @LargeTest class SourcesActivityTest { - @get:Rule val activityRule = ActivityScenarioRule(LoginActivity::class.java) @@ -34,32 +34,50 @@ class SourcesActivityTest { sourceName = UUID.randomUUID().toString().substring(0, 15) loginAndInitHome() - openActionBarOverflowOrOptionsMenu( - ApplicationProvider.getApplicationContext() - ) - onView(withText(R.string.menu_home_sources)) - .perform(click()) + goToSources() } @Test fun addSource() { - onView(withId(R.id.fab)) - .perform(click()) - onView(withId(R.id.nameInput)) - .perform(click()).perform(typeTextIntoFocusedView(sourceName)) - onView(withId(R.id.sourceUri)) - .perform(click()) - .perform(typeTextIntoFocusedView("https://lorem-rss.herokuapp.com/feed?unit=year&interval=1&length=10")) - onView(withId(R.id.tags)) - .perform(click()).perform(typeTextIntoFocusedView("tag1,tag2,tag3")) - onView(withId(R.id.spoutsSpinner)) - .perform(click()) - onView(withText("RSS Feed")) - .perform(scrollCompletelyTo()) - .perform(click()) - onView(withId(R.id.saveBtn)) - .perform(click()) - onView(withText(sourceName)).check(matches(isDisplayed())) + testAddSourceWithUrl( + "https://lorem-rss.herokuapp.com/feed?unit=year&interval=1&length=10", + sourceName + ) } + + @Test + fun addSourceCheckContent() { + testAddSourceWithUrl("https://news.google.com/rss?hl=en-US&gl=US&ceid=US:en", sourceName) + onView(isRoot()).perform(ViewActions.pressBack()) + openMenu() + onView(withText(R.string.menu_home_refresh)).perform(click()) + onView(withText(R.string.refresh_dialog_message)).check(matches(isDisplayed())) + onView( + withId(android.R.id.button1) + ).perform(click()) + Thread.sleep(10000) + onView(withId(R.id.swipeRefreshLayout)).perform(swipeDown()) + Thread.sleep(2000) + try { + onView(withId(R.id.sourceTitleAndDate)).check(matches(isDisplayed())) + } catch (e: AmbiguousViewMatcherException) { + assert(true) + } + goToSources() + } + + @After + fun deleteTheCreatedSource() { + onView(withText(sourceName)).check(matches(isDisplayed())) + onView(withId(R.id.deleteBtn)).perform(click()) + onView(withText(sourceName)).check(doesNotExist()) + } + + + private fun goToSources() { + openMenu() + onView(withText(R.string.menu_home_sources)) + .perform(click()) + } } \ No newline at end of file diff --git a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/helpers.kt b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/helpers.kt index 60c300f..ecca84b 100644 --- a/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/helpers.kt +++ b/androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/helpers.kt @@ -1,5 +1,6 @@ package bou.amine.apps.readerforselfossv2.android +import android.content.Context import android.view.View import android.widget.EditText import android.widget.ImageView @@ -7,6 +8,8 @@ import android.widget.RelativeLayout import androidx.annotation.DrawableRes import androidx.annotation.StringRes import androidx.core.graphics.drawable.toBitmap +import androidx.test.core.app.ApplicationProvider +import androidx.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu import androidx.test.espresso.Root import androidx.test.espresso.matcher.RootMatchers.isPlatformPopup import androidx.test.espresso.matcher.ViewMatchers.hasSibling @@ -98,4 +101,10 @@ fun withSettingsCheckboxFrame(@StringRes id: Int): Matcher? { ) ) ) +} + +fun openMenu() { + openActionBarOverflowOrOptionsMenu( + ApplicationProvider.getApplicationContext() + ) } \ No newline at end of file