Android - Testen
Das Android-Framework enthält ein integriertes Testframework, mit dem Sie alle Aspekte Ihrer Anwendung testen können. Die SDK-Tools enthalten Tools zum Einrichten und Ausführen von Testanwendungen. Unabhängig davon, ob Sie in Eclipse mit ADT oder über die Befehlszeile arbeiten, helfen Ihnen die SDK-Tools beim Einrichten und Ausführen Ihrer Tests in einem Emulator oder auf dem Gerät, auf das Sie abzielen.
Teststruktur
Die Build- und Testtools von Android setzen voraus, dass Testprojekte in einer Standardstruktur aus Tests, Testfallklassen, Testpaketen und Testprojekten organisiert sind.
Testen von Tools in Android
Es gibt viele Tools, die zum Testen von Android-Anwendungen verwendet werden können. Einige sind offiziell wie Junit, Monkey und andere sind Tools von Drittanbietern, mit denen Android-Anwendungen getestet werden können. In diesem Kapitel werden wir diese beiden Tools zum Testen von Android-Anwendungen erklären.
- JUnit
- Monkey
JUnit
Sie können die JUnit verwenden TestCaseKlasse, um Unit-Tests für eine Klasse durchzuführen, die keine Android-APIs aufruft. TestCase ist auch die Basisklasse für AndroidTestCase, mit der Sie Android-abhängige Objekte testen können. Neben der Bereitstellung des JUnit-Frameworks bietet AndroidTestCase Android-spezifische Setup-, Teardown- und Hilfsmethoden.
Um TestCase zu verwenden, erweitern Sie Ihre Klasse mit der TestCase-Klasse und implementieren Sie einen Methodenaufruf setUp (). Die Syntax ist unten angegeben -
public class MathTest extends TestCase {
protected double fValue1;
protected double fValue2;
protected void setUp() {
fValue1= 2.0;
fValue2= 3.0;
}
}
Implementieren Sie für jeden Test eine Methode, die mit dem Gerät interagiert. Überprüfen Sie die erwarteten Ergebnisse mit Zusicherungen, die durch Aufrufen von assertTrue (String, boolean) mit einem boolean angegeben wurden.
public void testAdd() {
double result= fValue1 + fValue2;
assertTrue(result == 5.0);
}
Die Assert-Methoden vergleichen die von einem Test erwarteten Werte mit den tatsächlichen Ergebnissen und lösen eine Ausnahme aus, wenn der Vergleich fehlschlägt.
Sobald die Methoden definiert sind, können Sie sie ausführen. Die Syntax ist unten angegeben -
TestCase test= new MathTest("testAdd");
test.run();
Affe
Der UI / Application Exerciser Monkey, normalerweise "Monkey" genannt, ist ein Befehlszeilenprogramm, das pseudozufällige Ströme von Tastenanschlägen, Berührungen und Gesten an ein Gerät sendet. Sie führen es mit dem Android Debug Bridge (adb) Tool aus.
Sie verwenden es, um Ihre Anwendung einem Stresstest zu unterziehen und aufgetretene Fehler zu melden. Sie können einen Strom von Ereignissen wiederholen, indem Sie das Tool jedes Mal mit demselben Zufallszahlen-Startwert ausführen.
Affenmerkmale
Monkey hat viele Funktionen, aber es kann alles in diese vier Kategorien zusammengefasst werden.
- Grundlegende Konfigurationsoptionen
- Betriebliche Einschränkungen
- Ereignistypen und -frequenzen
- Debugging-Optionen
Affengebrauch
Um monkey zu verwenden, öffnen Sie eine Eingabeaufforderung und navigieren Sie einfach zum folgenden Verzeichnis.
android ->sdk ->platform-tools
Schließen Sie Ihr Gerät im Verzeichnis an den PC an und führen Sie den folgenden Befehl aus.
adb shell monkey -p your.package.name -v 500
Dieser Befehl kann in diese Schritte unterteilt werden.
- adb - Android Debug Bridge. Ein Tool zum Verbinden und Senden von Befehlen von einem Desktop- oder Laptop-Computer an Ihr Android-Telefon.
- Shell - Shell ist nur eine Schnittstelle auf dem Gerät, die unsere Befehle in Systembefehle übersetzt.
- Affe - Affe ist das Testwerkzeug.
- v - v steht für ausführliche Methode.
- 500- Dies ist die Frequenzverbindung oder die Anzahl der Ereignisse, die zum Testen gesendet werden sollen.
Dies ist auch in der Abbildung dargestellt -
Mit dem obigen Befehl führen Sie das Monkey-Tool in der Standard-Android-UI-Anwendung aus. Um es nun in Ihrer Anwendung auszuführen, müssen Sie hier Folgendes tun.
Schließlich werden Sie wie unten gezeigt fertig
Dies wurde auch in der folgenden Abbildung gezeigt. Durch Eingabe dieses Befehls generieren Sie tatsächlich 500 zufällige Ereignisse zum Testen.
Beispiel
Das folgende Beispiel zeigt die Verwendung von Tests. Es erstellt eine Basisanwendung, die für Affen verwendet werden kann.
Um mit diesem Beispiel zu experimentieren, müssen Sie dies auf einem tatsächlichen Gerät ausführen und dann den am Anfang erläuterten Affenschritten folgen.
Schritte | Beschreibung |
---|---|
1 | Mit Android Studio erstellen Sie eine Android-Anwendung unter dem Paket com.tutorialspoint.myapplication. |
2 | Ändern Sie die Datei src / MainActivity.java, um Aktivitätscode hinzuzufügen. |
3 | Ändern Sie das Layout einer XML-Datei res / layout / activity_main.xml und fügen Sie bei Bedarf eine beliebige GUI-Komponente hinzu. |
4 | Erstellen Sie die Datei src / second.java, um den Aktivitätscode hinzuzufügen. |
5 | Ändern Sie die Layout-XML-Datei res / layout / view.xml und fügen Sie bei Bedarf eine beliebige GUI-Komponente hinzu. |
6 | Führen Sie die Anwendung aus und wählen Sie ein laufendes Android-Gerät aus. Installieren Sie die Anwendung darauf und überprüfen Sie die Ergebnisse. |
Hier ist der Inhalt von MainActivity.java.
package com.tutorialspoint.myapplication;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
public class MainActivity extends AppCompatActivity {
Button b1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
b1=(Button)findViewById(R.id.button);
}
public void button(View v){
Intent in =new Intent(MainActivity.this,second.class);
startActivity(in);
}
}
Hier ist der Inhalt von second.java.
package com.tutorialspoint.myapplication;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
public class second extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.view);
Button b1=(Button)findViewById(R.id.button2);
b1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(second.this,"Thanks",Toast.LENGTH_SHORT).show();
}
});
}
}
Hier ist der Inhalt von activity_main.xml.
Im folgenden Code abc zeigt das Logo von tutorialspoint.com an
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="UI Animator Viewer"
android:id="@+id/textView"
android:textSize="25sp"
android:layout_centerHorizontal="true" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorials point"
android:id="@+id/textView2"
android:layout_below="@+id/textView"
android:layout_alignRight="@+id/textView"
android:layout_alignEnd="@+id/textView"
android:textColor="#ff36ff15"
android:textIsSelectable="false"
android:textSize="35dp" />
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/imageView"
android:src="@drawable/abc"
android:layout_below="@+id/textView2"
android:layout_centerHorizontal="true" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Button"
android:onClick="button"
android:id="@+id/button"
android:layout_below="@+id/imageView"
android:layout_centerHorizontal="true"
android:layout_marginTop="100dp" />
</RelativeLayout>
Hier ist der Inhalt von view.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent" android:layout_height="match_parent">
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="button"
android:id="@+id/button2"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorials point "
android:id="@+id/textView3"
android:textColor="#ff3aff22"
android:textSize="35dp"
android:layout_above="@+id/button2"
android:layout_centerHorizontal="true"
android:layout_marginBottom="90dp" />
</RelativeLayout>
Hier ist der Inhalt von Strings.xml.
<resources>
<string name="app_name">My Application</string>
</resources>
Hier ist der Inhalt von AndroidManifest.xml.
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.tutorialspoint.myapplication" >
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".second"></activity>
</application>
</manifest>
Versuchen wir, Ihre Android-Testanwendung auszuführen. Ich gehe davon aus, dass Sie Ihr aktuelles Android Mobile-Gerät mit Ihrem Computer verbunden haben. Um die App von Android Studio aus auszuführen, öffnen Sie eine der Aktivitätsdateien Ihres Projekts und klicken Sie in
Wählen Sie Ihr Mobilgerät als Option aus und überprüfen Sie dann Ihr Mobilgerät, auf dem der Anwendungsbildschirm angezeigt wird. Befolgen Sie nun einfach die oben im Abschnitt "Affen" genannten Schritte, um Tests für diese Anwendung durchzuführen.