【实测】关于‘钱学森弹道’应用软件测试的设计与实现(02)【4个具体方案】

简介: 【实测】关于‘钱学森弹道’应用软件测试的设计与实现(02)【4个具体方案】

   实测系列是纯硬核技术文章,并且是博主亲自演示已经落地取得一定成果的技术和原创教程,无偿进行分享,大家一键三连,支持一下!

   上一节,我们大致明白了钱学森弹道技术应用在软件测试领域的背景和意义,算是补足了一个小技术黑洞。本节课我们就来讨论下实现的方案有哪些?毕竟是要在无数个随机方向事件后能确定走到目标的技术,在外界眼里看起来,这发导弹或者说自动化driver,就像在故意做着很多战术性欺骗动作,最终冷不丁的突然实现目的。

    下面开始说说实现思路,大致有以下几点:

   1. 完全随机碰撞法

    在ui自动化的过程中,我们把模拟人手进行操作的驱动driver比作是这枚按照钱学森弹道的导弹。完全随机碰撞法,姑且先叫这个名字。

   意思就是driver的具体操作是没有方向的,完全凭随机,在driver走到每个节点(页面)后都会完全随机的操作而去到另一个节点或促进另一个步骤,所以在A->E的过程中,运气最好的最短路程是直接A-B-C-D-E,运气不好的情况下,就可能是A-B-A-B-C-B-A-B-C-D-B-...(n多步骤)...-D-E,当然,步骤越多,就越偏离真实用户的操作,所以可以给这个办法设置一个最大步骤数,比如还是房源下单流程,正常下单是5步,那我们就可以划定范围为最大20步,当我们的程序启动后,会生成很多个路线,其中但凡超过20步,就直接终止废弃,经过相当长时间后,查重率接近90%(或某个其他阙值)后,终止程序。此时我们就会获得相当数量的低于20步的路线用例了,然后可以用driver去自动执行这些用例即可。

   这个方法的优点是算法比较简单,很容易实现,相当于在传统monkey的基础上,增加了目标点(即:终止条件),又规定了最大步骤数,又可以记录路线用例,又进行去重。但其中的回头路走的实在太多,确实不太像正常用户的行为。下面介绍改进方案:

   2. 免回头随机法

   依然是这个driver,在各个节点的随机动作中,进行了方向的指定,避免了走大量回头路的可能(或者规定最多走一步回头路,比如下错订单返回修改,然后修改后继续提交)。

   所以在这个过程中,我们需要监控,一旦driver在节点随机时出现了回头现象,也就是走刚走过的节点,就进行记录,超过最大可回头数就直接过滤掉更古老的回头节点。

   比如规定最大回头数0 ,即不可回头:A-B-C ,当driver在C节点继续随机下一步的时候,就要自然而然的过滤掉刚刚走过的B节点。

   如果规定最大回头数1,即最多回头1次:A-B-C,当driver在C节点继续随机下一步的时候,我们是允许走回B节点的,但要过滤A节点。也就是说:我们允许【A-B-C-B-A之外节点】,但不允许【A-B-C-B-A】,如果C可以直接返回到A的话也不允许【A-B-C-A】。

   这个方法下,我们可以直接避免大量回头太多的现实场景基本不出现的路线用例,性价比得到了显著提高。但,本质上,仍然是随机法,不具备钱学森弹道的目标趋向性,也极有可能出现死循环路线,如【A-B-C-B-C-B-C....】,也就是说,距离最真实用户行为还是有差距。所以继续看优化方案:

 3.行为模拟随机法

     其实,如果你能拿到你们线上服务器的用户日志或埋点数据,就可以统计出很多信息,比如各个页面的用户操作占比。

   举个例子:用户在某产品详情页,点开评价的行为占比50%,点开商铺主页的行为占比10%,直接下单的占比30%,返回上一层的占比10%。

   此时你就会发现,这其实并非完全随机的概率,并非是等分1/4。所以,用更少的用例来,覆盖最真实的场景,就成了性价比更高的方案。此时在我们的driver算法中,在某个节点后,在下一个操作的随机选择算法中,就要按照具体的日志统计,来强行改变概率。

   比如你随机的列表是[评价,主页,下单,返回] ,此时随机就是1/4。如果改成如下方案[评价,评价,评价,评价,评价,主页,下单,下单,下单,返回] ,即可模拟出大致概率,这个列表页并非我们手动设置,只需要去读取线上日志自动生成即可,并不难。难的是,影响概率的情况是比较多的,不能取单一的片段,比如早上和晚上,工作日和节假日,双十一和平时。而软件产品的性能和线上服务器的动态调控负载均衡等问题,也可能会影响测试效果,这些都需要和开发运维同事合作来制定具体计划哦~ 。

   但这种方案是需要大量线上日志来模拟出用户真实动作的,如果我们不具备这个条件呢?我只是个小测试,没有调取线上生产环境服务器日志的权限。所以你要来看看更优化的方案:目标趋向随机法

   欢迎继续收看本系列!

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
7天前
|
测试技术 数据安全/隐私保护
深入理解与应用软件测试中的边界值分析法
【4月更文挑战第23天】在软件测试的诸多技术中,边界值分析法因其简洁性和高效性而备受青睐。本文旨在探讨边界值分析法的核心原理及其在实际测试场景中的应用。通过对边界条件进行系统的识别、分类和测试,该方法能够有效地发现软件缺陷。我们将详细讨论如何确定边界值,设计测试用例,以及如何处理复杂数据类型的边界情况。此外,文章还将展示通过案例研究来验证边界值分析法在提升测试覆盖率和发现潜在错误方面的实际效益。
|
8天前
|
机器学习/深度学习 敏捷开发 人工智能
深入探究持续集成在软件测试中的应用
【4月更文挑战第23天】 随着敏捷开发和DevOps文化的普及,持续集成(CI)已成为软件开发生命周期中不可或缺的一环。本文旨在剖析持续集成如何革新软件测试流程,提升测试效率及质量。文中不仅探讨了CI的基本原理与架构,还细致地分析了其对测试自动化、快速反馈以及质量控制的显著影响。同时,通过实际案例分析,揭示了实施CI的最佳实践及其面临的挑战。最终,文章提出了未来持续集成在测试领域可能的发展方向,为软件测试专业人士提供了前瞻性的参考。
|
8天前
|
Linux Android开发
测试程序之提供ioctl函数应用操作GPIO适用于Linux/Android
测试程序之提供ioctl函数应用操作GPIO适用于Linux/Android
12 0
|
1天前
|
敏捷开发 机器学习/深度学习 Java
Java中的异常处理机制深入理解与实践:持续集成在软件测试中的应用探索自动化测试在敏捷开发中的关键作用
【4月更文挑战第29天】在Java编程中,异常处理是一个重要的概念。它允许开发者在程序执行过程中遇到错误或异常情况时,能够捕获并处理这些异常,从而保证程序的稳定运行。本文将详细介绍Java中的异常处理机制,包括异常的分类、异常的处理方式以及自定义异常等内容。 【4月更文挑战第29天】 随着敏捷开发和DevOps文化的兴起,持续集成(CI)已成为现代软件开发周期中不可或缺的一环。本文将探讨持续集成在软件测试领域内的关键作用、实施策略以及面临的挑战。通过对自动化构建、测试用例管理、及时反馈等核心要素的详细分析,揭示持续集成如何提高软件质量和加速交付过程。 【4月更文挑战第29天】 在当今快速发
|
2天前
|
敏捷开发 测试技术 持续交付
深入探究持续集成在软件测试中的应用与优化
【4月更文挑战第28天】随着敏捷开发模式的普及,持续集成(Continuous Integration, CI)已成为软件开发工作流中不可或缺的一环。本文将深入探讨CI在软件测试领域的关键作用,分析其如何提升测试效率和质量,并指出实践中常见的挑战及解决策略。通过对自动化测试流程、测试驱动开发(TDD)以及持续部署(CD)等关键技术的综合运用,揭示了构建高效、可靠软件系统的方法论。
|
3天前
|
敏捷开发 Devops 测试技术
深入探究持续集成在软件测试中的应用与优化
【4月更文挑战第28天】随着敏捷开发和DevOps文化的兴起,持续集成(CI)已经成为现代软件开发不可或缺的一环。本文将探讨持续集成在软件测试领域的关键作用,分析其如何提高测试效率、确保产品质量,并指出实施过程中可能遇到的挑战及相应的解决策略。通过案例研究和最佳实践的分享,旨在为读者提供一套系统的持续集成优化方案,以支持更高效、更可靠的软件发布流程。
|
5天前
|
敏捷开发 运维 jenkins
探索自动化测试在敏捷开发中的应用与挑战
【4月更文挑战第25天】 在当今软件开发的快速迭代周期中,敏捷方法论已成为推动项目高效进行的关键。本文聚焦于自动化测试技术在敏捷开发环境下的应用实践,分析了其在提升软件交付速度和质量方面发挥的核心作用。通过深入探讨自动化测试框架的选择、测试用例设计、持续集成的实施等关键技术点,揭示了在多变的需求面前如何维持测试覆盖率和准确性。同时,本文也识别了实施过程中可能遇到的挑战,如资源分配、工具选型以及团队协作等,并提出了相应的解决策略。
|
6天前
|
Java 测试技术 持续交付
深入理解与应用Selenium WebDriver进行自动化测试
【4月更文挑战第25天】 在现代软件开发过程中,自动化测试已成为确保产品质量和加速市场发布的关键步骤。Selenium WebDriver作为业界广泛采用的自动化测试工具之一,提供了一种灵活且高效的方式来模拟用户与Web应用程序交互。本文将探讨Selenium WebDriver的核心概念、架构以及实际应用中的技巧和最佳实践。通过深入分析其工作原理及常见问题解决方案,旨在帮助测试工程师提升测试效率,确保测试结果的准确性和可靠性。
|
7天前
|
人工智能 监控 数据处理
【AI大模型应用开发】【LangSmith: 生产级AI应用维护平台】1. 快速上手数据集与测试评估过程
【AI大模型应用开发】【LangSmith: 生产级AI应用维护平台】1. 快速上手数据集与测试评估过程
27 0
|
13天前
|
敏捷开发 设计模式 测试技术
探索自动化测试在持续集成中的应用与挑战
【4月更文挑战第17天】 随着敏捷开发和持续集成(CI)实践的普及,自动化测试已成为确保软件质量和加速产品上市的关键。本文聚焦于自动化测试在持续集成环境中的有效运用,分析了实施过程中的挑战,并提出了优化策略。通过深入探讨自动化测试工具的选择、测试脚本的维护以及测试数据的管理等关键要素,文章旨在为软件开发团队提供实用的指导,帮助他们构建更加健壮和高效的自动化测试体系。

热门文章

最新文章