分类 杂谈 下的文章

引言说到API测试工具,大家首先想起的肯定是Postman。其实业界的API测试工具非常多,但是当年Postman作为免费的API工具,其易用性和免费性得到了广大用户的喜欢。但是随着其商业化进程的推进,它已经逐步的在削弱其免费功能,比如最近Postman官方博客就发布了要取消离线免费的功能Scratch Pad,它可以以一个项目工程的方式来管理API的Request、Collection、Environment。取而代之的是商用版本中的Workspace。其次Postman只开源了其Runtime,Collection Format和SDK,并没有开源Postman这个工具,甚至不支持p...

测试工作在软件开发中是必不可少的组成部分,包括测试分析、测试设计、测试策略、测试用例、测试执行等。然而,随着软件规模的增大,测试执行成为了最大的瓶颈。自动化测试的技术门槛和成本较高,导致许多测试用例仍然需要手工测试,因此出现了大量的手动测试执行人员,从而显著降低了软件研发的效率。然而,随着开源自动化测试框架、工具和基础设施的大量出现和普及,自动化测试的实施成本有所降低。特别是对于持续交付的项目,自动化测试可以大大降低回归测试成本,从而极大地提高软件研发的效率。自动化测试可以从开发角度进行分类为三种类型:步骤录制型、编写代码型和界面配置型。从架构和使用角度进行分类,可以分为三个类型:测试工...

介绍代码评审(Code Review)是保证代码内在质量的一种重要手段,也是软件外部质量非常重要的保证措施。它是通过由其他团队成员或同行对编写的代码进行仔细审查和讨论,以发现潜在问题、提供反馈和改进建议的过程。其次评审的内容包括代码的设计、功能、复杂度、命名、风格、测试等方面。评审的标准包括代码设计是否合理和精良、代码是否高效和安全、代码复杂度是否高、代码中的命名和风格是否符合团队的要求、代码是否有足够和合理的测试等。然后代码评审可以根据评审方式分为人工评审和自动评审。人工评审可以根据不同场景分为结对编程中的一对一代码评审、分布式团队中的在线远程专人代码评审,以及基于整个团队的团队代码评...

缺陷分析是软件质量管理中至关重要的一环。它是对软件中的缺陷进行系统性分析和评估的过程。在缺陷分析中,我们通过识别、定位和理解缺陷,以及找出其根本原因和解决方案,来提高软件质量和用户满意度。为什么要做缺陷分析?缺陷分析对于软件开发和维护团队来说至关重要,原因如下:提高软件质量:通过缺陷分析,我们可以发现并修复软件中的问题和缺陷,从而提高软件的稳定性、可靠性和功能性。用户满意度:通过及时处理和解决缺陷,我们可以提供更好的用户体验,增加用户的满意度和忠诚度。节约成本:早期发现和解决缺陷可以避免后期修复的高成本,减少软件开发和维护过程中的资源和时间浪费。全面改进:通过缺陷分析,我们可以深入了解软...

随着智能手机技术的不断发展,人们对于手机软件的需求也越来越高。为了满足这种需求,软件开发公司推出了各种各样的手机软件,但是,这些软件的兼容性却成为了一个普遍存在的问题,而且兼容性相关缺陷的出现概率极高,因此手机软件兼容性测试的重要性因此变得越来越明显。简介首先,手机软件兼容性测试是指将软件在不同的手机、不同的操作系统版本和不同的硬件平台上进行测试,以保证软件在各种环境下能够正常运行。由于手机市场的多样性,手机软件兼容性测试变得尤为重要。例如,同一款手机软件可能需要在iOS、Android等多个不同的操作系统版本上进行测试,以保证软件的兼容性。手机软件兼容性测试的主要目的是确保软件在各种环...

随着数字化时代的到来,软件已经成为我们生活中不可或缺的一部分。软件的质量对于用户和企业来说都是至关重要的,因此,软件测试已经成为软件开发周期中不可或缺的环节。然而,即使软件经过了严格的测试,仍然可能存在缺陷。这个问题一直困扰着软件开发和QA,今天我们来探究一下这个问题的原因。缺陷产生的原因软件缺陷是每个软件开发和QA都面临的挑战。软件缺陷可能导致软件系统不稳定、不可靠、不安全,甚至可能导致系统崩溃或数据丢失。因此,软件缺陷的追踪和修复非常重要。然而,由于软件系统的复杂性和变化性,软件缺陷的追踪和修复并不总是一件容易的事情。本文将探讨软件缺陷的迷思,即缺陷产生的原因以及我们在处理软件缺陷时...

测试数据是测试用例执行的前提条件之一,也是测试分析与设计的基础之一,比如等价类,边界值都是靠不同的测试数据来体现不同的测试用例和测试场景。如果把测试步骤比喻成测试用例的骨架,那么测试数据就是测试用例的血液,只有当测试用例和测试数据一起才能形成一个好的测试用例。测试数据的现状测试数据是一个经常被测试人员忽视的地方,绝大部分商用软件系统的功能测试中的测试数据都是靠测试人员通过分析和设计,手动生成的测试数据。但是有些特殊的软件系统,比如一些复杂的网络系统,一些复杂操作系统,一些复杂的硬件系统等,由于测试数据的数量巨大,并且类型众多,所以一般需要靠特定的数据系统来自动生成测试数据。并且对于一些特...

1. 培训无用培训无用论是现在很多技术类企业遇到的现实问题,不管是内部培训,还是外部培训,还是各种技术大会之类的快速培训,总是发现培训之后学员还是不懂,还是不知道怎么做,但是公司的培训预算又不得不使用,导致很多培训无用。培训无用论的本质是培训的目标没有达到,那培训的目标到底有哪些呢?我总结了以下几个目标:1.1 不知道自己不知道 -> 知道自己不知道通过培训探索式的发现自己还有哪些不知道的知识和领域,从而可以选择学习和发展的方向。这类目标主要是通过一些技术大会可以达到。1.2 知道自己不知道 -> 知道自己知道当明确自己的学习和发展方向后,通过特定的培训学习自己了解的知识体系...

Part INowadays, there are a lot of discussions about software testing and quality in the industry and from where a lot of neologisms are created, such as de-testers, uselessness of testers, technicalization of testing, testing engineering, testing and quality empowerment, agile testing, continuou...

1 介绍随着全球、全产业数字化需求的进一步增加,越来越多传统行业和复杂业务都转向了数字化。要完成数字化转型,软件系统一般是必不可少的,但是对于很多传统行业中的复杂业务,都需要大型的软件系统。而大型的软件系统一般都是需要大规模的开发团队来进行开发。传统的瀑布模型看起来似乎非常适合大型项目的开发,但是随着软件危机的出现,软件研发专家提出了敏捷软件开发,用于应对模糊不清和不断变化的业务需求,尽早、快速和持续验证开发中的软件功能。但敏捷开发的特性和实践更适合于中小规模团队,而在大规模团队中会遇到很多问题和痛点。比如在敏捷开发中的测试实践,一般并不依赖独立的测试团队,QA人员需要加入到交付团队进行...