Skip to content

Commit

Permalink
Fix
Browse files Browse the repository at this point in the history
Signed-off-by: alperozturk <[email protected]>
  • Loading branch information
alperozturk96 authored and tobiasKaminsky committed Aug 23, 2024
1 parent 27d2970 commit 2c72af7
Showing 1 changed file with 91 additions and 62 deletions.
153 changes: 91 additions & 62 deletions app/src/androidTest/java/com/nextcloud/client/ActivitiesActivityIT.kt
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,15 @@
package com.nextcloud.client

import android.view.View
import androidx.test.espresso.Espresso
import androidx.annotation.UiThread
import androidx.test.core.app.launchActivity
import androidx.test.espresso.Espresso.onView
import androidx.test.espresso.IdlingRegistry
import androidx.test.espresso.assertion.ViewAssertions.matches
import androidx.test.espresso.contrib.DrawerActions
import androidx.test.espresso.intent.rule.IntentsTestRule
import androidx.test.espresso.matcher.ViewMatchers.isDisplayed
import androidx.test.espresso.matcher.ViewMatchers.isRoot
import androidx.test.espresso.matcher.ViewMatchers.withId
import com.facebook.testing.screenshot.Screenshot
import com.owncloud.android.AbstractIT
import com.owncloud.android.R
import com.owncloud.android.lib.resources.activities.model.Activity
Expand All @@ -21,74 +25,95 @@ import com.owncloud.android.lib.resources.activities.model.RichObject
import com.owncloud.android.lib.resources.activities.models.PreviewObject
import com.owncloud.android.lib.resources.status.OCCapability
import com.owncloud.android.ui.activities.ActivitiesActivity
import com.owncloud.android.utils.EspressoIdlingResource
import com.owncloud.android.utils.ScreenshotTest
import org.junit.Rule
import org.junit.After
import org.junit.Before
import org.junit.Test
import java.util.GregorianCalendar

class ActivitiesActivityIT : AbstractIT() {
@get:Rule
var activityRule = IntentsTestRule(ActivitiesActivity::class.java, true, false)
private val testClassName = "com.nextcloud.client.ActivitiesActivityIT"

@Before
fun registerIdlingResource() {
IdlingRegistry.getInstance().register(EspressoIdlingResource.countingIdlingResource)
}

@After
fun unregisterIdlingResource() {
IdlingRegistry.getInstance().unregister(EspressoIdlingResource.countingIdlingResource)
}

@Test
@UiThread
@ScreenshotTest
fun openDrawer() {
val sut = activityRule.launchActivity(null)
shortSleep()
Espresso.onView(withId(R.id.drawer_layout)).perform(DrawerActions.open())
sut.runOnUiThread {
sut.dismissSnackbar()
launchActivity<ActivitiesActivity>().use { scenario ->
scenario.onActivity { sut ->
onIdleSync {
EspressoIdlingResource.increment()
onView(withId(R.id.drawer_layout)).perform(DrawerActions.open())
sut.dismissSnackbar()
EspressoIdlingResource.decrement()
val screenShotName = createName(testClassName + "_" + "openDrawer", "")
onView(isRoot()).check(matches(isDisplayed()))
screenshotViaName(sut, screenShotName)
}
}
}
shortSleep()
waitForIdleSync()
screenshot(sut)
}

@Test
@UiThread
@ScreenshotTest
fun loading() {
val sut: ActivitiesActivity = activityRule.launchActivity(null).apply {
runOnUiThread {
dismissSnackbar()
binding.emptyList.root.visibility = View.GONE
binding.swipeContainingList.visibility = View.GONE
binding.loadingContent.visibility = View.VISIBLE
launchActivity<ActivitiesActivity>().use { scenario ->
scenario.onActivity { sut ->
onIdleSync {
EspressoIdlingResource.increment()
sut.dismissSnackbar()
sut.binding.emptyList.root.visibility = View.GONE
sut.binding.swipeContainingList.visibility = View.GONE
sut.binding.loadingContent.visibility = View.VISIBLE
EspressoIdlingResource.decrement()
val screenShotName = createName(testClassName + "_" + "loading", "")
onView(isRoot()).check(matches(isDisplayed()))
screenshotViaName(sut, screenShotName)
}
}
}

shortSleep()
waitForIdleSync()

Screenshot.snap(sut.binding.loadingContent).record()
}

@Test
@UiThread
@ScreenshotTest
fun empty() {
val sut: ActivitiesActivity = activityRule.launchActivity(null)

sut.runOnUiThread {
sut.showActivities(mutableListOf(), nextcloudClient, -1)
sut.setProgressIndicatorState(false)
sut.dismissSnackbar()
launchActivity<ActivitiesActivity>().use { scenario ->
scenario.onActivity { sut ->
onIdleSync {
EspressoIdlingResource.increment()
sut.showActivities(mutableListOf(), nextcloudClient, -1)
sut.setProgressIndicatorState(false)
sut.dismissSnackbar()
EspressoIdlingResource.decrement()
val screenShotName = createName(testClassName + "_" + "empty", "")
onView(isRoot()).check(matches(isDisplayed()))
screenshotViaName(sut, screenShotName)
}
}
}

shortSleep()
waitForIdleSync()

screenshot(sut)
}

@Test
@UiThread
@ScreenshotTest
@SuppressWarnings("MagicNumber")
fun showActivities() {
val capability = OCCapability()
capability.versionMayor = 20
fileDataStorageManager.saveCapabilities(capability)

val sut: ActivitiesActivity = activityRule.launchActivity(null)

val date = GregorianCalendar()
date.set(2005, 4, 17, 10, 35, 30) // random date

Expand Down Expand Up @@ -136,7 +161,7 @@ class ActivitiesActivityIT : AbstractIT() {
"calendar",
"35",
"",
ArrayList<PreviewObject>(),
ArrayList(),
RichElement()
),
Activity(
Expand All @@ -159,35 +184,39 @@ class ActivitiesActivityIT : AbstractIT() {
)
)

sut.runOnUiThread {
sut.showActivities(activities as List<Any>?, nextcloudClient, -1)
sut.setProgressIndicatorState(false)
sut.dismissSnackbar()
launchActivity<ActivitiesActivity>().use { scenario ->
scenario.onActivity { sut ->
onIdleSync {
EspressoIdlingResource.increment()
sut.showActivities(activities as List<Any>?, nextcloudClient, -1)
sut.setProgressIndicatorState(false)
sut.dismissSnackbar()
EspressoIdlingResource.decrement()
val screenShotName = createName(testClassName + "_" + "showActivities", "")
onView(isRoot()).check(matches(isDisplayed()))
screenshotViaName(sut, screenShotName)
}
}
}

longSleep()
waitForIdleSync()

screenshot(sut)
}

@Test
@UiThread
@ScreenshotTest
fun error() {
val sut: ActivitiesActivity = activityRule.launchActivity(null)

shortSleep()

sut.runOnUiThread {
sut.showEmptyContent("Error", "Error! Please try again later!")
sut.setProgressIndicatorState(false)
sut.dismissSnackbar()
launchActivity<ActivitiesActivity>().use { scenario ->
scenario.onActivity { sut ->
onIdleSync {
EspressoIdlingResource.increment()
sut.showEmptyContent("Error", "Error! Please try again later!")
sut.setProgressIndicatorState(false)
sut.dismissSnackbar()
EspressoIdlingResource.decrement()
val screenShotName = createName(testClassName + "_" + "error", "")
onView(isRoot()).check(matches(isDisplayed()))
screenshotViaName(sut, screenShotName)
}
}
}

shortSleep()
shortSleep()
waitForIdleSync()

screenshot(sut)
}
}

0 comments on commit 2c72af7

Please sign in to comment.