ride日志不显示

之前写过一篇《RIDE的日志怎么不见了》,那篇主要是由于IEDriver或ChromeDriver存在进程导致的RIDE下面的日志不见。如果是在做web测试的同学遇到RIDE日志不见了请参考这篇。


今天说的这个问题,是近期新出现的一个频率比较高的问题,具体为啥出现不太清楚,做了一个临时方案,分享给大家。


先看问题表现:


最近有同学出现这种错误(借图),和之前不同的是从上方的记录看,案例没有运行完成,之前那个还有个运行结果,这个基本上直接就是finished了。单纯从这里看不出什么问题。


遇到这种情况的时候,请打开命令行输入ride.py,按回车打开RIDE,再次运行你的案例,如果还是有上面图中不出现日志的情况,请回到命令行界面查看一下是否有报错信息(很多RIDE有关的问题都可以这样来发现):


可以看到这里报了一个UnicodeDecodeError,具体原因不晓得,推测是和报告里出现了某些特定字符,0xb2是什么不太清楚,因为我这边没出现过这样的情况,所以无法确认具体是什么字符,有机会的话让我远程调试一下也可以。


从报错日志找问题,很显然不太适合去utf-8.py这里去做改动,因为这是个比较公共的库了,那么找到前一处报错,是在Python27\Lib\site-packages\robotide\contrib\testrunner下的testrunner.py文件的第400行pop方法里的这一句:

return result.decode('UTF-8')


那我们进入这个目录:



用Python的IDLE打开testrunner.py,其他工具最好是Python常用的IDE,避免用文本工具改的缩进有问题,如果你改完后发现报错信息是IndentationError: unexpected indent,通常就是缩进有问题。


在源码文件里找到这个pop函数,可以看到出错的那行语句:


我的方案只能是个临时方案,因为没有找到具体报错的字符,所以不确定原因,有谁有出错的会自己改脚本的可以在return前面print result,看看具体是什么内容。我的方案就是加个try catch:


注意try是和for对其的,这里的代码如下:

try:

    result=result.decode('UTF-8')

except UnicodeDecodeError:

    pass

return result


主要作用就是判断出现了UnicodeDecodeError的异常的时候,直接用pass过滤,然后不做decode,直接return result,当然如果没有异常,那么原先的decode逻辑已经做了,所以可以解决掉前面日志不见的问题。


如果不会修改的同学,可以在我的共享里下载这个文件,注意:我的文件是基于RIDE1.5.2.1版本修改的,其他版本建议自己修改,直接替换可能会有其他错误,或者升级RIDE到1.5.2.1版本后再替换。

文件地址:http://t.cn/RqOcsbt

替换到Python27\Lib\site-packages\robotide\contrib\testrunner下,覆盖同名文件,建议同时删除testrunner.pyc文件。


然后重新打开RIDE,此时应该已经恢复了正常。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值