您的位置:首页 > 移动开发 > Android开发

Android日志输出、单元测试

2011-12-08 22:47 351 查看
Android日志输出、单元测试

由于这几天睡得晚,导致第二天都没有精神,还晕晕的听课,效率低,我不能熬夜了。下面我来讲讲今天学习的知识点吧。

一、 单元测试

有了测试以后我们遇到bug的时候就好解决了。

单元测试需要以下几步:

1. 首先要在AndroidManifest.xml中加入如下代码:

<uses-library android:name=”android.test.runner”/>这行代码必须只能放在

<application></ application >元素之内,与<activity></activity>平级。

<instrumentation android:name=”android.test.InstrumentationTestRunner”

Android:targetPackage=”cn.class3g.action”android:label=”Tests for My App”

>这行代码放在<manifest></manifest>之中。这里的targetPackage指定的包和应用的package相同。如果不相同,就会出现找不到单元测试用例的错误。

2. 编写单元测试代码 测试类必须继承自AndroidTestCase类。

3. 执行测试

让我们来看一个具体的测试项目的实现吧:
1. 创建项目:
创建名为JunitTest的项目
2.在功能清单文件中配置单元测试环境;
打开功能清单文件,添加上面所述的代码,最终代码如下;
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="cn.class3g"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdkandroid:minSdkVersion="10" />

<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >

<uses-library android:name="android.test.runner"/>

<activity
android:label="@string/app_name"
android:name=".JunitHaoActivity" >
<intent-filter >
<action android:name="android.intent.action.MAIN"/>

<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
<instrumentation android:name="android.test.InstrumentationTestRunner"
android:targetPackage="cn.class3g" android:label="Tests/>
</manifest>

新建测试用例
首先在项目位置,右击新建一个UserTests类,在创建这个类的时候要继承AndroidTestCase类;
注意:如果测试方法内部遇到异常,建议直接抛出,而不要捕获异常。异常抛出后会被测试框架获取,之后在控制台显示出来,方便我们了解异常信息。
集体的类文件如下:
package cn.class3g;

packagecom.sharpandroid.unitandlog;

import junit.framework.Assert;

import android.test.AndroidTestCase;

import android.util.Log;

public classUserTest extends AndroidTestCase{

private static final StringTAG = "MyTest";

public void testSave()throws Throwable{

int i= 4+8;

Assert.assertEquals(5,i);

}

}
Assert类在此的作用是判断所得到的结果与期望值的关系。这里判断i是否等于5。如果相等则通过,不相等,则抛出异常。

运行测试用例:
首先要进入大纲视图(outline),如果默认的界面中没有的话,可以通过以下步骤:
window-----showView----outline 就可以了!

在大纲视图中找到自己的测试类,然后展开,找到集体的方法,然后选定右击,选择Run as----Android Junit Test 就可以了;
观看结果条,如果是红色说明没有通过,代码有问题,如果是绿色就说明测试通过了。

二、日志输出

我们在开发Android应用时,控制台不会打印出字符串,该字符串会在LogCat中打印出来。在程序中进行信息输出,一般采用android.util.Log类的静态方法就可以实现。Log类所输出的日志的内容从少到多分别是ERROR,WARN,INFO,DEBUG,VERBOSE,对应五种不同类型的首字母,分别对应有Log.e( )、Log.w( )、Log.i()、Log.d( )、Log.v( )五种静态方法。

让我们来编写一个日志输出的测试类吧
package cn.class3g;
import junit.framework.Assert;

import android.test.AndroidTestCase;

import android.util.Log;

public class UserTest extendsAndroidTestCase{

private static final StringTAG = "tag";

public void testSave()throws Throwable{
int i= 4+8;
Log.i(TAG, "i = " + i);
Assert.assertEquals(5,i);
}

}

说明:
Log.i(Stringtag,String msg);
tag:为这条信息定义一个标签,在开发时通常采用其所在类的类名,这样方便我们追踪输出的信息。也方便我们在看到信息时知道其由哪个类输出。
msg:该参数为希望输出的信息的内容。 一般将第一个参数定义成一个静态常量。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: