This bootcamp serves as an introduction point into the Espresso framework and other testing tools for android.
Bootcamp coverts majority of the common scenarios one might encounter while developing tests for android applications.
Please refrain from modifying the weather app source code even if it stinks. The project is only for demo purposes and is a modified version of a "Project Sunshine" tutorial by Google.
Fork this repo and request evaluation from QA members experienced in developing Espresso tests.
Software:
* Android studio
* Android SDK
* JDK 1.7 or 1.8
#Espresso basics
[Espresso setup instructions] (https://google.github.io/android-testing-support-library/docs/espresso/setup/index.html)
- Set up the espresso tests on the sample app provided in the repo
- Add a test that launches the app and waits (use SystemClock.sleep() to wait)
#####Description:
Using the links above set up an androidTest directory and add your first test. The idea behind having a test that waits to actually see the result. Remove the test once it's working.
[Espresso basics tutorial] (https://google.github.io/android-testing-support-library/docs/espresso/basics/index.html)
[Espresso api cheat sheet] (https://google.github.io/android-testing-support-library/docs/espresso/cheatsheet/index.html)
Add a test that opens an overflow menu, selects Settings and verifies that "Forecast Preference" is displayed for a particular view
#####Description:
To click on items and assert the view you will need to know the identifiers of the views. They can be obtained using tools like uiatomatorviewer or [hierarchy viewer] (http://developer.android.com/tools/help/hierarchy-viewer.html).
Main difference between two tools is that hierarchy viewer provides you with ENTIRE hierarchy, including items that are not visible (invisbile, gone), while uiatomatorviewer shows only visible views. This discrepancy is important to remember as there is a fundamental difference between a view that doesn't exist and view that is not visible.
Add a test that Changes the location in settings and verifies that the new location is saved in the settings
#####Description: Same as #2 this task is just for exploring capabilities of out-of-the box features of espresso library. Please don't test anything other than UI. Only validate that settings accepted your change. Don't test network responses and data integrity.
Add a pull to refresh test. Verify that snackbar is displayed.
#####Description: Don't test anything other than snackbar.
Notice that this test fails frequently. And this is because your tests don't know yet how to synchronize with the background thread to take into the account network request and response processing times. This will be fixed in task #11 with the implementation of the IdlingResource.
#Espresso Intermediate. Dynamic content and data validation.
[Advanced espresso guide] (https://google.github.io/android-testing-support-library/docs/espresso/advanced/index.html)
Add a test that changes the temperature units using onData()
#####Description:
Whenever you encounter a list view in the hierarchy, this is an indication that onView() doesn't work here any more. onView will only work for items that are currently visible on the screen. However, if an item is off the screen onView will produce view not found exception and fail the test. onData doesn't take a view matcher, but instea it's looking for a data matcher, which matches the data in the adapter behind the ListView. Making assertions with onData will automatically scroll to the view if it's not displayed.
Before starting the test investigate what kind of data the adapter holds in the unit selection dialog. You can write a failing test that will show you data type in the exception log.
[Cursor matchers] (http://developer.android.com/reference/android/support/test/espresso/matcher/CursorMatchers.html)
Pretend that main activity contains a list view that is backed by an adapter that is holding Cursors for each forecast item.
Write a pseudo test that uses onData and clicks on a card with today's forecast.
#####Description:
Explore the source code and find where cursors are used. Explore the contrib library of esresso framework to find how to match data in the cursor adapters. Annotate the test with @Ignore so it doesn't run when you run the whole test suite.
Write a test that clicks on last forecast item of the main page. Don't use position to scroll to the item! Scroll only once!
##Task #7: Custom ViewMatcher
Write a test that checks number of items in the recycler view of the main activity.
#####Description: This functionality is not available in the Espresso framework and will require an implementation of a custom ViewMatcher.
Prettify the output of the matcher's description. Notice that this test is flaky as well. Implementation of the custom idling resource (task #11) will make this test more stable.
##Task #8: External intents
[Espresso intents] (https://google.github.io/android-testing-support-library/docs/espresso/intents/)
Write a test that verifies that correct location data is being sent to a map when Map is selected from the overflow menu.
#####Description: To make this test independent make sure to clear the shared preference storage beforehand. Your test should be checking for a default location value.
##Task #9: Launching into different activities
[Activity test rule] (http://developer.android.com/reference/android/support/test/rule/ActivityTestRule.html)
#####Objective: Write a test that launches straight into the DetailsActivity and verify all that all ui elements display correct information.
#####Description: You need to setup the test in a way that the data is preloaded into the databse. You will need to do it before activity launches. Your activity after the setup must look identical to a normal activity that was created as a result of a selection on the main activity.
#Espresso Advanced. Dependency Injections. Network synchronization. Fake data.
[Dagger] (http://square.github.io/dagger/) [Example project] (http://blog.sqisland.com/2015/04/dagger-2-espresso-2-mockito.html)
#####Objective:
- Create a testmodule with custom dependencies for espresso tests
- Implement a custom test runner and use it to initiate dependencies
#####Description: Learn how the production app initiates dependencies. Don't add any dependencies for now. Just add your module on top of the existing one.
[IdlingResource] (http://developer.android.com/reference/android/support/test/espresso/IdlingResource.html) [Setting executor] (square/retrofit#1081)
#####Objective:
- Implement an idling resource mechanism to wait for network requests to finish before proceeding with the test.
- Add a test that changes a location and verify that snackbar with new location appears on the home activity.
#####Description: This is the right time to use a test module to your advantage. You tests should pass 100% of the runs.
#####Useful material and links:
[MockWebServer] (https://github.com/square/okhttp/tree/master/mockwebserver) [Test Rules] (https://google.github.io/android-testing-support-library/docs/rules/index.html) [GSON] (https://github.com/google/gson)
#####Objective:
- Add a mockwebserver and replace all network requests with mocked ones.
- Add a test that clicks on the card and verifies elements of the WeatherDetails activity.
- Add a test that tests server unavailable error
#####Description: Responses need to be built out using GSON library.