Browse Source

created external android e2e

Daniel Zlotin 7 years ago
parent
commit
a2e70b99be

+ 9
- 0
AndroidE2E/.gitignore View File

@@ -0,0 +1,9 @@
1
+*.iml
2
+.gradle
3
+/local.properties
4
+/.idea/workspace.xml
5
+/.idea/libraries
6
+.DS_Store
7
+/build
8
+/captures
9
+.externalNativeBuild

+ 1
- 0
AndroidE2E/app/.gitignore View File

@@ -0,0 +1 @@
1
+/build

+ 43
- 0
AndroidE2E/app/build.gradle View File

@@ -0,0 +1,43 @@
1
+apply plugin: 'com.android.application'
2
+
3
+android {
4
+    compileSdkVersion 25
5
+    buildToolsVersion "25.0.2"
6
+    defaultConfig {
7
+        applicationId "com.reactnativenavigation.e2e.androide2e"
8
+        minSdkVersion 23
9
+        targetSdkVersion 25
10
+        versionCode 1
11
+        versionName "1.0"
12
+
13
+        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
14
+    }
15
+}
16
+
17
+dependencies {
18
+    compile fileTree(dir: 'libs', include: ['*.jar'])
19
+    compile 'com.android.support:appcompat-v7:25.1.1'
20
+
21
+    androidTestCompile 'org.assertj:assertj-core:2.5.0'
22
+    androidTestCompile 'com.android.support:support-annotations:25.1.1'
23
+    androidTestCompile 'com.android.support.test:runner:0.5'
24
+    androidTestCompile 'com.android.support.test:rules:0.5'
25
+    androidTestCompile 'com.android.support.test.uiautomator:uiautomator-v18:2.1.2'
26
+}
27
+
28
+task reinstallNavigation {
29
+    shell("cd ../../playground/ && yarn run uninstall-android && yarn run android");
30
+}
31
+
32
+def shell(cmd) {
33
+    exec {
34
+        executable "sh"
35
+        args "-c", "$cmd"
36
+    }
37
+}
38
+
39
+tasks.whenTaskAdded { task ->
40
+    if (task.name == 'connectedAndroidTest') {
41
+        task.dependsOn reinstallNavigation
42
+    }
43
+}

+ 17
- 0
AndroidE2E/app/proguard-rules.pro View File

@@ -0,0 +1,17 @@
1
+# Add project specific ProGuard rules here.
2
+# By default, the flags in this file are appended to flags specified
3
+# in /Users/danielzl/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
+#}

+ 56
- 0
AndroidE2E/app/src/androidTest/java/com/reactnativenavigation/e2e/androide2e/ApplicationLifecycleTest.java View File

@@ -0,0 +1,56 @@
1
+package com.reactnativenavigation.e2e.androide2e;
2
+
3
+import android.annotation.TargetApi;
4
+import android.content.Intent;
5
+import android.provider.Settings;
6
+import android.support.test.filters.SdkSuppress;
7
+import android.support.test.runner.AndroidJUnit4;
8
+import android.support.test.uiautomator.UiDevice;
9
+import android.support.test.uiautomator.UiSelector;
10
+
11
+import org.junit.Test;
12
+import org.junit.runner.RunWith;
13
+
14
+import static android.support.test.InstrumentationRegistry.getInstrumentation;
15
+import static org.assertj.core.api.Java6Assertions.assertThat;
16
+
17
+@RunWith(AndroidJUnit4.class)
18
+@SdkSuppress(minSdkVersion = 23)
19
+@TargetApi(23)
20
+public class ApplicationLifecycleTest {
21
+    @Test
22
+    public void showSplash_AcceptsOverlayPermissions_ShowsWelcomeScreen() throws Exception {
23
+        launchTheApp();
24
+        Thread.sleep(2000);
25
+//        assertThat(rule.getActivity().getContentView()).isNotNull().isInstanceOf(NavigationSplashView.class);
26
+//        acceptOverlayPermissionIfNeeded();
27
+//        assertMainShown();
28
+    }
29
+
30
+    private void acceptOverlayPermissionIfNeeded() throws Exception {
31
+        if (Settings.canDrawOverlays(getInstrumentation().getTargetContext())) {
32
+            return;
33
+        }
34
+        uiDevice().waitForIdle();
35
+        uiDevice().findObject(new UiSelector().text("Playground")).click();
36
+        uiDevice().findObject(new UiSelector().text("Permit drawing over other apps")).click();
37
+        uiDevice().pressBack();
38
+        uiDevice().pressBack();
39
+    }
40
+
41
+    private void launchTheApp() throws Exception {
42
+//        uiDevice().findObject(new UiSelector().description("Apps")).clickAndWaitForNewWindow();
43
+        uiDevice().wakeUp();
44
+        uiDevice().pressHome();
45
+        uiDevice().waitForIdle();
46
+        Intent intent = getInstrumentation().getTargetContext().getPackageManager().getLaunchIntentForPackage("com.reactnativenavigation.playground");
47
+        assertThat(intent).isNotNull();
48
+        getInstrumentation().getTargetContext().startActivity(intent);
49
+        uiDevice().waitForIdle();
50
+    }
51
+
52
+    private UiDevice uiDevice() {
53
+        return UiDevice.getInstance(getInstrumentation());
54
+    }
55
+
56
+}

+ 21
- 0
AndroidE2E/app/src/androidTest/java/com/reactnativenavigation/e2e/androide2e/EnvironmentTest.java View File

@@ -0,0 +1,21 @@
1
+package com.reactnativenavigation.e2e.androide2e;
2
+
3
+import android.annotation.TargetApi;
4
+import android.support.test.filters.SdkSuppress;
5
+import android.support.test.runner.AndroidJUnit4;
6
+
7
+import org.junit.Test;
8
+import org.junit.runner.RunWith;
9
+
10
+import static android.support.test.InstrumentationRegistry.getInstrumentation;
11
+import static org.assertj.core.api.Java6Assertions.assertThat;
12
+
13
+@RunWith(AndroidJUnit4.class)
14
+@SdkSuppress(minSdkVersion = 23)
15
+@TargetApi(23)
16
+public class EnvironmentTest {
17
+    @Test
18
+    public void instrumentationAndAssertJ() throws Exception {
19
+        assertThat(getInstrumentation().getTargetContext().getPackageName()).isEqualTo("com.reactnativenavigation.e2e.androide2e");
20
+    }
21
+}

+ 18
- 0
AndroidE2E/app/src/main/AndroidManifest.xml View File

@@ -0,0 +1,18 @@
1
+<manifest xmlns:android="http://schemas.android.com/apk/res/android"
2
+    xmlns:tools="http://schemas.android.com/tools"
3
+    package="com.reactnativenavigation.e2e.androide2e">
4
+
5
+    <uses-sdk
6
+        android:minSdkVersion="23"
7
+        tools:overrideLibrary="android.support.test.uiautomator.v18" />
8
+
9
+    <application
10
+        android:allowBackup="true"
11
+        android:icon="@mipmap/ic_launcher"
12
+        android:label="@string/app_name"
13
+        android:supportsRtl="true"
14
+        android:theme="@style/AppTheme">
15
+
16
+    </application>
17
+
18
+</manifest>

BIN
AndroidE2E/app/src/main/res/mipmap-hdpi/ic_launcher.png View File


BIN
AndroidE2E/app/src/main/res/mipmap-mdpi/ic_launcher.png View File


BIN
AndroidE2E/app/src/main/res/mipmap-xhdpi/ic_launcher.png View File


BIN
AndroidE2E/app/src/main/res/mipmap-xxhdpi/ic_launcher.png View File


BIN
AndroidE2E/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png View File


+ 6
- 0
AndroidE2E/app/src/main/res/values/colors.xml View File

@@ -0,0 +1,6 @@
1
+<?xml version="1.0" encoding="utf-8"?>
2
+<resources>
3
+    <color name="colorPrimary">#3F51B5</color>
4
+    <color name="colorPrimaryDark">#303F9F</color>
5
+    <color name="colorAccent">#FF4081</color>
6
+</resources>

+ 3
- 0
AndroidE2E/app/src/main/res/values/strings.xml View File

@@ -0,0 +1,3 @@
1
+<resources>
2
+    <string name="app_name">AndroidE2E</string>
3
+</resources>

+ 11
- 0
AndroidE2E/app/src/main/res/values/styles.xml View File

@@ -0,0 +1,11 @@
1
+<resources>
2
+
3
+    <!-- Base application theme. -->
4
+    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
5
+        <!-- Customize your theme here. -->
6
+        <item name="colorPrimary">@color/colorPrimary</item>
7
+        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
8
+        <item name="colorAccent">@color/colorAccent</item>
9
+    </style>
10
+
11
+</resources>

+ 21
- 0
AndroidE2E/build.gradle View File

@@ -0,0 +1,21 @@
1
+// Top-level build file where you can add configuration options common to all sub-projects/modules.
2
+
3
+buildscript {
4
+    repositories {
5
+        jcenter()
6
+    }
7
+    dependencies {
8
+        classpath 'com.android.tools.build:gradle:2.3.0-beta3'
9
+
10
+        // NOTE: Do not place your application dependencies here; they belong
11
+        // in the individual module build.gradle files
12
+    }
13
+}
14
+
15
+allprojects {
16
+    repositories {
17
+        mavenLocal()
18
+        jcenter()
19
+        mavenCentral()
20
+    }
21
+}

+ 17
- 0
AndroidE2E/gradle.properties View File

@@ -0,0 +1,17 @@
1
+# Project-wide Gradle settings.
2
+
3
+# IDE (e.g. Android Studio) users:
4
+# Gradle settings configured through the IDE *will override*
5
+# any settings specified in this file.
6
+
7
+# For more details on how to configure your build environment visit
8
+# http://www.gradle.org/docs/current/userguide/build_environment.html
9
+
10
+# Specifies the JVM arguments used for the daemon process.
11
+# The setting is particularly useful for tweaking memory settings.
12
+org.gradle.jvmargs=-Xmx1536m
13
+
14
+# When configured, Gradle will run in incubating parallel mode.
15
+# This option should only be used with decoupled projects. More details, visit
16
+# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
17
+# org.gradle.parallel=true

BIN
AndroidE2E/gradle/wrapper/gradle-wrapper.jar View File


+ 6
- 0
AndroidE2E/gradle/wrapper/gradle-wrapper.properties View File

@@ -0,0 +1,6 @@
1
+#Mon Dec 28 10:00:20 PST 2015
2
+distributionBase=GRADLE_USER_HOME
3
+distributionPath=wrapper/dists
4
+zipStoreBase=GRADLE_USER_HOME
5
+zipStorePath=wrapper/dists
6
+distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip

+ 160
- 0
AndroidE2E/gradlew View File

@@ -0,0 +1,160 @@
1
+#!/usr/bin/env bash
2
+
3
+##############################################################################
4
+##
5
+##  Gradle start up script for UN*X
6
+##
7
+##############################################################################
8
+
9
+# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
10
+DEFAULT_JVM_OPTS=""
11
+
12
+APP_NAME="Gradle"
13
+APP_BASE_NAME=`basename "$0"`
14
+
15
+# Use the maximum available, or set MAX_FD != -1 to use that value.
16
+MAX_FD="maximum"
17
+
18
+warn ( ) {
19
+    echo "$*"
20
+}
21
+
22
+die ( ) {
23
+    echo
24
+    echo "$*"
25
+    echo
26
+    exit 1
27
+}
28
+
29
+# OS specific support (must be 'true' or 'false').
30
+cygwin=false
31
+msys=false
32
+darwin=false
33
+case "`uname`" in
34
+  CYGWIN* )
35
+    cygwin=true
36
+    ;;
37
+  Darwin* )
38
+    darwin=true
39
+    ;;
40
+  MINGW* )
41
+    msys=true
42
+    ;;
43
+esac
44
+
45
+# Attempt to set APP_HOME
46
+# Resolve links: $0 may be a link
47
+PRG="$0"
48
+# Need this for relative symlinks.
49
+while [ -h "$PRG" ] ; do
50
+    ls=`ls -ld "$PRG"`
51
+    link=`expr "$ls" : '.*-> \(.*\)$'`
52
+    if expr "$link" : '/.*' > /dev/null; then
53
+        PRG="$link"
54
+    else
55
+        PRG=`dirname "$PRG"`"/$link"
56
+    fi
57
+done
58
+SAVED="`pwd`"
59
+cd "`dirname \"$PRG\"`/" >/dev/null
60
+APP_HOME="`pwd -P`"
61
+cd "$SAVED" >/dev/null
62
+
63
+CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
64
+
65
+# Determine the Java command to use to start the JVM.
66
+if [ -n "$JAVA_HOME" ] ; then
67
+    if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
68
+        # IBM's JDK on AIX uses strange locations for the executables
69
+        JAVACMD="$JAVA_HOME/jre/sh/java"
70
+    else
71
+        JAVACMD="$JAVA_HOME/bin/java"
72
+    fi
73
+    if [ ! -x "$JAVACMD" ] ; then
74
+        die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
75
+
76
+Please set the JAVA_HOME variable in your environment to match the
77
+location of your Java installation."
78
+    fi
79
+else
80
+    JAVACMD="java"
81
+    which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
82
+
83
+Please set the JAVA_HOME variable in your environment to match the
84
+location of your Java installation."
85
+fi
86
+
87
+# Increase the maximum file descriptors if we can.
88
+if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
89
+    MAX_FD_LIMIT=`ulimit -H -n`
90
+    if [ $? -eq 0 ] ; then
91
+        if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
92
+            MAX_FD="$MAX_FD_LIMIT"
93
+        fi
94
+        ulimit -n $MAX_FD
95
+        if [ $? -ne 0 ] ; then
96
+            warn "Could not set maximum file descriptor limit: $MAX_FD"
97
+        fi
98
+    else
99
+        warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
100
+    fi
101
+fi
102
+
103
+# For Darwin, add options to specify how the application appears in the dock
104
+if $darwin; then
105
+    GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
106
+fi
107
+
108
+# For Cygwin, switch paths to Windows format before running java
109
+if $cygwin ; then
110
+    APP_HOME=`cygpath --path --mixed "$APP_HOME"`
111
+    CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
112
+    JAVACMD=`cygpath --unix "$JAVACMD"`
113
+
114
+    # We build the pattern for arguments to be converted via cygpath
115
+    ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
116
+    SEP=""
117
+    for dir in $ROOTDIRSRAW ; do
118
+        ROOTDIRS="$ROOTDIRS$SEP$dir"
119
+        SEP="|"
120
+    done
121
+    OURCYGPATTERN="(^($ROOTDIRS))"
122
+    # Add a user-defined pattern to the cygpath arguments
123
+    if [ "$GRADLE_CYGPATTERN" != "" ] ; then
124
+        OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
125
+    fi
126
+    # Now convert the arguments - kludge to limit ourselves to /bin/sh
127
+    i=0
128
+    for arg in "$@" ; do
129
+        CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
130
+        CHECK2=`echo "$arg"|egrep -c "^-"`                                 ### Determine if an option
131
+
132
+        if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition
133
+            eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
134
+        else
135
+            eval `echo args$i`="\"$arg\""
136
+        fi
137
+        i=$((i+1))
138
+    done
139
+    case $i in
140
+        (0) set -- ;;
141
+        (1) set -- "$args0" ;;
142
+        (2) set -- "$args0" "$args1" ;;
143
+        (3) set -- "$args0" "$args1" "$args2" ;;
144
+        (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
145
+        (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
146
+        (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
147
+        (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
148
+        (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
149
+        (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
150
+    esac
151
+fi
152
+
153
+# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
154
+function splitJvmOpts() {
155
+    JVM_OPTS=("$@")
156
+}
157
+eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
158
+JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"
159
+
160
+exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"

+ 90
- 0
AndroidE2E/gradlew.bat View File

@@ -0,0 +1,90 @@
1
+@if "%DEBUG%" == "" @echo off
2
+@rem ##########################################################################
3
+@rem
4
+@rem  Gradle startup script for Windows
5
+@rem
6
+@rem ##########################################################################
7
+
8
+@rem Set local scope for the variables with windows NT shell
9
+if "%OS%"=="Windows_NT" setlocal
10
+
11
+@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
12
+set DEFAULT_JVM_OPTS=
13
+
14
+set DIRNAME=%~dp0
15
+if "%DIRNAME%" == "" set DIRNAME=.
16
+set APP_BASE_NAME=%~n0
17
+set APP_HOME=%DIRNAME%
18
+
19
+@rem Find java.exe
20
+if defined JAVA_HOME goto findJavaFromJavaHome
21
+
22
+set JAVA_EXE=java.exe
23
+%JAVA_EXE% -version >NUL 2>&1
24
+if "%ERRORLEVEL%" == "0" goto init
25
+
26
+echo.
27
+echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
28
+echo.
29
+echo Please set the JAVA_HOME variable in your environment to match the
30
+echo location of your Java installation.
31
+
32
+goto fail
33
+
34
+:findJavaFromJavaHome
35
+set JAVA_HOME=%JAVA_HOME:"=%
36
+set JAVA_EXE=%JAVA_HOME%/bin/java.exe
37
+
38
+if exist "%JAVA_EXE%" goto init
39
+
40
+echo.
41
+echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
42
+echo.
43
+echo Please set the JAVA_HOME variable in your environment to match the
44
+echo location of your Java installation.
45
+
46
+goto fail
47
+
48
+:init
49
+@rem Get command-line arguments, handling Windowz variants
50
+
51
+if not "%OS%" == "Windows_NT" goto win9xME_args
52
+if "%@eval[2+2]" == "4" goto 4NT_args
53
+
54
+:win9xME_args
55
+@rem Slurp the command line arguments.
56
+set CMD_LINE_ARGS=
57
+set _SKIP=2
58
+
59
+:win9xME_args_slurp
60
+if "x%~1" == "x" goto execute
61
+
62
+set CMD_LINE_ARGS=%*
63
+goto execute
64
+
65
+:4NT_args
66
+@rem Get arguments from the 4NT Shell from JP Software
67
+set CMD_LINE_ARGS=%$
68
+
69
+:execute
70
+@rem Setup the command line
71
+
72
+set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
73
+
74
+@rem Execute Gradle
75
+"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
76
+
77
+:end
78
+@rem End local scope for the variables with windows NT shell
79
+if "%ERRORLEVEL%"=="0" goto mainEnd
80
+
81
+:fail
82
+rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
83
+rem the _cmd.exe /c_ return code!
84
+if  not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
85
+exit /b 1
86
+
87
+:mainEnd
88
+if "%OS%"=="Windows_NT" endlocal
89
+
90
+:omega

+ 1
- 0
AndroidE2E/settings.gradle View File

@@ -0,0 +1 @@
1
+include ':app'

+ 1
- 0
playground/package.json View File

@@ -7,6 +7,7 @@
7 7
     "start": "adb reverse tcp:8081 tcp:8081; watchman watch-del-all; react-native start",
8 8
     "xcode": "open ios/playground.xcodeproj",
9 9
     "android": "cd android && ./gradlew installDebug",
10
+    "uninstall-android": "cd android && ./gradlew clean uninstallAll",
10 11
     "xcodeunit": "node ./scripts/unit.ios.js",
11 12
     "e2e-android": "node ./scripts/e2e.android.js",
12 13
     "e2e-ios": "node ./scripts/e2e.ios.js"

+ 11
- 11
playground/scripts/e2e.android.js View File

@@ -2,12 +2,12 @@ const _ = require('lodash');
2 2
 const shellUtils = require('shell-utils');
3 3
 const fs = require('fs');
4 4
 
5
-// function runEmulator() {
6
-//   shellUtils.exec.execSync(`echo no | android create avd --force -n test -t android-25 --abi armeabi-v7a`);
7
-//   shellUtils.exec.execSync(`emulator -avd test -no-skin -no-audio -no-window &`);
8
-//   shellUtils.exec.execSync(`android-wait-for-emulator`);
9
-//   shellUtils.exec.execSync(`adb shell input keyevent 82 &`);
10
-// }
5
+function runEmulator() {
6
+  //   shellUtils.exec.execSync(`echo no | android create avd --force -n test -t android-25 --abi armeabi-v7a`);
7
+  //   shellUtils.exec.execSync(`emulator -avd test -no-skin -no-audio -no-window &`);
8
+  //   shellUtils.exec.execSync(`android-wait-for-emulator`);
9
+  //   shellUtils.exec.execSync(`adb shell input keyevent 82 &`);
10
+}
11 11
 
12 12
 function e2e() {
13 13
   shellUtils.exec.execSync(`cd android && ./gradlew uninstallAll`);
@@ -15,14 +15,14 @@ function e2e() {
15 15
 }
16 16
 
17 17
 function run() {
18
-  shellUtils.exec.execSync(`echo 'travis_fold:start:android-espresso'`);
18
+  shellUtils.exec.execSync(`echo 'travis_fold:start:android-e2e'`);
19 19
   try {
20
-    // if (process.env.CI) {
21
-    // runEmulator();
22
-    // }
20
+    if (process.env.CI) {
21
+      runEmulator();
22
+    }
23 23
     e2e();
24 24
   } finally {
25
-    shellUtils.exec.execSync(`echo 'travis_fold:end:android-espresso'`);
25
+    shellUtils.exec.execSync(`echo 'travis_fold:end:android-e2e'`);
26 26
   }
27 27
 }
28 28