使用Laravel 的你知道这个事情吗?
也许这只是我见识太少,对单元测试了解太少了!
今天在写自己小项目的单元测试时,遇到一个坑!~我登录后,想进行测试检测用户是否登录的操作!~
因为是登录后有进行用户信息缓存的,所以在检测是否登录时就是去缓存中进行查看,看是否有对应的Key的信息,如果有就将用户信息取出,并返回,如果没有则返回登录超时或未登录的响应。
但是今天写了个单元测试,死活不通过测试!~在排查问题过程中,发现
Cache::has($key)
总是返回false!signin时Cache::put($key, $user, $minutes);
两个$key 的值是一样的,可是为啥总是不行呢?
自己用redis-cli连接了redis客户端,用keys * 查看所有的键,发现并没有存到redis中!
可是我在.env 中配置的CACHE_DRIVER 明明是redis啊!~无奈我只好在调用Cache 时,打印了defaultDriver(Cache::getDefaultDriver())!~~你们猜结果是什么?
array , 我的天,为什么是 array 驱动?醉了,醉了,醉了!~
最后我只能使出杀手锏,
grep -r "CACHE_DRIVER " ./*
结果发现了这么一件事情:
./config/cache.php: 'default' => env('CACHE_DRIVER', 'file'),
./phpunit.xml: <env name="CACHE_DRIVER" value="array"/>
终于找到你:./phpunit.xml: <env name="CACHE_DRIVER" value="array"/>
原来是phpunit.xml 配置文件指定了在测试用例中使用的CACHE_DRIVER为array!~
好吧,我认输,我承认我知道的太少了!不过还好找到了原因,不然今晚估计睡不好了,哈哈!
现在改完了这里,测试用例通过了所有测试,可以安心睡觉了!~