3

サーブレットに接続するための JUnit テスト (GWT で作成) が必要です (内部で GAE 呼び出しを使用)。テストを実行すると、次のスタック トレースが表示されます。

java.lang.NullPointerException
    at com.google.appengine.api.NamespaceManager.get(NamespaceManager.java:101)
    at com.google.appengine.api.memcache.BaseMemcacheServiceImpl.getEffectiveNamespace(BaseMemcacheServiceImpl.java:65)
    at com.google.appengine.api.memcache.AsyncMemcacheServiceImpl.doGet(AsyncMemcacheServiceImpl.java:295)
    at com.google.appengine.api.memcache.AsyncMemcacheServiceImpl.contains(AsyncMemcacheServiceImpl.java:283)
    at com.google.appengine.api.memcache.MemcacheServiceImpl.contains(MemcacheServiceImpl.java:44)
    at com.peerkesoftware.etheria.web.server.model.UpdateTimer.<init>(UpdateTimer.java:17)
    at com.peerkesoftware.etheria.web.server.UpdateTimerServlet.<init>(UpdateTimerServlet.java:12)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
    at java.lang.Class.newInstance0(Class.java:355)
    at java.lang.Class.newInstance(Class.java:308)
    at org.mortbay.jetty.servlet.Holder.newInstance(Holder.java:153)
    at org.mortbay.jetty.servlet.ServletHolder.getServlet(ServletHolder.java:339)
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:463)
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.Server.handle(Server.java:324)
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
    at org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:829)
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:513)
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488)

なぜこれが起こっているのか誰かが私に説明できますか? どうすればこれを解決できますか?テストを実行する前に何かを初期化する必要がありますか?

GWT バージョン 2.5.1 と GAE バージョン 1.7.5 を使用しています。

私のコードはGitHubで見ることができます。

4

2 に答える 2

3

私は自分でそれを理解しました。

私が使用した解決策: LocalServiceTestHelper を作成し、サーブレットへの呼び出しを行う前にこれを設定します。次に、私の JUnit テストはすべて緑色です。

于 2013-03-25T15:01:43.990 に答える
2

null ポインター例外をスローする 101 行目は、https://code.google.com/p/googleappengine/source/browse/trunk/java/src/main/com/google/appengine/api/NamespaceManager.javaに対応します。

Map<String, Object> attributes =ApiProxy.getCurrentEnvironment().getAttributes();

ApiProxy.getCurrentEnvironment() が null を返していると推測しています。

解決策: war/WEB-INF/web.xml を GAEApplicationServlet ではなく ApplicationServlet に編集します。

GWT クライアント側の単体テストは、サーバー側の奥深くまで実行するべきではないことを指摘したいと思います。モックを使用するか、サーバー側のクラスが GWT テストから呼び出されないようにして、GWT テストを高速化し、クライアント固有に保つ必要があります。

于 2013-03-25T03:38:32.380 に答える