我正在使用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>
有人有解决此问题的方法吗?
答案 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);
}