我正在考虑建立一个新的,轻量级的数据库人口框架.我绝对讨厌dbunit.在我做之前,我想知道是否有人已经这样做了.
我不喜欢dbunit的事情:
1)不推荐使用最简单的编写和入门格式.他们希望您使用膨胀的格式.有些甚至需要xml架构.好吧,无所谓了.
2)它们不按您编写的顺序填充行,但是在顺序表中是在xml文件中定义的.这非常糟糕,因为您无法以外键约束不会导致问题的方式对数据进行排序.这只会迫使你彻底解决它们的麻烦.
这也会浪费时间并使你的junit基类膨胀,以包含禁用外键约束的代码.您可能必须测试数据库类型(hsqldb等)并以特定于数据库的方式禁用它们.这很糟糕.
如果dbunit有助于自动禁用外键约束作为其框架的一部分,但它们不会这样做.他们确实跟踪方言......所以为什么不使用它们呢?最终,所有这一切都迫使程序员浪费时间而不是快速起床和测试.
3)XML是一种痛苦的写作.我不需要多说这个.他们也提供了很多方法,我认为这只会使问题复杂化.只需提供一个非常可靠的方法并完成它.
4)当你的数据变大时,跟踪id及其一致/正确的关系是一种巨大的痛苦.
另外,如果你没有在一个月的项目上工作,你怎么记得user_id 1是管理员,user_id 2是业务用户,user_id 3是工程师而user_id 4是其他什么?回去检查这是浪费更多时间.除了任意数字之外,应该有一种有意义的方法来检索它.
5)这很慢.我发现除非使用hsqldb,否则它会非常缓慢.它不一定是.还有很多方法可以搞乱其配置,因为"开箱即用"并不容易.有一个驼峰,你必须通过它来使其正常工作.所有这一切都鼓励人们不要使用它,或者在他们开始使用它时感到生气.
6)有些值往往会重复很多,比如日期.指定默认值,甚至让框架自动设置默认值是很好的,即使没有告诉它将默认值放在那里.这样,您可以使用所需的值创建对象,并将其余部分保留.如果不需要,这肯定会指定列的每个角落和裂缝.
7)最令人烦恼的可能是第一个条目必须包含所有值 - 甚至是空占位符 - 或者将来的行不会选择您实际指定的列.
DBunit没有将[NULL]转换为实际空值的合理默认值.您必须手动添加它.告诉我,谁没有用dbunit做到这一点?每个人都有.它应该不是这样的!
这意味着如果你有一个多态对象,你必须声明第一行中每个子类的连接表的所有外键,即使它们是null.如果为所有子类模式执行表,则仍必须指定第一行上的所有字段.这太可怕了.
有什么东西可以满足我,或者我应该成为更好的数据库测试框架的下一个框架开发人员?
我对H2DB有一些疑问.我有H2DB数据库,它将数据存储在文件中,我有3个文件test.18.log.db,test.data.db,test.index.db.我想得到sql转储文件,就像我使用mysqldump时一样.可能吗?