junitはマルチスレッドのテストに使用できません
1605 ワード
スレッドクラス:
テストクラス:
出力結果:
オンラインクラスでは10000個の数字をループ印刷するが、テストクラスでは一部のみ印刷する.テストクラスでsleep()のコメントを外すと、すべての数字を印刷することができる.コードを通常のmain()に入れて実行すると、すべての数字を印刷することもできます.
実はjunitはtestをパラメータとしてTestRunnerに渡したmain関数です.main関数で実行します.test関数はmainで実行されます.test実行が終了するとmainはSystemを呼び出す.exit(0);他のスレッドが実行する場合でもmainはSystemを呼び出す.exit(0);System.exit()はシステム呼び出しであり、jvmの実行が直ちに終了することを通知し、jvmにスレッドが実行されていてもjvmは停止します.だから前のような状況が起こります.その中でSystem.exit(0);のパラメータが0の場合、システムが正常に終了したことを示し、0でない場合、システムが異常に終了したことを示します.
junit TestRunner部分ソースコード:
public class Thread1 implements Runnable {
@Override
public void run() {
// TODO Auto-generated method stub
for(int i=0;i<10000;i++){
System.out.print(i+" ");
}
}
}
テストクラス:
public class MultiThreadTest {
@Test
public void test() throws IOException, InterruptedException{
Runnable Thread1 = new Thread1();
new Thread(Thread1).start();
// Thread.sleep(10000);
System.out.println(" main thread terminate");
}
}
出力結果:
terminate
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
まとめ:
オンラインクラスでは10000個の数字をループ印刷するが、テストクラスでは一部のみ印刷する.テストクラスでsleep()のコメントを外すと、すべての数字を印刷することができる.コードを通常のmain()に入れて実行すると、すべての数字を印刷することもできます.
実はjunitはtestをパラメータとしてTestRunnerに渡したmain関数です.main関数で実行します.test関数はmainで実行されます.test実行が終了するとmainはSystemを呼び出す.exit(0);他のスレッドが実行する場合でもmainはSystemを呼び出す.exit(0);System.exit()はシステム呼び出しであり、jvmの実行が直ちに終了することを通知し、jvmにスレッドが実行されていてもjvmは停止します.だから前のような状況が起こります.その中でSystem.exit(0);のパラメータが0の場合、システムが正常に終了したことを示し、0でない場合、システムが異常に終了したことを示します.
junit TestRunner部分ソースコード:
junit.textui.TestRunner
public static void main (String[] args) {
TestRunner aTestRunner = new TestRunner();
try {
TestResult r = aTestRunner.start(args);
if (!(r.wasSuccessful()))
System.exit (1);
System.exit(0);
} catch (Exception e) {
System.err.println(e.getMessage());
System.exit(2);
}
}