Conext:Mavenのフェイルセーフ統合テストプラグインで実行されるjunitテストクラスがあり、無限に並列化できるいくつかのテストがあります。彼らはすでに展開されているクラウドプラットフォームに対して、プロモーションを構築するためのゲートとして運営されています。これらのテストのそれぞれは、最初は速いメモリスパイクを持っていますが、その後の使用は非常に少なく、アクションが完了するまで基本的にポーリングします。junitでのスタガー並列テスト開始?
すべてのテストを並列に実行する必要があります(ジョブを高速化するスケーリング動作を引き起こす待ち行列に負荷がかかるため)。フェイルセーフで簡単ですが、メモリのスパイクも私は記憶を使い果たしてはいません。私はそれらをずらす達成すべきどのように
?現在の実装ではThread.sleep(random)
が実行されますが、十分な統計的確率で重複してメモリが足りなくなります。 Semaphore
をテストクラスに入れ、@Before
メソッドで待機する必要がありますか?これは私がカスタムJUnitランナーでもっと簡単にできることですか?
私もこの考えがありました。それは間違いなく機能しますが、私は自分の記憶を綿密に(1つずつ)守る必要があるかどうかはわかりません。おそらく一度に5人ほどが良いかもしれませんか?いずれにしても、それはうまくいくので、アップヴォートを持ってください。 –