日期:2021/05/19 21:48来源:未知人气:
简单的说他是软件生产过程中的质量管理者,其不但要对软件产品最后的功能、性能负责,而且从软件的“需求分析”、“结构设计”阶段以及文档规范等诸多方面就开始对软件的质量加以保障,使生产出来的软件的功能达到设计之初的要求,让用户用上高质量的软件。可见软件测试工程师的重要性了,随着我国加入WTO及国内软件企业的日益成熟和壮大,软件测试工程师在业界的地位已经变得越来越重要。 软件测试是目前较新的一个IT领域,同级别软件测试的人员不会比开发者薪水低,甚至更高。软件日益复杂,质量问题日益凸显,软件测试是降低软件项目风险、提高企业竞争力的最佳手段。企业一方面对软件测试工程师需求量大增,另一方面,则“万金”难求一优秀的测试工程师。具备开发能力的软件测试工程师、掌握扎实的Linux、Oracle基础知识的测试工程师、掌握自动化测试技术的测试工程师、具备测试设计能力的测试工程师更是少之又少。看看iPhone的受欢迎程度,正是软件测试的实力体现。高层次的软件测试专业人员竞争要少得多。 内容来自尚观科技
什么是软件测试,软件测试的目的软件测试,描述一种用来促进鉴定软件的正确性、完整性、安全性和质量的过程。换句话说,软件测试是一种实际输出与预期输出间的审核或者比较过程。软件测试的经典定义是:在规定的条件下对程序进行操作,以发现程序错误,衡量软件质量,并对其是否能满足设计要求进行评估的过程。
什么是软件测试?软件测试的薪水如何?简单的说他是软件生产过程中的质量管理者,其不但要对软件产品最后的功能、性能负责,而且从软件的“需求分析”、“结构设计”阶段以及文档规范等诸多方面就开始对软件的质量加以保障,使生产出来的软件的功能达到设计之初的要求,让用户用上高质量的软件。可见软件测试工程师的重要性了,随着我国加入WTO及国内软件企业的日益成熟和壮大,软件测试工程师在业界的地位已经变得越来越重要。 软件测试是目前较新的一个IT领域,同级别软件测试的人员不会比开发者薪水低,甚至更高。软件日益复杂,质量问题日益凸显,软件测试是降低软件项目风险、提高企业竞争力的最佳手段。企业一方面对软件测试工程师需求量大增,另一方面,则“万金”难求一优秀的测试工程师。具备开发能力的软件测试工程师、掌握扎实的Linux、Oracle基础知识的测试工程师、掌握自动化测试技术的测试工程师、具备测试设计能力的测试工程师更是少之又少。看看iPhone的受欢迎程度,正是软件测试的实力体现。高层次的软件测试专业人员竞争要少得多。 内容来自尚观科技
软件测试策略和测试软件有哪些。怎么办?策略特别多,看你从啥角度了。例如按阶段分可以分单元测试,集成测试,系统(System)测试;按可见度分可以分白盒,黑盒;其中白盒又能按方法分,例如不一样的覆盖率:条件覆盖,路径覆盖等。还可以按动态和静态分,好比代码走读算静态,手动执行算动态。还能按流程分,例如数据流测试,业务流测试。各种不一样的策略也不是单一存在的,是几种并存的。好比你用Nunit做单元测试,它就包含了几种策略,首先它是单元测试阶段,其次,它可以走数据流,第三,它可以做函数等的条件覆盖,再者,它是动态测试的一种等等。 建议你去读下软件工程的书,先做1个入门。 测试软件特别多,看你做功能还是性能了。基本都是录制回放加验证,没啥大花头。 但假如要通过软件构件测试框架的话就要你有扎实的基本功和很高的工具熟悉程度了。
软件测试的生命周期是?软件测试周期分为如下的阶段: Planning 计划阶段 Analysis 分析阶段 Design 设计阶段 Construction 书写阶段 Testing Cycles 测试阶段 Final Testing 完成阶段 Implementation 执行阶段 Planning - this is the product definition phase 这是产品测试概念定义的阶段。我觉得这部分的工作主要是管理人员在做,然后让测试组员进入某些活动。 包含的工作是: 1. High Level Test Plan 制定一个高级别的测试计划,应该就是测试大纲了,包含多个测试周期的设定等等。 2. Quality Assurance Plan 制定测试的目标,质量参数,beta测试的验收标准等等。 3. Identify when review will be held 制定各个阶段进行review的时间。这个review应该是对上阶段的情况进行分析和总结,以调整计划。也应该有一些讨论测试覆盖率或者某些Test case或者人员的不足啊之类的东西吧。 4. Problem Reporting Procedures 制定错误报告的流程。比如说那些问题要报,那些问题暂时不用报。书写的格式,跟踪的方法等等。 5. Identify Problem Classification 制定错误报告的类型。比如说那些是UI的,那些是功能的,那些是性能的等等 6. Identify Acceptance Criteria 制定软件可接受标准。比如说错误率在多少,那些错误可以暂时不修改,测试多少轮,覆盖率多少,测试深度多少等等。 7. Identify application testing databases 制定程序测试数据库。这个可能是模仿用户需求的数据库模型是什么,或者也可能是一个包含需要测试的数据的库 8. Identify measurement criteria制定错误的优先级别。分为紧急啊,一般啊,较高啊之类的级别。用来给开发人员参考,那些需要先修改。 9. Identify metrics for the project 制定项目的跟踪。比如一些跟踪文档,每周提交的weekly report之类的。例如在周报里面包含着本周新写多少个问题,解决了多少个问题,有多少问题是无效的,运行了多少个测试用例,通过率是多少等等。10. Begin overall testing project schedule 制定详细项目计划表。包括每个阶段的具体时间了,需要的人数了,需要的资源了等等。 11. Review Product Definition Document 复检产品定义文档。主要是重新对设计文档进行阅读,对现在开发的产品进行检验,防止出现误差。并且对一些设计提出用户角度的观点等等。这个应该不用所有测试人员参与。生成的应该是设计文档的一个修改和一个会议记录之类的文档。 12. Plan to manage all test cases in a database, both manual and automated. 设立一个数据库将手工测试和自动测试用例放到一起管理。我觉得不如只输入编号,然后剩下得字段用于记录每个测试用例在不同软件版本时的情况。例如,是否通过,还是阻塞了和有那些问题报告等等。 Analysis -This is external document phase 这是一个外部文档阶段。之所以说是外部文档,是因为这个阶段的工作主要都是从客户和开发组得到的文档。在这个阶段,对这些外部文档进行分析和总结。根据得到的信息,去创建测试的框架和文档。所以本阶段主要的工作是完成分析,搭出框架,书写大纲等。并不是要所有的文档工作都在本阶段内完成。 包括的主要工作是: 1. Develop Functional validation matrix based on Business requirements 制定功能验证矩阵,基于商业要求。嗯,我觉得这里应该是根据设计说明书来划分需要测试的功能区域,每个区域内要测试的元素和功能逻辑。这样就是建立了一个可以被测试用例和问题分类使用的功能验证表格。而且可以检验测试的覆盖度。 2. Develop Test Case format 制定测试用例格式。就是制定一系列的文档格式。对于UI,功能,性能,自动化测试脚本等应该都有不同的格式规范。然后给出测试优先级别,这样优先级别低,对系统影响小,一般都比较稳定的一些测试用例就可以减少测试频率和周期次数。然后最好给每个测试用例估计一个时间,这样便于统计和管理人力资源。 3. Develop Test Cycles matrices and time line 制定测试轮次和时间线。这时候应该是根据写好的测试用例估计的时间,按照对系统的不同测试点制定测试轮次。然后每个轮次之间有个时间点。例如在刚刚收到产品时,做的都是简单的功能的验证测试。这时候可以设置一个测试目标,选择一批测试用例。然后在测试目标达到后(比如,测试用例通过率达到85%)就可以进行复杂的功能测试。这个就可以称之为一个轮次。是以测试用例走完一遍为测试轮次的。当然也可以设置,一周或一个月为一个轮次。因此我们看到,找个实际上考验的是一个领导者制定计划和管理执行计划的能力。好的管理人员就能够制定有效的针对具体系统不同的计划,而不是一成不变,老是用一套方法。 4. Begin writes Test Case based on Functional Validation matrix 根据功能验证矩阵书写测试用例。 这个就没什么好说了,以前写过一个怎么写测试用例的文档。总之一句话,测试用例书写的标准就是满足需要,而不是硬套模板。 5. Map baseline data to test cases to business requirements 将用户需求中的设定测试数据和测试用例链接。有些用户,需要你对某些特殊的数据结构或者数据类型等等进行测试,这时候就需要将那些数据独立出来,以便能够复用。 6. Identify test case to automate 标示出能够使用自动工具的测试用例。将一些能够使用自动化测试的用例做一个标示,这样,在人力资源较少的时候,或者需要快速回归的时候就可以使用自动工具了。有些测试用例是直接就写成测试脚本使用测试工具测试的。有些是事先写为手工测试测试用例,可以通过使用已有的自动测试脚本快速的编制成自动测试用例的。毕竟手工测试和自动测试各有利弊。 7. Automation team begins to setup variable files and high-level scripts in Auto tester. 对于自动化测试组来说,这个时候就要做一些基本的工作了。像一些公用的文件和一些一些基础的公共函数和方法。 8. Define area for Stress and Performance testing 制定出要进行压力测试和性能测试的区域。并书写测试用例。 9. Begin setup the test cycles 根据已经完成的测试用例,开始制定测试轮次中包括的测试用例,总轮次,测试时间等等。 10. Review the documents 不断的复查文档,防止出现偏差。这个工作可以有一个固定周期,比如一个月内有几次,分别查看那些文档等等。 11. Review test environments 检查测试环境。包括软件,硬件,人力等等。 Design - This is architecture document phase 本阶段是完成测试内部文档的阶段,这些文档大部分都是在分析阶段形成了大体的组织结构和大纲的文档,像测试用例之类的都有了一些基本的描述,本阶段主要的工作就是完成这些文档的最终书写。在本阶段后,基本上测试计划,测试时间表,测试数据,各种相关文档都应该处于完成阶段。当然,仍然可以通过设计的危机处理机制进行更新。 但是特别要指出的是,测试用例并不能够在本阶段完成。由于新功能的添加,具体功能的实现方法,修改功能等因素,测试用例只能不断的更新。 包括的主要工作是: 1. Revise Test plan base on changes 根据具体的变化重新调整测试计划。 2. Revise Test Cycle matrices and timelines 根据计划的调整,调整各个测试轮次的内容和时间。 3. Revise Functional Matrix 根据变化调整功能设置。 4. Verify that test case and test data 确认已有的测试用例和测试数据仍然有效。 5. Continual write test cases and add new test cases base on changes 继续书写已经设定的测试用例和添加新的测试用例。一个测试用例,在本文中在上个阶段书写的时候可能只有一个简单的描述,具体的测试步骤需要后面填写。有的时候,有些测试用例事先没有考虑到,有些是重复的,所以需要删改。 6. Develop Risk Assessment Criteria 设置风险评估标准。通过设置风险评估,可以有效的帮助我们灵活的调整计划。比如,某个测试轮次是需要50个小时完成,而我们风险评估标准将这类测试设定为时间值应该设置为150%,也就是说,在计划中应该填写75小时为实际设定完成时间。 7. Finalize test cycles 最终完成各个测试轮次的设置。在本阶段结束后,除非有其他的特殊情况,通过预先设置的危机处理方法处理外,不再修改。 8. Finalize Test plan 完成测试计划。 9. Estimate resource to support development in unit testng 评估支持开发人员进行单元测试的可行性。有些项目,需要测试人员去帮助开发人员进行单元测试。 Construction - This is unit and model testing phase 本阶段是在开发人员编码的同时,最终完成系统预先设置的各种测试用例的阶段。本阶段的很多工作其实在上个阶段就已经涉及到了。本阶段完成后,进入测试的主要阶段,对产品进行实现设定的各种测试。 包括的主要工作是: 1. Complete unit-testing 完成单元测试 2. Complete all test case manual 完成所有的手工测试用例。随着系统不断开发,在拿到一个完整的软件版本之后,基本上手工测试用例都能够完成书写。 3. Complete auto testing tools 完成自动测试工具的开发。这个阶段可以设计编写一些专用的自动测试工具。 4. Complete Stress test case 完成压力测试用例 5. Complete performance test case 完成性能测试用例 6. Review the functional matrix 重新复检功能表 7. Complete auto test case 完成自动测试用例 Test Cycle - This is phase that to run Test Cycle(s), report bugs, verifies Bug fixes etc. 这个阶段就是最费时间的阶段了。按照实现制定好的计划,利用各种资源,工具,依循实现书写的测试用例对系统进行一轮轮的测试,直到代码冻结阶段。本阶段也包含了不断设置的回归测试。 包括的主要工作是: 1) Test Cycle 1, run first set of test cases 2) Report bugs 3) Bug Verification 4) Revise test cases as required 5) Add test cases as required 6) Test Cycle II 7) Test Cycle III .............. Final testing - This is code freeze phase 本阶段是代码冻结后的测试阶段。这个时候需要进行的是最后的验证测试。本轮主要是完成最终的性能,压力,文档测试和UI等测试过程,开始形成系统说明书和用户手册。 包括的主要工作是: Execution of all front to end test case – manual and automated Execution of all back to end test case – manual and automated 上面是在最后进行产品gold的时候,进行的测试,主要是一些大的功能的传测,测试用例一般是对主要功能的一些验证。防止出现最终打包出错等认为因素。 Execute all Stress test Execute all Performance test Execute all UI test Execute all documents test Do the last cycle regression test 以上测试就是最终的功能测试,这个时候一般不在去修改主要的源代码,只是对外观和界面的错误进行修复。只是对现有的一些问题进行跟踪和管理,必要的时候准备出版hot fix版本。 Implementation - This is review entire project phase 本阶段是对整个项目进行总结的阶段。
软件测试&软件测试工程师有什么关系?目前传统的软件行业还是以软件测试工程师为主,但是在新兴的互联网行业大多还是以QA来命名这个职位,也就是质量保证
软件测试发展怎样?看去什么学校学了,选择培训机构的标准主要就是这几条: 学费,师资,课程内容,项目,教学环境。 个人认为,最重要因素的当然就是是项目了。 再详细的话,你还是自己上门比较吧~~~~可以先尝试去听一下免费的视听课看看~南京中博新街口还不错的。