时间:2021-05-26
相对于其它测试,数据库测试可以说是相对复杂繁琐的,因为数据库测试不可避免地会涉及到数据库的增删改查,而这些操作会影响数据库的数据,而我们测试最忌讳的就是修改了数据的测试,因为这样的话下次测试的时候,可能测试结果就会发生改变。
庆幸的是,laravel为我们提供了非常简洁的数据库测试方法,而且不会影响原数据。
use DatabaseMigrations
通过使用转移表,我们可以对数据进行。不过这就要求我们的数据是通过migration来生成的,如果直接在数据库创建的话,我们进行测试的时候就会提示:
SQLSTATE[HY000]: General error: 1 no such table: exchange_code
我们可以看下DatabaseMigrations的源码,可以看到它是trait,它会在执行测试之前
migrate:fresh
执行测试之后
migrate:rollback
这样的话就保证我们对数据库的操作都会进行回滚。
注意事项
这里的migrate:fresh 会删除掉所有表,然后重建数据.
use RefreshDatabase
这种方式回去判断是否是内存数据测试,如果是的话,因为是在内存操作,不影响数据库。
如果是mysql等数据库,它会启用事务,也就是我们测试的数据不会真的提交,测试完毕后,进行回滚,然后提交,也就是相当于我们对数据库什么也没做。
测试数据库的时候,我们都是使用工厂进行创建数据,否则你会发现即使数据库有数据,也是空的。
public function testGet() { factory(Exchange::class)->create(); $exchange = Exchange::select('code')->where('status', 0)->first(); $code = $exchange->code; $this->assertDatabaseHas('exchange_code', [ 'code' => $code, ]); }总结
到此这篇关于laravel使用数据库测试注意事项的文章就介绍到这了,更多相关laravel数据库测试内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在数据库中存储时,使用Bytes更精确,可扩展性和灵活性都很高。输出时,需要做一些适配。1.注意事项与测试代码1.需要考虑sizeInBytes为None的场景
数据库兼容,在开发项目过程中,难免会遇到更改数据库,或者后期项目升级,也可能会遇到这种情况,这里就说明下oralce和db2兼容开发注意事项。兼容oralce、
laravel中可以使用migration创建数据表,这使得数据库的迁移非常便利,下面介绍一下laravel中使用migration创建数据表的过程。数据库使用
新闻网站制作技术的注意事项。(一)数据库的连接。在实际的网站制作过程中,将会有更多的网站尝试使用交互技术,以此实现和浏览者之间的沟通和交流,但是在使用数据的时候
Oracle数据库服务器修改操作系统时间的注意事项:对单机或者ha1.对数据库本身而言,其实是没有影响的。因为scn不依赖于os时间2.对app(应用程序)而言