针对Sqlite进行单元测试出现的问题

单元测试是一个很好的工具,既可以从测试的角度检视自己代码逻辑,也可以找出代码中不易发现的bug.Android项目中的单元测试工具有很多,Junit,Mockito,Robolectric等,针对UI和其他逻辑搭配来使用,相关资料很多,大家可以自行搜集.我推荐两个人的吧,从他俩的博客里受益匪浅.

  1. 小创 一个蘑菇街出来的Android开发,单元测试以他写的文章入门最好不过了.

  2. 键盘男 悦跑圈Android开发,他的代码唯一的缺点就是不带github!不过文章质量挺高的,特别是针对Android各项功能的单元测试都有.

    其实今天的主题是我在做Sqlite的单元测试的时候碰到一个IllegalStateException,异常具体内容如下:


java.lang.RuntimeException: java.lang.IllegalStateException: Illegal connection pointer 1. Current pointers for thread Thread[pool-4-thread-1,5,main] 
//......

初看之下是线程之间的冲突,遂搜索之,找到这个链接,大致意思是 某个测试用例执行数据库之后没有执行关闭操作,然后下一个测试用例打开的时候出现错误,所以文章给出的做法是,@After注解一个关闭数据库的方法,代表每一个测试用例后都执行一次这个注解方法

我的做法是在Dao类里的每一个CRUD方法后都主动加上closeDatabase方法,这样就不需要在测试用例后再加After注解了.

转载于:https://my.oschina.net/lengwei/blog/1475483

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值