├── .gitignore ├── README.md ├── app ├── .gitignore ├── build.gradle ├── proguard-rules.pro └── src │ ├── androidTest │ └── java │ │ └── com │ │ └── android │ │ └── sample │ │ └── espressouitestsample │ │ ├── login │ │ └── LoginScreenTest.java │ │ ├── mainscreen │ │ └── MainScreenTest.java │ │ └── signup │ │ └── SignUpScreenTest.java │ ├── main │ ├── AndroidManifest.xml │ ├── java │ │ └── com │ │ │ └── android │ │ │ └── sample │ │ │ └── espressouitestsample │ │ │ ├── BaseActivity.java │ │ │ ├── BaseFragment.java │ │ │ ├── SuccessActivity.java │ │ │ ├── login │ │ │ ├── LoginActivity.java │ │ │ ├── LoginFragment.java │ │ │ ├── LoginScreenContract.java │ │ │ └── LoginScreenPresenter.java │ │ │ ├── mainscreen │ │ │ ├── MainActivity.java │ │ │ ├── MainFragment.java │ │ │ ├── MainScreenContract.java │ │ │ └── MainScreenPresenter.java │ │ │ └── signup │ │ │ ├── SignUpActivity.java │ │ │ ├── SignUpContract.java │ │ │ ├── SignUpFragment.java │ │ │ └── SignUpPresenter.java │ └── res │ │ ├── layout │ │ ├── activity_login.xml │ │ ├── activity_main.xml │ │ ├── activity_sign_up.xml │ │ ├── activity_success.xml │ │ ├── fragment_login.xml │ │ ├── fragment_main.xml │ │ └── fragment_sign_up.xml │ │ ├── mipmap-hdpi │ │ └── ic_launcher.png │ │ ├── mipmap-mdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xhdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xxhdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xxxhdpi │ │ └── ic_launcher.png │ │ ├── values-w820dp │ │ └── dimens.xml │ │ └── values │ │ ├── colors.xml │ │ ├── dimens.xml │ │ ├── strings.xml │ │ └── styles.xml │ └── test │ └── java │ └── com │ └── android │ └── sample │ └── espressouitestsample │ └── ExampleUnitTest.java ├── build.gradle ├── gradle.properties ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat └── settings.gradle /.gitignore: -------------------------------------------------------------------------------- 1 | *.iml 2 | .gradle 3 | /local.properties 4 | /.idea/workspace.xml 5 | /.idea/libraries 6 | .DS_Store 7 | /build 8 | /captures 9 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # EspressoUIIntegrationTest 2 | Android App to show how to do UI Integration test with Espresso 3 | -------------------------------------------------------------------------------- /app/.gitignore: -------------------------------------------------------------------------------- 1 | /build 2 | -------------------------------------------------------------------------------- /app/build.gradle: -------------------------------------------------------------------------------- 1 | apply plugin: 'com.android.application' 2 | 3 | android { 4 | compileSdkVersion 23 5 | buildToolsVersion "23.0.3" 6 | 7 | defaultConfig { 8 | applicationId "com.android.sample.espressouitestsample" 9 | minSdkVersion 15 10 | targetSdkVersion 23 11 | versionCode 1 12 | versionName "1.0" 13 | 14 | testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" 15 | } 16 | buildTypes { 17 | release { 18 | minifyEnabled false 19 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 20 | } 21 | } 22 | } 23 | 24 | dependencies { 25 | compile fileTree(dir: 'libs', include: ['*.jar']) 26 | testCompile 'junit:junit:4.12' 27 | compile "com.android.support:appcompat-v7:$rootProject.supportLibraryVersion" 28 | compile "com.android.support:design:$rootProject.supportLibraryVersion" 29 | 30 | androidTestCompile "com.android.support:support-annotations:$rootProject.ext.supportAnnotationsversion" 31 | 32 | // Android Testing Support Library's runner and rules 33 | androidTestCompile "com.android.support.test:runner:$rootProject.ext.runnerVersion" 34 | androidTestCompile "com.android.support.test:rules:$rootProject.ext.rulesVersion" 35 | 36 | // Espresso UI Testing dependencies. 37 | androidTestCompile "com.android.support.test.espresso:espresso-core:$rootProject.ext.espressoVersion" 38 | } 39 | -------------------------------------------------------------------------------- /app/proguard-rules.pro: -------------------------------------------------------------------------------- 1 | # Add project specific ProGuard rules here. 2 | # By default, the flags in this file are appended to flags specified 3 | # in /Users/mayowa.adegeye/Library/Android/sdk/tools/proguard/proguard-android.txt 4 | # You can edit the include path and order by changing the proguardFiles 5 | # directive in build.gradle. 6 | # 7 | # For more details, see 8 | # http://developer.android.com/guide/developing/tools/proguard.html 9 | 10 | # Add any project specific keep options here: 11 | 12 | # If your project uses WebView with JS, uncomment the following 13 | # and specify the fully qualified class name to the JavaScript interface 14 | # class: 15 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview { 16 | # public *; 17 | #} 18 | -------------------------------------------------------------------------------- /app/src/androidTest/java/com/android/sample/espressouitestsample/login/LoginScreenTest.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.login; 2 | 3 | import android.support.test.InstrumentationRegistry; 4 | import android.support.test.filters.LargeTest; 5 | import android.support.test.rule.ActivityTestRule; 6 | import android.support.test.runner.AndroidJUnit4; 7 | 8 | import com.android.sample.espressouitestsample.R; 9 | 10 | import org.junit.Rule; 11 | import org.junit.Test; 12 | import org.junit.runner.RunWith; 13 | 14 | import static android.support.test.espresso.Espresso.onView; 15 | import static android.support.test.espresso.action.ViewActions.click; 16 | import static android.support.test.espresso.action.ViewActions.closeSoftKeyboard; 17 | import static android.support.test.espresso.action.ViewActions.typeText; 18 | import static android.support.test.espresso.assertion.ViewAssertions.matches; 19 | import static android.support.test.espresso.matcher.ViewMatchers.isDisplayed; 20 | import static android.support.test.espresso.matcher.ViewMatchers.withId; 21 | import static android.support.test.espresso.matcher.ViewMatchers.withText; 22 | 23 | /** 24 | * Created by mayowa.adegeye on 01/06/2016. 25 | */ 26 | @RunWith(AndroidJUnit4.class) 27 | @LargeTest 28 | public class LoginScreenTest { 29 | @Rule 30 | public ActivityTestRule mLoginActivityTestRule = 31 | new ActivityTestRule(LoginActivity.class); 32 | 33 | @Test 34 | public void clickLoginButton_showsSuccessScreenAfterLogin() { 35 | String email = "username@email.com"; 36 | String password = "password"; 37 | 38 | //type in email 39 | onView(withId(R.id.edit_text_email)).perform(typeText(email), closeSoftKeyboard()); 40 | 41 | //type in password 42 | onView(withId(R.id.edit_text_password)).perform(typeText(password), closeSoftKeyboard()); 43 | 44 | //click on login button 45 | onView(withId(R.id.button_login)).perform(click()); 46 | 47 | //verify that success screen shows 48 | String successString = InstrumentationRegistry.getTargetContext().getString(R.string.text_login_successful); 49 | onView(withText(successString)).check(matches(isDisplayed())); 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /app/src/androidTest/java/com/android/sample/espressouitestsample/mainscreen/MainScreenTest.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.mainscreen; 2 | 3 | import android.support.test.filters.LargeTest; 4 | import android.support.test.rule.ActivityTestRule; 5 | import android.support.test.runner.AndroidJUnit4; 6 | 7 | import com.android.sample.espressouitestsample.R; 8 | import com.android.sample.espressouitestsample.signup.SignUpActivity; 9 | 10 | import org.junit.Rule; 11 | import org.junit.Test; 12 | import org.junit.runner.RunWith; 13 | 14 | import static android.support.test.espresso.Espresso.onView; 15 | import static android.support.test.espresso.action.ViewActions.click; 16 | import static android.support.test.espresso.assertion.ViewAssertions.matches; 17 | import static android.support.test.espresso.matcher.ViewMatchers.isDescendantOfA; 18 | import static android.support.test.espresso.matcher.ViewMatchers.isDisplayed; 19 | import static android.support.test.espresso.matcher.ViewMatchers.withId; 20 | import static android.support.test.espresso.matcher.ViewMatchers.withParent; 21 | import static org.hamcrest.core.AllOf.allOf; 22 | 23 | /** 24 | * Test for the MainActivity screen 25 | */ 26 | 27 | @RunWith(AndroidJUnit4.class) 28 | @LargeTest 29 | public class MainScreenTest { 30 | @Rule 31 | public ActivityTestRule mMainActivityTestRule = new 32 | ActivityTestRule(MainActivity.class); 33 | 34 | @Test 35 | public void clickSignUpButton_opensSignUpScreen() { 36 | //click on the sign up button 37 | onView(withId(R.id.button_sign_up)).perform(click()); 38 | 39 | //check if the sign up screen is displayed by asserting that the first name edittext is displayed 40 | onView(withId(R.id.edit_text_first_name)).check(matches(allOf(isDescendantOfA(withId(R.id.layout_sign_up)), isDisplayed()))); 41 | } 42 | 43 | @Test 44 | public void clickLoginButton_openLoginScreen() { 45 | //locate and click on the login button 46 | onView(withId(R.id.button_login)).perform(click()); 47 | 48 | //check that the login screen is displayed 49 | onView(withId(R.id.edit_text_email)).check(matches(allOf(isDescendantOfA(withId(R.id.layout_login)), isDisplayed()))); 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /app/src/androidTest/java/com/android/sample/espressouitestsample/signup/SignUpScreenTest.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.signup; 2 | 3 | import android.support.test.InstrumentationRegistry; 4 | import android.support.test.filters.LargeTest; 5 | import android.support.test.rule.ActivityTestRule; 6 | import android.support.test.runner.AndroidJUnit4; 7 | 8 | import com.android.sample.espressouitestsample.R; 9 | 10 | import org.junit.Rule; 11 | import org.junit.Test; 12 | import org.junit.runner.RunWith; 13 | 14 | import static android.support.test.espresso.Espresso.onView; 15 | import static android.support.test.espresso.action.ViewActions.click; 16 | import static android.support.test.espresso.action.ViewActions.closeSoftKeyboard; 17 | import static android.support.test.espresso.action.ViewActions.typeText; 18 | import static android.support.test.espresso.assertion.ViewAssertions.matches; 19 | import static android.support.test.espresso.matcher.ViewMatchers.isDisplayed; 20 | import static android.support.test.espresso.matcher.ViewMatchers.withId; 21 | import static android.support.test.espresso.matcher.ViewMatchers.withText; 22 | import static org.hamcrest.CoreMatchers.allOf; 23 | 24 | /** 25 | * Created by mayowa.adegeye on 31/05/2016. 26 | */ 27 | @RunWith(AndroidJUnit4.class) 28 | @LargeTest 29 | public class SignUpScreenTest { 30 | @Rule 31 | public ActivityTestRule mSignUpActivityTestRule = 32 | new ActivityTestRule(SignUpActivity.class); 33 | 34 | @Test 35 | public void clickSignUpButtonAfterFillingForm_showProgressAndSuccessScreen() { 36 | String first_name = "Firstname"; 37 | String last_name = "lastname"; 38 | String emailAddress = "firstname.lastname@g.com"; 39 | String password = "password"; 40 | 41 | //find the firstname edit text and type in the first name 42 | onView(withId(R.id.edit_text_first_name)).perform(typeText(first_name), closeSoftKeyboard()); 43 | 44 | //find the lastname edit text and type in the last name 45 | onView(withId(R.id.edit_text_last_name)).perform(typeText(last_name), closeSoftKeyboard()); 46 | 47 | //find the email address edit text and type in the email address 48 | onView(withId(R.id.edit_text_email)).perform(typeText(emailAddress), closeSoftKeyboard()); 49 | 50 | //find the password edit text and type in the password 51 | onView(withId(R.id.edit_text_password)).perform(typeText(password), closeSoftKeyboard()); 52 | 53 | //click the signup button 54 | onView(withId(R.id.button_sign_up)).perform(click()); 55 | 56 | //check that we can see the success screen with success message 57 | String successString = InstrumentationRegistry.getTargetContext().getString(R.string.text_sign_up_successful); 58 | onView(withId(R.id.text_view_status_message)).check(matches(allOf(withText(successString), isDisplayed()))); 59 | } 60 | } 61 | -------------------------------------------------------------------------------- /app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/BaseActivity.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample; 2 | 3 | import android.support.v4.app.Fragment; 4 | import android.support.v4.app.FragmentManager; 5 | import android.support.v4.app.FragmentTransaction; 6 | import android.support.v7.app.ActionBar; 7 | import android.support.v7.app.AppCompatActivity; 8 | import android.support.v7.widget.Toolbar; 9 | 10 | public class BaseActivity extends AppCompatActivity { 11 | //generic function to start fragment 12 | public void startFragment(Fragment fragment) { 13 | FragmentManager fragmentManager = getSupportFragmentManager(); 14 | FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction(); 15 | fragmentTransaction.replace(R.id.container, fragment); 16 | fragmentTransaction.commit(); 17 | } 18 | 19 | public void setupToolbar(Toolbar toolbar) { 20 | //setup the toolbar 21 | setSupportActionBar(toolbar); 22 | 23 | ActionBar actionBar = getSupportActionBar(); 24 | actionBar.setDisplayHomeAsUpEnabled(true); 25 | actionBar.setDisplayShowHomeEnabled(true); 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/BaseFragment.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample; 2 | 3 | import android.support.v4.app.Fragment; 4 | 5 | /** 6 | * Created by mayowa.adegeye on 31/05/2016. 7 | */ 8 | public class BaseFragment extends Fragment { 9 | } 10 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/SuccessActivity.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample; 2 | 3 | import android.os.Bundle; 4 | import android.support.annotation.Nullable; 5 | import android.widget.TextView; 6 | 7 | /** 8 | * Created by mayowa.adegeye on 31/05/2016. 9 | */ 10 | public class SuccessActivity extends BaseActivity { 11 | public static final String STATUS_MESSAGE = "message"; 12 | 13 | @Override 14 | protected void onCreate(@Nullable Bundle savedInstanceState) { 15 | super.onCreate(savedInstanceState); 16 | setContentView(R.layout.activity_success); 17 | 18 | String message = getIntent().getStringExtra(STATUS_MESSAGE); 19 | TextView textView = (TextView)findViewById(R.id.text_view_status_message); 20 | textView.setText(message); 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/login/LoginActivity.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.login; 2 | 3 | import android.os.Bundle; 4 | import android.support.annotation.Nullable; 5 | import android.support.v7.widget.Toolbar; 6 | 7 | import com.android.sample.espressouitestsample.BaseActivity; 8 | import com.android.sample.espressouitestsample.R; 9 | 10 | /** 11 | * Login Activity 12 | */ 13 | public class LoginActivity extends BaseActivity { 14 | @Override 15 | protected void onCreate(@Nullable Bundle savedInstanceState) { 16 | super.onCreate(savedInstanceState); 17 | setContentView(R.layout.activity_login); 18 | 19 | //setup the toolbar 20 | Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 21 | toolbar.setTitle(R.string.tool_bar_title_login); 22 | setupToolbar(toolbar); 23 | 24 | //start fragment 25 | startFragment(LoginFragment.newInstance()); 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/login/LoginFragment.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.login; 2 | 3 | import android.content.Intent; 4 | import android.os.Bundle; 5 | import android.support.annotation.Nullable; 6 | import android.view.LayoutInflater; 7 | import android.view.View; 8 | import android.view.ViewGroup; 9 | import android.widget.Button; 10 | import android.widget.ProgressBar; 11 | 12 | import com.android.sample.espressouitestsample.BaseFragment; 13 | import com.android.sample.espressouitestsample.R; 14 | import com.android.sample.espressouitestsample.SuccessActivity; 15 | 16 | /** 17 | * Created by mayowa.adegeye on 01/06/2016. 18 | */ 19 | public class LoginFragment extends BaseFragment implements LoginScreenContract.View { 20 | private LoginScreenContract.UserActionListener mUserActionListener; 21 | private ProgressBar mProgressBar; 22 | 23 | public static LoginFragment newInstance() { 24 | return new LoginFragment(); 25 | } 26 | 27 | @Override 28 | public void onCreate(@Nullable Bundle savedInstanceState) { 29 | super.onCreate(savedInstanceState); 30 | mUserActionListener = new LoginScreenPresenter(this); 31 | } 32 | 33 | @Nullable 34 | @Override 35 | public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { 36 | return inflater.inflate(R.layout.fragment_login, container, false); 37 | } 38 | 39 | @Override 40 | public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { 41 | super.onViewCreated(view, savedInstanceState); 42 | 43 | Button button = (Button)view.findViewById(R.id.button_login); 44 | button.setOnClickListener(new View.OnClickListener() { 45 | @Override 46 | public void onClick(View v) { 47 | mUserActionListener.loginButtonClick(); 48 | } 49 | }); 50 | 51 | mProgressBar = (ProgressBar)view.findViewById(R.id.progress_bar_login); 52 | } 53 | 54 | @Override 55 | public void showProgressDialog(boolean visible) { 56 | mProgressBar.setVisibility(visible ? View.VISIBLE : View.GONE); 57 | } 58 | 59 | @Override 60 | public void showLoginSuccessScreen() { 61 | Intent intent = new Intent(getActivity(), SuccessActivity.class); 62 | intent.putExtra(SuccessActivity.STATUS_MESSAGE, getString(R.string.text_login_successful)); 63 | startActivity(intent); 64 | } 65 | } 66 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/login/LoginScreenContract.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.login; 2 | 3 | /** 4 | * Created by mayowa.adegeye on 01/06/2016. 5 | */ 6 | public interface LoginScreenContract { 7 | 8 | interface View { 9 | void showProgressDialog(boolean visible); 10 | 11 | void showLoginSuccessScreen(); 12 | } 13 | 14 | interface UserActionListener { 15 | void loginButtonClick(); 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/login/LoginScreenPresenter.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.login; 2 | 3 | import android.os.Handler; 4 | import android.support.annotation.NonNull; 5 | 6 | /** 7 | * Created by mayowa.adegeye on 01/06/2016. 8 | */ 9 | public class LoginScreenPresenter implements LoginScreenContract.UserActionListener { 10 | private LoginScreenContract.View mLoginScreenView; 11 | 12 | public LoginScreenPresenter(@NonNull LoginScreenContract.View view) { 13 | mLoginScreenView = view; 14 | } 15 | @Override 16 | public void loginButtonClick() { 17 | mLoginScreenView.showProgressDialog(true); 18 | 19 | Handler handler = new Handler(); 20 | handler.postDelayed(new Runnable() { 21 | @Override 22 | public void run() { 23 | mLoginScreenView.showProgressDialog(false); 24 | mLoginScreenView.showLoginSuccessScreen(); 25 | } 26 | }, 3000); 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/mainscreen/MainActivity.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.mainscreen; 2 | 3 | import android.os.Bundle; 4 | import android.os.PersistableBundle; 5 | import android.support.annotation.Nullable; 6 | import android.support.v7.app.ActionBar; 7 | import android.support.v7.widget.Toolbar; 8 | 9 | import com.android.sample.espressouitestsample.BaseActivity; 10 | import com.android.sample.espressouitestsample.R; 11 | 12 | /** 13 | * Created by mayowa.adegeye on 31/05/2016. 14 | */ 15 | public class MainActivity extends BaseActivity { 16 | @Override 17 | protected void onCreate(@Nullable Bundle savedInstanceState) { 18 | super.onCreate(savedInstanceState); 19 | setContentView(R.layout.activity_main); 20 | 21 | //setup the toolbar 22 | Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 23 | setupToolbar(toolbar); 24 | 25 | //start fragment 26 | startFragment(MainFragment.newInstance()); 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/mainscreen/MainFragment.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.mainscreen; 2 | 3 | import android.content.Intent; 4 | import android.os.Bundle; 5 | import android.support.annotation.Nullable; 6 | import android.view.LayoutInflater; 7 | import android.view.View; 8 | import android.view.ViewGroup; 9 | import android.widget.Button; 10 | 11 | import com.android.sample.espressouitestsample.BaseFragment; 12 | import com.android.sample.espressouitestsample.R; 13 | import com.android.sample.espressouitestsample.login.LoginActivity; 14 | import com.android.sample.espressouitestsample.signup.SignUpActivity; 15 | 16 | /** 17 | * Created by mayowa.adegeye on 31/05/2016. 18 | */ 19 | public class MainFragment extends BaseFragment implements MainScreenContract.View{ 20 | private MainScreenContract.UserActionListener mUserActionListener; 21 | 22 | public static MainFragment newInstance() { 23 | return new MainFragment(); 24 | } 25 | 26 | @Override 27 | public void onCreate(@Nullable Bundle savedInstanceState) { 28 | super.onCreate(savedInstanceState); 29 | 30 | mUserActionListener = new MainScreenPresenter(this); 31 | } 32 | 33 | @Nullable 34 | @Override 35 | public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { 36 | return inflater.inflate(R.layout.fragment_main, container, false); 37 | } 38 | 39 | @Override 40 | public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { 41 | super.onViewCreated(view, savedInstanceState); 42 | 43 | //set up sign up button 44 | Button signUpButton = (Button) view.findViewById(R.id.button_sign_up); 45 | signUpButton.setOnClickListener(new View.OnClickListener() { 46 | @Override 47 | public void onClick(View v) { 48 | mUserActionListener.signUp(); 49 | } 50 | }); 51 | 52 | //set up login button 53 | Button loginButton = (Button)view.findViewById(R.id.button_login); 54 | loginButton.setOnClickListener(new View.OnClickListener() { 55 | @Override 56 | public void onClick(View v) { 57 | mUserActionListener.login(); 58 | } 59 | }); 60 | } 61 | 62 | @Override 63 | public void showLoginScreen() { 64 | Intent intent = new Intent(getActivity(), LoginActivity.class); 65 | startActivity(intent); 66 | } 67 | 68 | @Override 69 | public void showSignUpScreen() { 70 | Intent intent = new Intent(getActivity(), SignUpActivity.class); 71 | startActivity(intent); 72 | } 73 | } 74 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/mainscreen/MainScreenContract.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.mainscreen; 2 | 3 | /** 4 | * Created by mayowa.adegeye on 31/05/2016. 5 | */ 6 | public interface MainScreenContract { 7 | interface View { 8 | void showLoginScreen(); 9 | 10 | void showSignUpScreen(); 11 | } 12 | 13 | interface UserActionListener { 14 | void signUp(); 15 | 16 | void login(); 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/mainscreen/MainScreenPresenter.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.mainscreen; 2 | 3 | import android.support.annotation.NonNull; 4 | 5 | /** 6 | * Created by mayowa.adegeye on 31/05/2016. 7 | * 8 | * Specifies contract between view and presenter 9 | */ 10 | 11 | 12 | public class MainScreenPresenter implements MainScreenContract.UserActionListener{ 13 | 14 | private MainScreenContract.View mMainScreenView; 15 | 16 | public MainScreenPresenter(@NonNull MainScreenContract.View view) { 17 | mMainScreenView = view; 18 | } 19 | 20 | @Override 21 | public void signUp() { 22 | mMainScreenView.showSignUpScreen(); 23 | } 24 | 25 | @Override 26 | public void login() { 27 | mMainScreenView.showLoginScreen(); 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/signup/SignUpActivity.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.signup; 2 | 3 | import android.os.Bundle; 4 | import android.support.annotation.Nullable; 5 | import android.support.v7.app.ActionBar; 6 | import android.support.v7.widget.Toolbar; 7 | 8 | import com.android.sample.espressouitestsample.BaseActivity; 9 | import com.android.sample.espressouitestsample.R; 10 | import com.android.sample.espressouitestsample.mainscreen.MainFragment; 11 | 12 | /** 13 | * Created by mayowa.adegeye on 31/05/2016. 14 | */ 15 | public class SignUpActivity extends BaseActivity{ 16 | @Override 17 | protected void onCreate(@Nullable Bundle savedInstanceState) { 18 | super.onCreate(savedInstanceState); 19 | setContentView(R.layout.activity_sign_up); 20 | 21 | Toolbar toolbar = (Toolbar)findViewById(R.id.toolbar); 22 | toolbar.setTitle(R.string.tool_bar_title_sign_up); 23 | setupToolbar(toolbar); 24 | 25 | //start fragment 26 | startFragment(SignUpFragment.newInstance()); 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/signup/SignUpContract.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.signup; 2 | 3 | /** 4 | * Created by mayowa.adegeye on 31/05/2016. 5 | */ 6 | public interface SignUpContract { 7 | interface View { 8 | void showIndeterminateProgress(boolean visible); 9 | 10 | void showSuccessActivity(); 11 | } 12 | 13 | interface UserActionListener { 14 | void handleSignUpButtonClick(); 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/signup/SignUpFragment.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.signup; 2 | 3 | import android.app.ProgressDialog; 4 | import android.content.Intent; 5 | import android.os.Bundle; 6 | import android.support.annotation.Nullable; 7 | import android.view.LayoutInflater; 8 | import android.view.View; 9 | import android.view.ViewGroup; 10 | import android.widget.Button; 11 | import android.widget.ProgressBar; 12 | 13 | import com.android.sample.espressouitestsample.BaseFragment; 14 | import com.android.sample.espressouitestsample.R; 15 | import com.android.sample.espressouitestsample.SuccessActivity; 16 | 17 | /** 18 | * Created by mayowa.adegeye on 31/05/2016. 19 | */ 20 | public class SignUpFragment extends BaseFragment implements SignUpContract.View { 21 | private SignUpContract.UserActionListener mSignUpActivityUserActionListener; 22 | 23 | private ProgressBar mProgressDialog; 24 | 25 | public static SignUpFragment newInstance() { 26 | return new SignUpFragment(); 27 | } 28 | 29 | @Override 30 | public void onCreate(@Nullable Bundle savedInstanceState) { 31 | super.onCreate(savedInstanceState); 32 | 33 | mSignUpActivityUserActionListener = new SignUpPresenter(this); 34 | } 35 | 36 | @Nullable 37 | @Override 38 | public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { 39 | return inflater.inflate(R.layout.fragment_sign_up, container, false); 40 | } 41 | 42 | @Override 43 | public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { 44 | super.onViewCreated(view, savedInstanceState); 45 | 46 | Button signUpButton = (Button)view.findViewById(R.id.button_sign_up); 47 | signUpButton.setOnClickListener(new View.OnClickListener() { 48 | @Override 49 | public void onClick(View v) { 50 | mSignUpActivityUserActionListener.handleSignUpButtonClick(); 51 | } 52 | }); 53 | 54 | mProgressDialog = (ProgressBar) view.findViewById(R.id.progress_bar_indeterminate); 55 | } 56 | 57 | 58 | @Override 59 | public void showIndeterminateProgress(boolean visible) { 60 | mProgressDialog.setVisibility(visible ? View.VISIBLE : View.GONE); 61 | } 62 | 63 | 64 | @Override 65 | public void showSuccessActivity() { 66 | Intent intent = new Intent(getActivity(), SuccessActivity.class); 67 | intent.putExtra(SuccessActivity.STATUS_MESSAGE, getString(R.string.text_sign_up_successful)); 68 | startActivity(intent); 69 | } 70 | } 71 | -------------------------------------------------------------------------------- /app/src/main/java/com/android/sample/espressouitestsample/signup/SignUpPresenter.java: -------------------------------------------------------------------------------- 1 | package com.android.sample.espressouitestsample.signup; 2 | 3 | import android.os.Handler; 4 | import android.support.annotation.NonNull; 5 | 6 | /** 7 | * Created by mayowa.adegeye on 31/05/2016. 8 | */ 9 | public class SignUpPresenter implements SignUpContract.UserActionListener { 10 | private SignUpContract.View mSignUpActivityView; 11 | 12 | public SignUpPresenter(@NonNull SignUpContract.View view) { 13 | mSignUpActivityView = view; 14 | } 15 | @Override 16 | public void handleSignUpButtonClick() { 17 | //show progress bar 18 | mSignUpActivityView.showIndeterminateProgress(true); 19 | 20 | 21 | Handler handler = new Handler(); 22 | handler.postDelayed(new Runnable() { 23 | @Override 24 | public void run() { 25 | mSignUpActivityView.showIndeterminateProgress(false); 26 | mSignUpActivityView.showSuccessActivity(); 27 | } 28 | }, 3000); 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /app/src/main/res/layout/activity_login.xml: -------------------------------------------------------------------------------- 1 | 2 | 8 | 9 | 16 | 17 | 22 | -------------------------------------------------------------------------------- /app/src/main/res/layout/activity_main.xml: -------------------------------------------------------------------------------- 1 | 2 | 8 | 9 | 16 | 17 | 22 | 23 | -------------------------------------------------------------------------------- /app/src/main/res/layout/activity_sign_up.xml: -------------------------------------------------------------------------------- 1 | 2 | 8 | 9 | 16 | 17 | 22 | 23 | -------------------------------------------------------------------------------- /app/src/main/res/layout/activity_success.xml: -------------------------------------------------------------------------------- 1 | 2 | 8 | 9 | 15 | -------------------------------------------------------------------------------- /app/src/main/res/layout/fragment_login.xml: -------------------------------------------------------------------------------- 1 | 2 | 9 | 10 | 13 | 14 | 20 | 21 | 22 | 23 | 26 | 27 | 33 | 34 | 35 | 36 |