简单搭建环境,测试Android应用

发布时间:2020-06-29 03:38:52 作者:鹭明
来源:网络 阅读:617

如果你编写完Android应用软件,要进行一个测试,可以学习这个方法,具体内容如下所示:

用Eclipse建立测试

首先搭建测试环境:

  1. 下载安装Eclipse ADT插件

  2. 导入或创建我们想要测试的Android应用项目。

  3. 生成一个对应于应用程序项目测试的测试项目。为导入项目生成一个测试项目: a.在项目浏览器里,右击我们的应用项目,然后选择Android Tools > New Test Project b.在新建Android测试项目面板,为我们的测试项目设置合适的参数,然后点击Finish

上面环境搭建好后可以进入创建与执行测试用例:


创建一个测试用例

Activity测试都是通过结构化的方式编写的。请务必把测试代码放在一个单独的包内,从而与被测试的代码分开。

按照惯例,测试包的名称应该遵循与应用包名相同的命名方式,在应用包名后接“.tests”。在创建的测试包中,为我们的测试用例添加Java类。按照惯例,测试用例名称也应遵循要测试的Java或Android的类相同的名称,并增加后缀“Test”。

要在Eclipse中创建一个新的测试用例可遵循如下步骤:

a. 在Package Explorer中,右键点击待测试工程的src/文件夹,New > Package

b. 设置文件夹名称<你的包名称>.tests(比如, com.example.android.testingfun.tests)并点击Finish

c. 右键点击创建的测试包,并选择New > Calss

d. 设置文件名称<你的Activity名称>Test(比如, MyFirstTestActivityTest),然后点击Finish

建立测试数据集(Fixture)

测试数据集包含运行测试前必须生成的一些对象。要建立测试数据集,可以在我们的测试中覆写setUp()和tearDown()方法。测试会在运行任何其它测试方法之前自动执行setUp()方法。我们可以用这些方法使得被测试代码与测试初始化和清理是分开的。

在你的Eclipse中建立测试数据集:

1 . 在 Package Explorer中双击测试打开之前编写的测试用例,然后修改测试用例使它继承ActivityTestCase的子类。比如:

public class MyFirstTestActivityTest
        extends ActivityInstrumentationTestCase2<MyFirstTestActivity> {

2 . 下一步,给测试用例添加构造函数和setUp()方法,并为我们想测试的Activity添加变量声明。比如:

public class MyFirstTestActivityTest
        extends ActivityInstrumentationTestCase2<MyFirstTestActivity> {    private MyFirstTestActivity mFirstTestActivity;    private TextView mFirstTestText;    public MyFirstTestActivityTest() {        super(MyFirstTestActivity.class);
    }    @Override
    protected void setUp() throws Exception {        super.setUp();
        mFirstTestActivity = getActivity();
        mFirstTestText =
                (TextView) mFirstTestActivity
                .findViewById(R.id.my_first_test_text_view);
    }
}

构造函数是由测试用的Runner调用,用于初始化测试类的,而setUp()方法是由测试Runner在其他测试方法开始前运行的。

通常在setUp()方法中,我们应该:

我们可以使用getActivity()方法得到正在测试的Activity的引用。

增加一个测试前提

我们最好在执行测试之前,检查测试数据集的设置是否正确,以及我们想要测试的对象是否已经正确地初始化。这样,测试就不会因为有测试数据集的设置错误而失败。按照惯例,验证测试数据集的方法被称为testPreconditions()

例如,我们可能想添加一个像这样的testPreconditons()方法:

public void testPreconditions() {
    assertNotNull(“mFirstTestActivity is null”, mFirstTestActivity);
    assertNotNull(“mFirstTestText is null”, mFirstTestText);
}

Assertion(断言,译者注)方法源自于JunitAssert类。通常,我们可以使用断言来验证某一特定的条件是否是真的。

在这两种情况下,Runner都会继续运行其它测试用例的测试方法。

添加一个测试方法来验证Activity

下一步,添加一个或多个测试方法来验证Activity布局和功能。

例如,如果我们的Activity含有一个TextView,可以添加如下方法来检查它是否有正确的标签文本:

public void testMyFirstTestTextView_labelText() {    final String expected =
            mFirstTestActivity.getString(R.string.my_first_test);    final String actual = mFirstTestText.getText().toString();
    assertEquals(expected, actual);
}

该 testMyFirstTestTextView_labelText() 方法只是简单的检查Layout中TextView的默认文本是否和strings.xml资源中定义的文本一样。

注意:当命名测试方法时,我们可以使用下划线将被测试的内容与测试用例区分开。这种风格使得我们可以更容易分清哪些是测试用例。

做这种类型的字符串比较时,推荐从资源文件中读取预期字符串,而不是在代码中硬性编写字符串做比较。这可以防止当资源文件中的字符串定义被修改时,会影响到测试的效果。

为了进行比较,预期的和实际的字符串都要做为assertEquals()方法的参数。如果值是不一样的,断言将抛出一个AssertionFailedError异常。

如果添加了一个testPreconditions()方法,我们可以把测试方法放在testPreconditions之后。

要参看一个完整的测试案例,可以参考本节示例中的MyFirstTestActivityTest.java。

构建和运行测试

我们可以在Eclipse中的包浏览器(Package Explorer)中运行我们的测试。

利用如下步骤构建和运行测试:

  1. 连接一个Android设备,在设备或模拟器中,打开设置菜单,选择开发者选项并确保启用USB调试。

  2. 在包浏览器(Package Explorer)中,右键单击测试类,并选择Run As > Android Junit Test

  3. 在Android设备选择对话框,选择刚才连接的设备,然后单击“确定”。

  4. 在JUnit视图,验证测试是否通过,有无错误或失败。


Gradle version 建立测试

  1. 连接Android真机或开启Android模拟器。

  2. 在项目目录运行如下命令:

./gradlew build connectedCheck






推荐阅读:
  1. fultter搭建环境
  2. DUL 恢复简单表测试

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

测试 应用 android

上一篇:地图与位置服务笔记

下一篇:MySQL之数据表控制语句

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》