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:该参数为希望输出的信息的内容。 一般将第一个参数定义成一个静态常量。