【Play】異常処理

3050 ワード


【異常一、常にテストユニットを起動できない】
 
Playでは、Javaファイルに1つのクラス、またはネストされたクラスのみを含めることができます.
1つのJavaファイルに2つ以上のクラスが存在する場合、次の例外が報告されます.
これは、Playがソースコードをタイムリーにコンパイルして実行することと関係がある可能性があります.
 
appディレクトリの下にあるJavaファイルに2つ以上のクラスが含まれている場合、アプリケーションを起動すると例外が発生します.
testディレクトリの下にあるJavaファイルに2つ以上のクラスが含まれている場合、テストユニットを起動すると例外が発生します.
 
解決策:
クラスを1つのJavaファイルに置かないで独立します.
http://play.lighthouseapp.com/projects/57987/tickets/1379-unexpectedexception
 
 
play.exceptions.UnexpectedException: Unexpected Error
	at play.Play.start(Play.java:556)
	at play.test.PlayJUnitRunner.<init>(PlayJUnitRunner.java:34)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
	at java.lang.reflect.Constructor.newInstance(Constructor.java:525)
	at org.junit.internal.builders.AnnotatedBuilder.buildRunner(AnnotatedBuilder.java:31)
	at org.junit.internal.builders.AnnotatedBuilder.runnerForClass(AnnotatedBuilder.java:24)
	at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:57)
	at org.junit.internal.builders.AllDefaultPossibilitiesBuilder.runnerForClass(AllDefaultPossibilitiesBuilder.java:29)
	at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:57)
	at org.junit.internal.requests.ClassRequest.getRunner(ClassRequest.java:24)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.<init>(JUnit4TestReference.java:33)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestClassReference.<init>(JUnit4TestClassReference.java:25)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createTest(JUnit4TestLoader.java:48)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.loadTests(JUnit4TestLoader.java:38)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:452)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.lang.NullPointerException
	at play.classloading.ApplicationCompiler$2.acceptResult(ApplicationCompiler.java:266)
	at org.eclipse.jdt.internal.compiler.Compiler.compile(Compiler.java:478)
	at play.classloading.ApplicationCompiler.compile(ApplicationCompiler.java:282)
	at play.classloading.ApplicationClassloader.getAllClasses(ApplicationClassloader.java:426)
	at play.Play.start(Play.java:516)
	... 19 more