使用LoaderTestCase测试异常



在我的Android JUnit测试用例中,一个LoaderTestCase,我想测试我的Loader是否抛出异常或返回null。我看到在测试中抛出了一个NullPointerException,并且测试被中止。

我试着像这样捕捉异常:

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());
}

但是,LoaderTestCase并没有捕捉到异常,而是抛出了以下异常:

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)

你能告诉我怎样才能

  • 测试异常抛出在我的方法HistoricDataLoader#loadInBackground()
  • 有null作为有效的返回值?
编辑:

我知道如何在JUnit 4中测试异常。现在我正在用JUnit 3做我的Android测试,因此我像代码中显示的那样捕获它们。如果您的答案是我应该使用JUnit 4而不是JUnit 3,请解释为什么这会产生差异。抛出异常并中止方法getLoaderResultSynchronously()中的测试。它没有在调用链上传递,所以我不明白JUnit 4应该如何能够捕获它。

在jUnit 4中,您可以期待使用注释的异常,您的代码可能看起来像这样:

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

相关内容

  • 没有找到相关文章

最新更新