某项目定期进行线上Bug分析大会,主要针对近期出现的Bug和事故进行分析其出现的原因。经过一段时间的数据分析和汇总,找到了在开发过程中,较为常见的Bug以及其出现的原因。
通过分析原因,进一步找到解决方案,从而有利于降低Bug出现率,提高测试质量和产品质量。常见的4种Bug如下:
1、开发人员使用java框架错误
这个问题出现频率较高,原因就是开发人在使用多线程时,将多例使用成单例,导致系统在高并发进出现了串数据的现象。虽然我们使用单例能节省资源,降低系统的占用率,但这种情况并不合适目前的系统。
而此种情况在测试过程中并不一定能测试出来,这种出现的机率不定,必须在数据高并发时才有可能出现。
解决方案:
技术问题,将单例修改成多例。单例模式确保只有一个对象实例存在,而多例模式则允许存在多个对象实例,需要注意两者间的区别。
在Spring框架中,你可以通过设置bean的scope属性为prototype来实现多例模式。请注意,多例模式在进行注入时,不能使用 @Autowired,否则注入的还是单例模式,实现多例模式需要使用工厂模式。
2、开发人员上线时合并代码有遗漏
合并代码时容易出现遗漏,当遇到冲突时,开发者需仔细检查并解决所有冲突。不同的合并策略可能会影响合并结果,因此需要选择了适合当前情况的合并策略。在手动合并代码时,需要正确地合并每一处差异,否则可能会导致遗漏或重复。
解决方案:
(1)仔细审查合并冲突:在解决冲突时,要逐行检查代码,确保所有的更改都被考虑到。
(2)使用合适的合并策略:根据项目的具体需求和工作流程选择最合适的合并策略。
(3)测试合并后的代码:合并完成后,进行彻底的测试,确保新的代码能够正常工作且与原有功能兼容。
(4)保持良好的版本控制习惯:定期提交更改,避免长时间的代码积累,这样在合并时冲突会更少,更易于管理。
(5)使用合并工具:利用图形化的合并工具,如GitKraken、SourceTree等,可以帮助更直观地查看和解决冲突。
(6)代码审查:在合并前后进行代码审查,可以发现可能遗漏的问题。
3、回归测试不全
回归测试不全,其实就是相当于一定程度上的漏测,漏测应该是软件测试人员尽量避免,一般漏测是因为测试人员思考不全,导致某个方面没有测试到。如回归测试时,验证某个流程,但只验证到任务创建,就没有执行任务,上线后,该任务创建后执行会报错。
解决方案:
(1)回归测试时,主流程必须回归,并且有完整的回归步骤。
(2)一个业务流程测试必须跑完一个完整流程。
(3)测试过程中一定要细致,不能遗漏重要的点。
为了进一步提高测试覆盖率,我们可以使用CoCode开发云中的自动生成测试用例功能,使用AI,自动生成每个需求的正向反向多维度测试用例,提高测试覆盖度和全面性,保障测试质量,减轻测试人员工作量,提高20%-30%工作效率。
4、多系统上线 缺少联调或联调不全
联调出现问题,是常见问题。公司业务是由有多个系统组成的,同时还需要调用其他公司业务接口,测试人员在测试时调用相关系统接口时模拟返回或回调,基本都是使用的mock,mock返回的值并不是真的从相应系统的返回值,所以如果联调测试时没有把握好,就非常容易出现问题。
解决方案:
(1)在联调之前先将自己系统中本次项目所有用例测试完全。
(2)编写联调用例,并且与多方测试人员沟通,确保联调用例能全面覆盖业务流程和任务。
(3)在联调时,确保所有业务流程是全部走通,且返回的值正确。
为了避免Bug问题的出现,开发人员需培养良好的编程习惯,而测试人员需要将测试范围考虑完全,尽量避免遗漏测试点,对于不清楚的点,需要重点讨论。