使用LoaderTestCase测试异常

时间:2015-09-17 08:24:16

标签: android junit nullpointerexception loader android-testing

在我的Android JUnit测试用例begin -- try the insert insert... exception when dup_val_on_index then update... end; 中,我想测试我的Loader是否抛出异常或返回null。我看到测试中抛出LoaderTestCase,测试中止。

我试图抓住这样的例外:

NullPointerException

但是,不是捕获异常,而是LoaderTestCase正在中止,但有以下异常:

try {
    getLoaderResultSynchronously(new HistoricDataLoader(getContext(), url, username, password,
        https, md5, station, stationMetaData, from, to));
    // Expected exception wasn't thrown: fail.
    fail();
} catch (NullPointerException e) {
    // Expected exception was thrown. Success.
    Log.e(TAG, e.getMessage());
}

你能告诉我怎样才能

  • 测试我的方法java.lang.NullPointerException at java.util.concurrent.ArrayBlockingQueue.checkNotNull(ArrayBlockingQueue.java:126) at java.util.concurrent.ArrayBlockingQueue.offer(ArrayBlockingQueue.java:295) at java.util.AbstractQueue.add(AbstractQueue.java:66) at java.util.concurrent.ArrayBlockingQueue.add(ArrayBlockingQueue.java:282) at android.test.LoaderTestCase$2.onLoadComplete(LoaderTestCase.java:70) at android.content.Loader.deliverResult(Loader.java:144) at android.content.AsyncTaskLoader.dispatchOnLoadComplete(AsyncTaskLoader.java:265) at android.content.AsyncTaskLoader$LoadTask.onPostExecute(AsyncTaskLoader.java:92) at android.os.AsyncTask.finish(AsyncTask.java:632) at android.os.AsyncTask.access$600(AsyncTask.java:177) at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:645) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5086) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) at dalvik.system.NativeStart.main(Native Method)
  • 中引发的异常
  • 将null作为有效返回值吗?

修改

我知道如何在JUnit 4中测试异常。现在我正在使用JUnit 3进行Android测试,因此我会像在代码中看到的那样捕获它们。如果您的答案是我应该使用JUnit 4而不是JUnit 3,请解释为什么它应该有所作为。 抛出异常并中止方法HistoricDataLoader#loadInBackground()内的测试。它没有通过调用链,所以我不知道JUnit 4应该能够捕获它。

1 个答案:

答案 0 :(得分:0)

在jUnit 4中,你可以期待使用注释的例外,你的代码看起来像这样:

    @Test(expected=NullPointerException.class)
    public void loaderNpe() {
        getLoaderResultSynchronously(new HistoricDataLoader(getContext(), url,    username, password,vhttps, md5, station, stationMetaData, from, to));
    }