במדריך הזה מוסבר איך להתקין את Espresso באמצעות SDK Manager ואיך לבצע build באמצעות Gradle. מומלץ להשתמש ב-Android Studio.
הגדרת סביבת הבדיקה
כדי למנוע תנודות בתוצאות הבדיקה, מומלץ מאוד להשבית את האנימציות של המערכת במכשירים הווירטואליים או הפיזיים שמשמשים לבדיקה. במכשיר, בקטע הגדרות > אפשרויות למפתחים, משביתים את 3 ההגדרות הבאות:
- קנה מידה לאנימציה של חלון
- קנה מידה של הנפשת מעבר
- קנה מידה למשך זמן אנימציה
הוספת יחסי תלות של Espresso
כדי להוסיף יחסי תלות של Espresso לפרויקט, מבצעים את השלבים הבאים:
- פותחים את קובץ
build.gradleשל האפליקציה. בדרך כלל זה לא קובץbuild.gradleברמה העליונה, אלא קובץapp/build.gradle. - מוסיפים את השורות הבאות בתוך dependencies:
Groovy
androidTestImplementation 'androidx.test.espresso:espresso-core:3.6.1' androidTestImplementation 'androidx.test:runner:1.6.1' androidTestImplementation 'androidx.test:rules:1.6.1'
Kotlin
androidTestImplementation('androidx.test.espresso:espresso-core:3.6.1') androidTestImplementation('androidx.test:runner:1.6.1') androidTestImplementation('androidx.test:rules:1.6.1')
רשימת יחסי התלות המלאה ב-Gradle
הגדרת כלי ההרצה של המדידה
מוסיפים את השורה הבאה לקובץ build.gradle באזור android.defaultConfig:
Groovy
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
Kotlin
testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
קובץ build של Gradle לדוגמה
Groovy
plugins { id 'com.android.application' } android { compileSdkVersion 36 defaultConfig { applicationId "com.my.awesome.app" minSdkVersion 23 targetSdkVersion 36 versionCode 1 versionName "1.0" testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" } } dependencies { androidTestImplementation 'androidx.test:runner:1.6.1' androidTestImplementation 'androidx.test.espresso:espresso-core:3.6.1' }
Kotlin
plugins { id("com.android.application") } android { compileSdkVersion(36) defaultConfig { applicationId = "com.my.awesome.app" minSdkVersion(23) targetSdkVersion(36) versionCode = 1 versionName = "1.0" testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" } } dependencies { androidTestImplementation('androidx.test:runner:1.6.1') androidTestImplementation('androidx.test.espresso:espresso-core:3.6.1') }
ניתוח נתונים
כדי לוודא שאנחנו בכיוון הנכון בכל גרסה חדשה, כלי ההרצה של הבדיקות אוסף נתונים אנליטיים. באופן ספציפי יותר, הוא מעלה גיבוב של שם החבילה של האפליקציה שנבדקת לכל הפעלה. כך אנחנו יכולים למדוד גם את מספר החבילות הייחודיות באמצעות Espresso וגם את נפח השימוש.
אם אתם לא רוצים להעלות את הנתונים האלה, אתם יכולים לבטל את ההסכמה על ידי הוספת הארגומנט disableAnalytics לפקודת המדידה:
adb shell am instrument -e disableAnalytics true
הוספת הבדיקה הראשונה
כברירת מחדל, Android Studio יוצר בדיקות בתיקייה src/androidTest/java/com.example.package/.
דוגמה לבדיקת JUnit4 באמצעות Rules:
Kotlin
@RunWith(AndroidJUnit4::class) @LargeTest class HelloWorldEspressoTest { @get:Rule val activityRule = ActivityScenarioRule(MainActivity::class.java) @Test fun listGoesOverTheFold() { onView(withText("Hello world!")).check(matches(isDisplayed())) } }
Java
@RunWith(AndroidJUnit4.class) @LargeTest public class HelloWorldEspressoTest { @Rule public ActivityScenarioRule<MainActivity> activityRule = new ActivityScenarioRule<>(MainActivity.class); @Test public void listGoesOverTheFold() { onView(withText("Hello world!")).check(matches(isDisplayed())); } }
הרצת בדיקות
אפשר להריץ את הבדיקות ב-Android Studio או משורת הפקודה.
ב-Android Studio
כדי ליצור הגדרת בדיקה ב-Android Studio:
- פותחים את האפשרות Run > Edit Configurations (הפעלה > עריכת הגדרות).
- מוסיפים הגדרה חדשה של בדיקות Android.
- בוחרים מודול.
- הוספת רכיב ספציפי להרצת אינסטרומנטציה:
androidx.test.runner.AndroidJUnitRunner - מריצים את ההגדרה החדשה שנוצרה.
משורת הפקודה
מריצים את פקודת Gradle הבאה:
./gradlew connectedAndroidTest