本来以为在android上实现单元测试,应该是很简单的一件事,结果还是花费了一些功夫,主要是在配置文件,和测试环境上花费了不少时间,比想像中要复杂一些,不过也没什么高深的东西,下面简单讲一下。
第一步:新建一个TestCase,记得要继承AndroidTestCase,才能有getContext()来获取当前的上下文变量,这在android测试中很重要的,因为很多的android api都需要context。
public class TestMath extends AndroidTestCase {
private int i1;
private int i2;
static final String LOG_TAG = "MathTest";
@Override
protected void setUp() throws Exception {
i1 = 2;
i2 = 3;
}
public void testAdd() {
assertTrue("testAdd failed", ((i1 + i2) == 5));
}
public void testDec() {
assertTrue("testDec failed", ((i2 - i1) == 1));
}
@Override
protected void tearDown() throws Exception {
super.tearDown();
}
@Override
public void testAndroidTestCaseSetupProperly() {
super.testAndroidTestCaseSetupProperly();
//Log.d( LOG_TAG, "testAndroidTestCaseSetupProperly" );
}
}
第二步:新建一个TestSuit,这个就继承Junit的TestSuite就可以了,注意这里是用的addTestSuite方法,一开始使用addTest方法就是不能成功。
public class ExampleSuite extends TestSuite {
public ExampleSuite() {
addTestSuite(TestMath.class);
}
}
第三步:新建一个Activity,用来启动单元测试,并显示测试结果。系统的AndroidTestRunner竟然什么连个UI界面也没有实现,这里只是最简单的实现了一个
public class TestActivity extends Activity {
private TextView resultView;
private TextView barView;
private TextView messageView;
private Thread testRunnerThread;
private static final int SHOW_RESULT = 0;
private static final int ERROR_FIND = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
resultView = (TextView)findViewById(R.id.ResultView);
barView = (TextView)findViewById(R.id.BarView);
messageView = (TextView)findViewById(R.id.MessageView);
Button lunch = (Button)findViewById(R.id.LunchButton);
lunch.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
startTest();
}
});
}
private void showMessage(String message) {
hander.sendMessage(hander.obtainMessage(ERROR_FIND, message));
}
private void showResult(String text) {
hander.sendMessage(hander.obtainMessage(SHOW_RESULT, text));
}
private synchronized void startTest() {
if (testRunnerThread != null
&& testRunnerThread.isAlive()) {
testRunnerThread = null;
}
if (testRunnerThread == null) {
testRunnerThread = new Thread(new TestRunner(this));
testRunnerThread.start();
} else {
Toast.makeText(this,
"Test is still running",
Toast.LENGTH_SHORT).show();
}
}
public Handler hander = new Handler() {
public void handleMessage(Message msg) {
switch (msg.what) {
case SHOW_RESULT:
resultView.setText(msg.obj.toString());
break;
case ERROR_FIND:
messageView.append(msg.obj.toString());
barView.setBackgroundColor(Color.RED);
break;
default:
break;
}
}
};
class TestRunner implements Runnable, TestListener {
private Activity parentActivity;
private int testCount;
private int errorCount;
private int failureCount;
public TestRunner(Activity parentActivity) {
this.parentActivity = parentActivity;
}
@Override
public void run() {
testCount = 0;
errorCount = 0;
failureCount = 0;
ExampleSuite suite = new ExampleSuite();
AndroidTestRunner testRunner = new AndroidTestRunner();
testRunner.setTest(suite);
testRunner.addTestListener(this);
testRunner.setContext(parentActivity);
testRunner.runTest();
}
@Override
public void addError(Test test, Throwable t) {
errorCount++;
showMessage(t.getMessage() + "\n");
}
@Override
public void addFailure(Test test, AssertionFailedError t) {
failureCount++;
showMessage(t.getMessage() + "\n");
}
@Override
public void endTest(Test test) {
showResult(getResult());
}
@Override
public void startTest(Test test) {
testCount++;
}
private String getResult() {
int successCount = testCount - failureCount - errorCount;
return "Test:" + testCount + " Success:" + successCount + " Failed:" + failureCount + " Error:" + errorCount;
}
}
}
第四步:修改AndroidManifest.xml,加入<uses-library android:name="android.test.runner" />,不然会提示找不到AndroidTestRunner,这里需要注意是这句话是放在applications下面的,我一开始也不知道,放错了地方,浪费了不少时间
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.test.sample"
android:versionCode="1"
android:versionName="1.0">
<application android:icon="@drawable/icon" android:label="@string/app_name" android:debuggable="true">
<activity android:name=".TestActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<uses-library android:name="android.test.runner" />
</application>
<uses-sdk android:minSdkVersion="4" />
</manifest>
分享到:
相关推荐
在Android上实现Junit单元测试的四部曲
我们曾经和大家探讨过全面剖析JavaME单元测试理念,其实在Android上实现JUnit单元测试也不是很困难,主要是在配置文件和测试环境上将花费很长时间,下面从四步简单讲一下在Android上实 我们曾经和大家探讨过全面...
Android 单元测试,JUnit的4大功能 1. 管理测试用例。修改了哪些代码,这些代码的修改会对哪些部分有影响,通过JUnit将这次的修改做个完整测试。这也就JUnit中所谓的TestSuite。 2. 定义测试代码。这也就是JUnit中...
全面的android应用单元测试方法及案例 1.0版本 结合Junit Mockito与Robolectric实现对MVP架构下数据层,视图层,逻辑层覆盖率100%的全面单元测试
本文是在上一篇文章《java编程之单元测试(Junit)实例分析》的基础上继续讲解android的单元测试,android源码中引入了java单元测试的框架(android源码目录:libcore\junit\src\main\java\junit\framework中可见),...
第一,就是java程序员最为熟悉和常用的JUnit,但是由于目前androidsdk(version1.1)中只是提供了stubbedmethods/classes,没有具体的实现代码,所以如果用JUnit的话,我们需Android单元测试 如果想在android里面做...
相对于集成测试,灰度测试,单元测试是测试体系中最贴近代码实现的测试,其测试方式主要是以白盒为主,由开发人员完成。毫无疑问,最接近开发的测试是可以最早发现问题的测试,在这一步发现问题,就可以有效避免问题...
下篇对单元测试用例 测试的生命周期 自动化测试等均进行深入的分析与讲解 并结合模板方法模式 适配器模式 组合模式等深入解析JUnit框架的设计和实现思路 part1 总共2部分">从整体上来看 一款Android产品分为设计 ...
下篇对单元测试用例 测试的生命周期 自动化测试等均进行深入的分析与讲解 并结合模板方法模式 适配器模式 组合模式等深入解析JUnit框架的设计和实现思路 part2 总共2部分">从整体上来看 一款Android产品分为设计 ...
利用monkey进行压力测试,利用Junit进行单元测试 3、数据存储与访问 主要介绍存储文件到外部存储器和内部存储器,利用系统提供的API获取路径时,需要精准的掌握他们的目录层级。在将数据保存到SDCard时,需要判断...
测试气味被定义为单元测试代码中的不良编程实践(例如,测试用例的组织方式,实现方式以及彼此之间的交互方式),这些行为表明了测试源代码中潜在的设计问题。 项目概况 该项目的目的是双重的: 通过提出开发人员...
本程序是一个SQLite的规范使用示例,程序涉及到: SQLite 增、删、改、查、SQL版本更新,ListView创建条目生成,单个条目点击事件处理,程序中通过Junit来实现单元测试。
测试:有效的单元测试和界面测试以确保应用的各个部分都能正常工作。项目可能包含JUnit和Espresso框架编写的测试用例。这个大作业不仅适合作为学术用途,也适合初学者想要了解如何在Android平台上构建一个完整的电商...
没有通过TCP传输进行RTU的单元测试 无法将AbstractSerialTransportListener添加到ModbusSlave ,这意味着您无法得知库何时在发送和接收之间切换 重构是过期的,以隐藏软件包组件,以鼓励最佳实践使用模式 依存关系 ...
该项目包括一个使用 JUnit 编写单元测试的示例。 源代码和测试位于 CodeParser\src\codeparser。 CourseManager 示例 Android 应用程序,提供课程管理系统。 源代码位于 CourseManager/src/...
依赖项:- 我们的项目依赖于这些 3rd 方工具来成功编译和运行我们的项目:- JUnit 3.8.1 :- 用于单元测试。 sqlite-jdbc-3.8.7 :- 用于数据库管理服务。 apache-maven-3.2.3 :- 作为我们的构建自动化工具。 与我们...