Play框架:如何将数据库演变应用于假的applikation测试数据库

时间:2016-03-18 16:44:24

标签: java playframework playframework-2.4

我正在使用play框架2.4和ebean数据模型和演变。目前我正在尝试使用测试mysql数据库为我的模型编写第一个测试。在开始测试之前,我希望有一个干净的测试数据库。

到目前为止,我试过这个:

public class ModelUnitTest {

    public static FakeApplication app;

    @BeforeClass
    public static void startApp() {
        // Load test config  with testserver
        Map<String, String> settings = new HashMap<String, String>();
        settings.put("db.default.driver", "com.mysql.jdbc.Driver");
        settings.put("db.default.url", "jdbc:mysql://127.0.0.1:3306/sopra-ws1516-team10-test?autoReconnect=true&useSSL=false");
        settings.put("db.default.username", "root");
        settings.put("db.default.password", "root");
        settings.put("play.evolutions.autoApply", "true");
        settings.put("ebean.default", "models.ebean.*");
        app = play.test.Helpers.fakeApplication(settings);

        Evolutions.applyEvolutions(XXXXXX);

        Helpers.start(app);
    }



    @Test
    public void testCreateUser() {
        try {
            User testUser = User.createUser("Max", "Musterman", "01.01.1980", "max.mustermann@gmail.com", "1234");
            assertNotNull(testUser);
        } catch (Exception e) {
            assertNull(e);
        }
    }


    @AfterClass
    public static void stopApp() {
        Evolutions.cleanupEvolutions(XXXXXX);
        Helpers.stop(app);
    }

}

没有它的演变它可以工作,但问题是我开始测试时不能确定有一个空的数据库。我的解决方案是在我的测试之后应用evolutions并清理演变。这将为我的测试提供一个干净的环境。

但实际上不能在没有Evolutions对象的情况下使用Database类,并且似乎无法使用我的FakeApplication创建的数据库连接来创建数据库对象。 / p>

有人有解决此问题的方法吗?

1 个答案:

答案 0 :(得分:0)

我通过手动调用注射器解决了这个问题:

private static Database db;

@BeforeClass
public static void startApp() {
    ...
    app = play.test.Helpers.fakeApplication(settings);

    db = app.injector().instanceOf(Database.class);
    Evolutions.applyEvolutions(db);

    Helpers.start(app);
}

@AfterClass
public static void stopApp() {
    Evolutions.cleanupEvolutions(db);
    Helpers.stop(app);
}