14

彼ら!新しい質問があります。さまざまなキャッシュマネージャーを使用してキャッシュにデータを追加していますが、問題に直面しています。junit と spring を使ってやっています。テストを実行すると、テスト メソッドはランダムに実行されますが、順番に実行する必要があります。どうやってするの??以下は、いくつかのコードと証明用のコンソール出力です。

サービス クラス:

@Service("HelloCache")
public class CacheServiceImpl implements CacheInterface {
    @Autowired
    @Qualifier("memcachedClient")
    private MemcachedClient mBean;

    public void Add(String key, Object object) {
        mBean.set(key, 12, object);
    }

    public void Get(String key) {
        mBean.get(key);
    }

    public void Delete(String key) {
        mBean.delete(key);
    }    
}

テストは次のとおりです。

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "file:src/main/java/spring.xml")
public class UsingMemcachedTest extends TestCase {
    @Autowired
    @Qualifier("HelloCache")
    private CacheInterface emcached;
    private byte[][] i = new byte[2500][3000];
    private String key = "j";
    @Test
    public void testAddBulkObjects() {
        System.out.println("");
        System.out.println("This is async BULK adding test");
        long time = System.currentTimeMillis();
        for (int k=1; k<=1000; k++) {
            emcached.Add(key+k, i);
        }
        long time2 = System.currentTimeMillis();
        long timeE=time2-time;
        System.out.println("Vremya add BULK objects: " + timeE);
        System.out.println("");
    }

    @Test
    public void testGetBulkObjects() {
        System.out.println("");
        System.out.println("This is getting BULK objects test");
        long time = System.currentTimeMillis(); 
        for (int k=1; k<=1000; k++) {
            emcached.Get(key+k);
        }
        long time2 = System.currentTimeMillis();
        long timeE=time2-time;
        System.out.println("Vremya Get object: " + timeE);
        System.out.println("");
    } 

    @Test
    public void testDeleteBulkObjects() {
        System.out.println("");
        System.out.println("This is deleting BULK objects test");
        long time = System.currentTimeMillis();
        for (int k=1; k<=1000; k++) {
            emcached.Delete(key+k);
        }
        long time2 = System.currentTimeMillis();
        long timeE=time2-time;
        System.out.println("Vremya delete object: " + timeE);
        System.out.println("");
    }

そして出力:

This is deleting BULK objects test
Vremya delete object: 137


This is getting BULK objects test
Vremya Get object: 703


This is async BULK adding test
Vremya add BULK objects: 87681

助けてください!!=)

4

3 に答える 3

48

バージョン 4.11 から、アノテーションとメソッド名による順序付けを使用して実行順序を指定できます。

import org.junit.Test;
import org.junit.FixMethodOrder;
import org.junit.runners.MethodSorters;

@FixMethodOrder(MethodSorters.NAME_ASCENDING)
public class MyTest {

    @Test
    public void test1Create() {
        System.out.println("first");
    }

    @Test
    public void test2Update() {
        System.out.println("second");
    }
}

JUnit 4.11 リリース ノートを参照してください。

于 2014-04-10T12:23:15.203 に答える
10

JUnit は、テストが実行される順序に関して約束をしません。順序は、テストが実行される環境とコンテキストによって異なります。

この理由 (およびその他の理由) から、テストの動作に影響を与える順序付けは非常に悪いテスト設計と見なされます。@Before go を使用して白紙の状態で作業し、そのテストの一部として特定のテストのセットアップを行うことができます。

次の質問に対する受け入れられた回答は、適切な説明といくつかの有用なリソースへのリンクを提供します: How to run test methods in specific order in JUnit4?

于 2013-04-02T00:30:35.377 に答える