收藏 分销(赏)

知识管理系统-需求说明书(软件工程课).doc

上传人:胜**** 文档编号:693642 上传时间:2024-02-02 格式:DOC 页数:20 大小:220.50KB
下载 相关 举报
知识管理系统-需求说明书(软件工程课).doc_第1页
第1页 / 共20页
知识管理系统-需求说明书(软件工程课).doc_第2页
第2页 / 共20页
知识管理系统-需求说明书(软件工程课).doc_第3页
第3页 / 共20页
知识管理系统-需求说明书(软件工程课).doc_第4页
第4页 / 共20页
知识管理系统-需求说明书(软件工程课).doc_第5页
第5页 / 共20页
点击查看更多>>
资源描述

1、-精品word文档 值得下载 值得拥有-项目名称:知识管理系统需求说明书:一、引言1.1 编写目的 未来的世界将是知识经济的时代,知识逐渐成为各类组织中重要的资源,建立知识管理系统对增强企业和个人的核心竞争力发挥越来越重要的作用。本文档为学习管理系统的设计、实现、测试以及验收提供重要依据,也为评价系统功能和性能提供标准。本文档可供用户、项目管理人员、系统分析人员、程序设计人员以及系统测试人员阅读和参考。1.2 项目研究意义 新的世纪全球经济高速增长,知识及其精华-科学技术的贡献占7080%,知识创新、科技进步已成为一个国家富强的源泉,成为人类文明的主要的动力。二十一世纪,世界将由工业经济时代迈

2、向知识经济时代,推动这一伟大潮流进展的正是知识革命。知识管理是近几年兴起的一个新概念,一种全新的管理思想,并被管理者称为第五代管理。它是管理科学、社会科学及信息科学的交叉学科,主要功能是存贮知识、交流并传播和创新知识。本项目将注重研究知识管理系统的体系架构和技术实现层面的研究。通过构建某一领域的知识管理系统为某一特定用户(比如:旅游爱好者)提供有效的、持久的知识讯息。根据可重构、可重用的设计开发原则,通过对这一特定领域(旅游景点)的分析和开发,尽可能 做到将这一平台方便的移植到其他领域上,从而方便实现其他知识领域的开发和设计,满足不同用户的需求。1.3项目背景1、项目来源 软件工程课作业2、项

3、目规划阶段文档提交日期需求阶段需求文档2012.4.15开发设计阶段软件设计文档2012.4.24测试阶段测试文档2012.6.51. 项目开发小组开发人员姓名邮箱组长朱琳1107509010组员陈经欣1040445071组员杨康立604911488组员林骁龙1436169993组员蔡名哲12995669493、 参考资料二、任务概述2.1 目标1. 明确需求,严格完成需求定义的功能2. 严格按照项目进程完成软件开发3. 保证开发人员合格的工作效率2.2 运行环境1. 操作系统:Microsoft Window XP/Win 72. 数据库:SQL Server 20053. 开发工具:Mye

4、clipse(eclipse)2.3 条件与限制1. 处理器:Pumtium II 以上2. 运行环境:3. 内存需求:4. 由于组员开发能力和时间有限,数据库规模受限。2.3用户特征本软件比较适合具有如下特点的人群:1. 对某一领域(比如旅游景点)感兴趣并进行知识积累的人2. 较频繁使用到知识库知识,或添加知识到库中三、功能需求3.1 功能划分1. 支持知识库自动更新和人工更新2. 支持基于系统和Web的知识查询搜素能力3. 提供工具,对Web页中知识的捕获和自动分类存入知识库4. 对基于系统的查询结果出了返回词条式的索引目录,同时能够返回知识地图和知识结构图,这是本系统特别和特色功能之处。

5、3.2 功能描述:1. 利用知识链接到特定网址和利用程序spider,crawler,,或web wanderer进行自动更新2. 人工更新:提供编辑器用户可以通过键盘输入和复制黏贴两种方式创建知识,并分类存入数据库。用户可以有各种编辑知识的权限,比如:添加、删除、修改、插入。3. 软件可以实现对网页知识的捕获,下载到本地电脑后,用户通过贴标签,系统自动识别分类存入数据库4. 支持对知识库中知识按标签和分类进行查询和搜索,利用全文搜索技术对知识库中知识按关键字进行分类和查询,同时利用决策支持技术得到结构化和结果话的信息来支持决策。5. 在知识库中建立知识网络结构图,能够实现基于系统查询时返回相

6、关知识结构图。 四、 性能需求4.1数据精确度a知识数据相关搜索时,有尽可能多的相连知识b人工更新新知识时,需按规定数据库知识储存格式进行人手添加,不符合规格时自动弹窗提醒4.2时间特性a响应时间:0.5秒以内4.3适应性a满足特定领域知识使用者的需求b要求数据库具有较强数据更新能力,并能应对一般的并发事件且具有较强识别能力。c操作系统:Microsoft Windows xp/win74.4安全性只设立Administrator(用户级)一级,可进行增,改等操作。不能删除关联知识。五、运行需求5.1用户界面5.1.1 用户界面图例采用格式,界面中包含多个板块,板块间相互独立又互相关联。1.左

7、上角菜单栏菜单栏设计以美观简洁为核心2. 左方用户管理窗体试例在搜索框中键如知识,可实现和选择基于本地知识库的搜索和基于Web的搜索。3. 右方编辑文档窗口示例5.1.2 界面使用说明1. 用户如果创建了笔记需要存入知识库,点击保存后,将显示如下页面:(初步细化分类)通过用户手工贴标签和系统自动识别,实现知识自动分类。2.用户可以选择新建各种模式的笔记,新建标签,甚至笔记本,笔记存储在笔记本中。“编辑”框下包含一般word文档会有的编辑功能 3.“查看”栏下的有三种不同的视图模式,可以按视图按不同的方式排版。 4.在搜索框中键入想要搜索的内容,可以在笔记中查找到相应的资料5.而编辑窗口则含有基

8、本的word编辑功能。6.运行该知识管理系统后,打开网页浏览器时会在下方显示浮动框,用户可以通过浮动框上的按键来实现对网页知识的复制及收藏。5.3软件界面设计工具1.DotNetBar,DevExpress拥有最漂亮也实用的界面,当然也是最好的选择,但需要付费购买。2.WPF也很不错,只不过一切都得自己做,WPF不管从功能上要远大于Winform。3.Winform做界面是最简陋的,且美化界面需要更多的代码。5.2 接口设计5.2.1 硬件接口(1) 处理器要求:Pumtium II 以上(2) 运行环境:jdk6.0(3) 内存要求:512MB或以上5.2.2软件接口(1) 操作系统:Mic

9、rosoft Window XP/Win 7(2) 数据库:SQL Server 2005(3) 开发语言:Java(4) 开发工具:Myeclipse(eclipse)六、数据描述6.1静态数据 景点ID、景点名称、景点资料日期、景点类别、景点标签、景点原链接、景点介绍、景点历史背景。6.2动态数据输入数据:菜单选项、查询、新建游记、景点最新资讯的捕获。输出数据:查询结果的返回(包括相关知识)。6.3数据库描述采用SQL Server2005数据库。针对旅游这一领域,建立相关知识库。6.4数据词典景点库字段名数据类型主键描述景点ID可变字符串是景点的ID号景点名称可变字符串否景点的名称景点资

10、料日期日期否景点资料的生成日期景点类别可变字符串否景点的分类景点标签可变字符串否景点的标签景点原链接整型否景点资料获取的原链接(可为空)景点信息字段名数据类型主键描述景点ID可变字符串是景点的ID号景点名称可变字符串否景点的名称景点介绍可变字符串否景点的介绍景点历史背景可变字符串否景点的历史背景景点最新资讯可变字符串否景点的最新资讯景点游记可变字符串否景点的相关游记地点库字段名数据类型主键描述景点ID可变字符串是景点的ID号景点名称可变字符串否景点的名称景点所属城市可变字符串否景点所在的城市景点所属省份可变字符串否景点所在的省份游记库字段名数据类型主键描述景点ID可变字符串是景点的ID号游记标

11、题可变字符串否游记的标题游记内容可变字符串否游记的正文6.5数据采集(1)要求和范围主要通过键盘输入、复制粘贴和网页捕获的方式获取数据。(2)输入的承担者 人工更新为用户自行输入,自动更新为链接到特定网站的内容更新。数据库检索: 引入著录标引管理功能:在知识进入知识库前做好标准化处理,在知识库中建立知识名称和知识概念的一一对应关系。七、检验标准随着软件测试技术的不断发展,测试方法也越来越多样化,针对性更强;选择合适的软件测试方法可以让我们事半功倍。以下是一些常用的软件测试方法。 7.1 测试_Beta测试测试,英文是Beta testing。又称Beta测试,用户验收测试(UAT)。测试是软件

12、的多个用户在一个或多个用户的实际使用环境下进行的测试。开发者通常不在测试现场,Beta测试不能由程序员或测试员完成。当开发和测试根本完成时所做的测试,而最终的错误和问题需要在最终发行前找到。这种测试一般由最终用户或其他人员完成,不能由程序员或测试员完成。 7.2 测试_Alpha测试测试,英文是Alpha testing。又称Alpha测试。Alpha测试是由一个用户在开发环境下进行的测试,也可以是公司内部的用户在模拟实际操作环境下进行的受控测试,Alpha测试不能由该系统的程序员或测试员完成。在系统开发接近完成时对应用系统的测试;测试后,仍然会有少量的设计变更。这种测试一般由最终用户或其他人

13、员来完成,不能由程序员或测试员完成。 7.3可移植性测试可移植性测试,英文是Portability testing。又称兼容性测试。可移植性测试是指测试软件是否可以被成功移植到指定的硬件或软件平台上。 7.4用户界面测试-UI测试用户界面测试,英文是User interface testing。又称UI测试。用户界面,英文是User interface。是指软件中的可见外观及其底层与用户交互的部分(菜单、对话框、窗口和其它控件)。用户界面测试是指测试用户界面的风格是否满足客户要求,文字是否正确,页面是否美观,文字,图片组合是否完美,操作是否友好等等。UI 测试的目标是确保用户界面会通过测试对象

14、的功能来为用户提供相应的访问或浏览功能。确保用户界面符合公司或行业的标准。包括用户友好性、人性化、易操作性测试。用户界面测试用户分析软件用户界面的设计是否合乎用户期望或要求。它常常包括菜单,对话框及对话框上所有按钮,文字,出错提示,帮助信息 (Menu 和Help content)等方面的测试。比如,测试Microsoft Excel中插入符号功能所用的对话框的大小,所有按钮是否对齐,字符串字体大小,出错信息内容和字体大小,工具栏位置/图标等等。 7.5 冒烟测试冒烟测试,英文是Smoke testing。任何新电路板焊好后,先通电检查,如果存在设计缺陷,电路板可能会短路,板子冒烟了。冒烟测试

15、的对象是每一个新编译的需要正式测试的软件版本,目的是确认软件基本功能正常,可以进行后续的正式测试工作。冒烟测试的执行者是版本编译人员。 7.6 随机测试随机测试,英文是Ad hoc testing。随机测试没有书面测试用例、记录期望结果、检查列表、脚本或指令的测试。主要是根据测试者的经验对软件进行功能和性能抽查。随机测试主要是对被测软件的一些重要功能进行复测,也包括测试那些当前的测试样例(TestCase)没有覆盖到的部分。另外,对于软件更新和新增加的功能要重点测试。重点对一些特殊点情况点、特殊的使用环境、并发性、进行检查。尤其对以前测试发现的重大Bug,进行再次测试,可以结合回归测试 (Re

16、gressive testing)一起进行。 7.7 本地化测试本地化测试,英文是Localization testing。本地化就是将软件版本语言进行更改,比如将英文的windows改成中文的windows就是本地化。本地化测试的目的是测试特定目标区域设置的软件本地化质量。本地化测试的环境是在本地化的操作系统上安装本地化的软件。测试的内容主要包括软件本地化后的界面布局和软件翻译的语言质量,包含软件、文档和联机帮助等部分。 7.8 本地化能力测试本地化能力测试,英文是Localizability testing。本地化能力测试是指不需要重新设计或修改代码,将程序的用户界面翻译成任何目标语言的能

17、力。本地化能力测试中发现的典型错误包括:字符的硬编码(即软件中需要本地化的字符写在了代码内部),对需要本地化的字符长度设置了固定值,在软件运行时以控件位置定位,图标和位图中包含了需要本地化的文本,软件的用户界面与文档术语不一致等。 7.9 国际化测试国际化测试,英文是International testing。又称国际化支持测试。国际化测试的目的是测试软件的国际化支持能力,发现软件的国际化的潜在问题,保证软件在世界不同区域都能正常运行。国际化测试使用每种可能的国际输入类型,针对任何区域性或区域设置检查产品的功能是否正常,软件国际化测试的重点在于执行国际字符串的输入/输出功能。国际化测试数据必须

18、包含东亚语言、德语、复杂脚本字符和英语(可选)的混合字符。国际化支持测试是指验证软件程序在不同国家或区域的平台上也能够如预期的那样运行,而且还可以按照原设计尊重和支持使用当地常用的日期,字体,文字表示,特殊格式等等。比如,用英文版的 Windows XP 和 Microsoft Word 能否展示阿拉伯字符串?用阿拉伯版的 Windows XP 和 阿拉伯版的Microsoft Word 能否展示阿拉伯字符串?又比如,日文版的Microsoft Excel对话框是否显示正确翻译的日语?一旦来说执行国际化支持测试的测试人员往往需要基本上了解这些国家或地区的语言要求和期望行为是什么。 7.10 安

19、装测试安装测试,英文是Installing testing。安装测试是确保软件在正常情况和异常情况下,例如,进行首次安装、升级、完整的或自定义的安装都能进行安装的测试。异常情况包括磁盘空间不足、缺少目录创建权限等场景。核实软件在安装后可立即正常运行。安装测试包括测试安装代码以及安装手册。安装手册提供如何进行安装,安装代码提供安装一些程序能够运行的基础数据。 7.11 白盒测试白盒测试,英文是White Box Testing。又称结构测试或者逻辑驱动测试。白盒测试是把测试对象看作一个打开的盒子。利用白盒测试法进行动态测试时,需要测试软件产品的内部结构和处理过程,不需测试软件产品的功能。白盒测试

20、法的覆盖标准有逻辑覆盖、循环覆盖和基本路径测试。其中逻辑覆盖包括语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖和路径覆盖。白盒测试是知道产品内部工作过程,可通过测试来检测产品内部动作是否按照规格说明书的规定正常进行,按照程序内部的结构测试程序,检验程序中的每条通路是否都有能按预定要求正确工作,而不顾它的功能,白盒测试的主要方法有逻辑驱动、基路测试等,主要用于软件验证。白盒测试常用工具有:Jtest、VcSmith、Jcontract、C+ Test、CodeWizard、logiscope。 7.12 黑盒测试黑盒测试,英文是Black Box Testing。又称功能测试或者数据

21、驱动测试。黑盒测试是根据软件的规格对软件进行的测试,这类测试不考虑软件内部的运作原理,因此软件对用户来说就像一个黑盒子。软件测试人员以用户的角度,通过各种输入和观察软件的各种输出结果来发现软件存在的缺陷,而不关心程序具体如何实现的一种软件测试方法。黑盒测试常用工具有:AutoRunner、winrunner、loadrunner。 7.13 自动化测试自动化测试,英文是Automated Testing。使用自动化测试工具来进行测试,这类测试一般不需要人干预,通常在GUI、性能等测试和功能测试中用得较多。通过录制测试脚本,然后执行这个测试脚本来实现测试过程的自动化。国内领先的自动化测试服务提供

22、商是泽众软件。自动化测试工具有AutoRunner和TAR等。 7.14 回归测试回归测试,英文是Regression testing。回归测试是指在发生修改之后重新测试先前的测试以保证修改的正确性。理论上,软件产生新版本,都需要进行回归测试,验证以前发现和修复的错误是否在新软件版本上再次出现。根据修复好了的缺陷再重新进行测试。回归测试的目的在于验证以前出现过但已经修复好的缺陷不再重新出现。一般指对某已知修正的缺陷再次围绕它原来出现时的步骤重新测试。通常确定所需的再测试的范围时是比较困难的,特别当临近产品发布日期时。因为为了修正某缺陷时必需更改源代码,因而就有可能影响这部分源代码所控制的功能。

23、所以在验证修好的缺陷时不仅要服从缺陷原来出现时的步骤重新测试,而且还要测试有可能受影响的所有功能。因此应当鼓励对所有回归测试用例进行自动化测试。 7.15 验收测试验收测试,英文是Acceptance testing。验收测试是指系统开发生命周期方法论的一个阶段,这时相关的用户或独立测试人员根据测试计划和结果对系统进行测试和接收。它让系统用户决定是否接收系统。它是一项确定产品是否能够满足合同或用户所规定需求的测试。验收测试一般有三种策略:正式验收、非正式验收或Alpha 测试、Beta 测试。 7.16 动态测试动态测试,英文是Moment Testing。动态测试是指通过运行软件来检验软件的

24、动态行为和运行结果的正确性。7.17 探索测试探索测试,英文是Exploratory Testing。探索测试是指通常用于没有产品说明书的测试,这需要把软件当作产品说明书来看待,分步骤逐项探索软件特性,记录软件执行情况,详细描述功能,综合利用静态和动态技术来进行测试。探索测试人员只靠智能、洞察力和经验来对bug的位置进行判断,所以探索测试又被称为自由形式测试。 7.18 单元测试单元测试,英文是Unit Testing。单元测试是最微小规模的测试;以测试某个功能或代码块。典型地由程序员而非测试员来做,因为它需要知道内部程序设计和编码的细节知识。这个工作不容易做好,除非应用系统有一个设计很好的体

25、系结构; 还可能需要开发测试驱动器模块或测试套具。 7.19 集成测试集成测试,英文是Integration Testing。集成测试是指一个应用系统的各个部件的联合测试,以决定他们能否在一起共同工作并没有冲突。部件可以是代码块、独立的应用、网络上的客户端或服务器端程序。这种类型的测试尤其与客户服务器和分布式系统有关。一般集成测试以前,单元测试需要完成。集成测试是单元测试的逻辑扩展。它的最简单的形式是:两个已经测试过的单元组合成一个组件,并且测试它们之间的接口。从这一层意义上讲,组件是指多个单元的集成聚合。在现实方案中,许多单元组合成组件,而这些组件又聚合成程序的更大部分。方法是测试片段的组合

26、,并最终扩展进程,将您的模块与其他组的模块一起测试。最后,将构成进程的所有模块一起测试。此外,如果程序由多个进程组成,应该成对测试它们,而不是同时测试所有进程。集成测试识别组合单元时出现的问题。通过使用要求在组合单元前测试每个单元,并确保每个单元的生存能力的测试计划,可以知道在组合单元时所发现的任何错误很可能与单元之间的接口有关。这种方法将可能发生的情况数量减少到更简单的分析级别 7.20 系统测试系统测试,英文是System Testing。系统测试是基于系统整体需求说明书的黑盒类测试,应覆盖系统所有联合的部件。系统测试是针对整个产品系统进行的测试,目的是验证系统是否满足了需求规格的定义,找

27、出与需求规格不相符合或与之矛盾的地方。系统测试的对象不仅仅包括需要测试的产品系统的软件,还要包含软件所依赖的硬件、外设甚至包括某些数据、某些支持软件及其接口等。因此,必须将系统中的软件与各种依赖的资源结合起来,在系统实际运行环境下来进行测试。 7.21 端到端测试端到端测试,英文是End to End Testing。端到端测试类似于系统测试,测试级的“宏大”的端点,涉及整个应用系统环境在一个现实世界使用时的模拟情形的所有测试。例如与数据库对话,用网络通讯,或与外部硬件、应用系统或适当的系统对话。端到端架构测试包含所有访问点的功能测试及性能测试。端到端架构测试实质上是一种灰盒测试,一种集合了白

28、盒测试和黑盒测试的优点的测试方法。 7.22 健全测试健全测试,英文是Sanity testing。健全测试是指一个初始化的测试工作,以决定一个新的软件版本测试是否足以执行下一步大的测试能力。例如,如果一个新版软件每5分钟与系统冲突,使系统陷于泥潭,说明该软件不够“健全”,目前不具备进一步测试的条件。 7.23 衰竭测试衰竭测试,英文是Failure Testing。衰竭测试是指软件或环境的修复或更正后的“再测试”。可能很难确定需要多少遍再次测试。尤其在接近开发周期结束时。7.24 接受测试接受测试,英文是Accept Testing。接受测试是基于客户或最终用户的规格书的最终测试,或基于用户

29、一段时间的使用后,看软件是否满足客户要求。一般从功能、用户界面、性能、业务关联性进行测试。 7.25 负载测试负载测试,英文是Load testing。负载测试是测试一个应用在重负荷下的表现。例如测试一个 Web 站点在大量的负荷下,何时系统的响应会退化或失败,以发现设计上的错误或验证系统的负载能力。在这种测试中,将使测试对象承担不同的工作量,以评测和评估测试对象在不同工作量条件下的性能行为,以及持续正常运行的能力。负载测试的目标是确定并确保系统在超出最大预期工作量的情况下仍能正常运行。此外,负载测试还要评估性能特征,例如,响应时间、事务处理速率和其他与时间相关的方面。 7.26 强迫测试强迫

30、测试,英文是Force Testing。强迫测试是在交替进行负荷和性能测试时常用的术语。也用于描述象在异乎寻常的重载下的系统功能测试之类的测试,如某个动作或输入大量的重复,大量数据的输入,对一个数据库系统大量的复杂查询等。 7.27 压力测试压力测试,英文是Stress Testing。和负载测试差不多。压力测试是一种基本的质量保证行为,它是每个重要软件测试工作的一部分。压力测试的基本思路很简单:不是在常规条件下运行手动或自动测试,而是在计算机数量较少或系统资源匮乏的条件下运行测试。通常要进行压力测试的资源包括内部内存、CPU 可用性、磁盘空间和网络带宽等。一般用并发来做压力测试。 7.28

31、性能测试性能测试,英文是Performance Testing。性能测试是在交替进行负荷和强迫测试时常用的术语。理想的“性能测试”(和其他类型的测试)应在需求文档或质量保证、测试计划中定义。性能测试一般包括负载测试和压力测试。通常验证软件的性能在正常环境和系统条件下重复使用是否还能满足性能指标。或者执行同样任务时新版本不比旧版本慢。一般还检查系统记忆容量在运行程序时会不会流失(memory leak)。比如,验证程序保存一个巨大的文件新版本不比旧版本慢。 可用性测试可用性测试,英文是Practical Usability Testing。可用性测试是对“用户友好性”的测试。显然这是主观的,且将

32、取决于目标最终用户或客户。用户面谈、调查、用户对话的录象和其他一些技术都可使用。程序员和测试员通常都不宜作可用性测试员。 卸载测试卸载测试,英文是Uninstall Testing。卸载测试是对软件的全部、部分或升级卸载处理过程的测试。主要是测试软件能否卸载,卸载是否干净,对系统有无更改,在系统中的残留与后来的生成文件如何处理等。还有原来更改的系统值是否修改回去 恢复测试恢复测试,英文是Recovery testing。恢复测试是测试一个系统从如下灾难中能否很好地恢复,如遇到系统崩溃、硬件损坏或其他灾难性问题。恢复测试指通过人为的让软件(或者硬件)出现故障来检测系统是否能正确的恢复,通常关注恢

33、复所需的时间以及恢复的程度。恢复测试主要检查系统的容错能力。当系统出错时,能否在指定时间间隔内修正错误并重新启动系统。恢复测试首先要采用各种办法强迫系统失败,然后验证系统是否能尽快恢复。对于自动恢复需验证重新初始化(reinitialization)、检查点(checkpointing mechanisms)、数据恢复(data recovery)和重新启动 (restart)等机制的正确性;对于人工干预的恢复系统,还需估测平均修复时间,确定其是否在可接受的范围内。 安全测试安全测试,英文是Security Testing。安全测试是测试系统在防止非授权的内部或外部用户的访问或故意破坏等情况时

34、怎么样。这可能需要复杂的测试技术。安全测试检查系统对非法侵入的防范能力。安全测试期间,测试人员假扮非法入侵者,采用各种办法试图突破防线。例如:想方设法截取或破译口令;专门定做软件破坏系统的保护机制;故意导致系统失败,企图趁恢复之机非法进入;试图通过浏览非保密数据,推导所需信息,等等。理论上讲,只要有足够的时间和资源,没有不可进入的系统。因此系统安全设计的准则是,使非法侵入的代价超过被保护信息的价值。此时非法侵入者已无利可图。 兼容性测试兼容测试,英文是Compatibility Testing。兼容测试是测试软件在一个特定的硬件/软件/操作系统/网络等环境下的性能如何。向上兼容向下兼容,软件兼

35、容硬件兼容。软件的兼容性有很多需要考虑的地方。 比较测试比较测试,英文是Compare Testing。比较测试是指与竞争伙伴的产品的比较测试,如软件的弱点、优点或实力。来取长补短,以增强产品的竞争力。 可接受性测试可接受性测试,英文是Acceptability Testing。可接受性测试是在把测试的版本交付测试部门大范围测试以前进行的对最基本功能的简单测试。因为在把测试的版本交付测试部门大范围测试以前应该先验证该版本对于所测试的功能基本上比较稳定。必须满足一些最低要求。比如不会很容易程序就挂起或崩溃。如果一个新版本没通过可测试性的验证,就应该阻拦测试部门花时间在该测试版本上测试。同时还要找

36、到造成该版本不稳定的主要缺陷并督促尽快加以修正 边界条件测试边界条件测试,英文是Boudary Testing。又称边界值测试。一种黑盒测试方法,适度等价类分析方法的一种补充,由长期的测试工作经验得知,大量的错误是发生在输入或输出的边界上。因此针对各种边界情况设计测试用例,可以查出更多的错误。边界条件测试是环绕边界值的测试。通常意味着测试软件各功能是否能正确处理最大值,最小值或者所设计软件能够处理的最长的字符串等等。 强力测试强力测试,英文是Mightiness Testing。强力测试通常验证软件的性能在各种极端的环境和系统条件下是否还能正常工作。或者说是验证软件的性能在各种极端环境和系统条

37、件下的承受能力。比如,在最低的硬盘驱动器空间或系统记忆容量条件下,验证程序重复执行打开和保存一个巨大的文件1000次后也不会崩溃或死机。 装配/安装/配置测试装配/安装/配置测试是验证软件程序在不同厂家的硬件上,所支持的不同语言的新旧版本平台上,和不同方式安装的软件都能够如预期的那样正确运行。比如,把英文版的 Microsoft Office 2003安装在韩文版 的Windows Me 上,再验证所有功能都正常运行。 静态测试静态测试,英文是Static Testing。静态测试指测试不运行的部分,例如测试产品说明书,对此进行检查和审阅.。静态方法是指不运行被测程序本身,仅通过分析或检查源程

38、序的文法、结构、过程、接口等来检查程序的正确性。静态方法通过程序静态特性的分析,找出欠缺和可疑之处,例如不匹配的参数、不适当的循环嵌套和分支嵌套、不允许的递归、未使用过的变量、空指针的引用和可疑的计算等。静态测试结果可用于进一步的查错,并为测试用例选取提供指导。静态测试常用工具有:Logiscope、PRQA; 隐藏数据测试隐藏数据测试在软件验收和确认阶段是十分必要和重要的一部分。程序的质量不仅仅通过用户界面的可视化数据来验证,而且必须包括遍历系统的所有数据。假设一个应用程序要求用户两条信息-用户名和密码来创建帐户。这个用户输入这两条数据后保存。最后,一个确认窗口将通过数据库中找到这条数据来显

39、示用户名和密码给用户。为了验证所有的数据保存是否正确,一个QA测试人员会在这个确认窗口简单的查看下用户名和密码。如果他们成功了?假设数据库记录了第三条信息-创建日期,它可能不会出现在确认窗口,而只在存档中才出现。如果创建日期保留的不正确,而QA测试人员只验证屏幕上的数据,那么这个问题就不可能被发现。创建日期可能就是一个bug,由于一个用户帐户保存了一个错误的日期到数据库中,这个问题也不可能会被引起注意,因为它被用户界面所隐藏。这只是一个简单的例子,但是它却演化出了一点:隐藏数据测试的重要性。 等价划分测试等价划分测试的英文是equivalence partition testing。等价划分测

40、试是根据等价类设计测试用例的一种技术。是黑盒测试的典型方法之一,通过把被测试程序所有可能的输入数据域划分成若干部分。从每一部分中选取少数有代表性的数据作为测试用例,可有效减少测试次数,极大提高软件测试效率,缩短软件开发周期等价类划分测试的目的就是为了在有限的测试资源的情况下,用少量有代表性的数据得到比较好的测试效果。有效等价类盒无效等价类。有效等价类中的数据代表的是一组符合需求文档的正确的有意义数据。无效等价类则正相反。 判定表判定表的英文是decision table,是指一个表格,用于显示条件和条件导致动作的集合。定义:判定表是分析和表达多逻辑条件下执行不同操作的情况的工具。判定表的优点:

41、能够将复杂的问题按照各种可能的情况全部列举出来,简明并避免遗漏。因此,利用判定表能够设计出完整的测试用例集合。在一些数据处理问题当中,某些操作的实施依赖于多个逻辑条件的组合,即:针对不同逻辑条件的组合值,分别执行不同的操作。判定表很适合于处理这类问题 深度测试深度测试的英文Depth test ,是指执行一个产品的一个特性的所有细节,但不测试所有特性。当比较函数返回真的时候才显示出效果来。必须启用“#深度测试”,才能执行测试。不使用的时候需要关闭。 基于设计的测试基于设计的测试的英文是design-based testing,是根据软件的构架或详细设计引出测试用例的一种方法。一种基于设计模型的

42、测试方法(Model Based TestIng System,MATIS).该方法利用用户界面自动生成方法,把设计模型中的类属性定义和实现中的控件属性组织在一起,构建描述界面的逻辑对照表,辅助测试脚本引擎执行自动测试脚本.借助设计模型中扩展的类定义,MATIS方法可以自动生成测试用例和测试数据。 文档测试文档测试的英文是documentation testing,测试关注于文档的正确性。文档测试有三大类分别是开发文件、用户文件、管理文件。1. 开发文件:可行性研究报告、软件需求说明书、数据要求说明书、概要设计说明书、详细设计说明书、数据库设计说明书、模块开发卷宗。2.用户文件:用户手册、操作

43、手册。3.管理文件:项目开发计划、测试计划、测试分析报告、开发进度月报、项目开发总结报告。软件测试中的文档测试主要是对相关的设计报告和用户使用说明进行测试,对于设计报告主要是测试程序与设计报告中的设计思想是否一致;对于用户使用说明进行测试时,主要是测试用户使用说明书中对程序操作方法的描述是否正确,重点是用户使用说明中提到的操作例子要进行测试,保证采用的例子能够在程序中正确完成操作。域测试域测试的英文是domain testing,定义参考等价划分测试(equivalence partition testing);一般分为单域测试和多域测试,其中单域测试包括设备测试和业务测试,设备测试包括测试某

44、个系统的软交换设备、中继媒体网关设备、信令网关设备、接入媒体网关和IAD等设备。等价类划分有两种不同的情况:有效等价类和无效等价类。设计时要同时考虑这两种等价类,因为软件不仅要能接收合理的数据,也要能经受意外的考验。一有效等价类:是指对于程序的规格说明来说是合理的、有意义的输入数据构成的集合。利用有效等价类可检验程序是否实现了规格说明中所规定的功能和性能。二无效等价类:与有效等价类的定义恰巧相反。 接口测试接口测试的英文是interface testing,接口测试测试系统组件间接口的一种测试。接口测试的好处:由于接口测试代码本身就是用junit(当然接口的类型不同,不一定是Junit来实现)

45、来实现的,是属于自动化测试的范畴,因此必定也包含自动化测试所固有的优势。1) 提高测试质量软件开发的过程是一个持续集成和改进的过程,而每一次的改进都可能引进新bug,因此当软件的一部,或者全部修改时,都需要对软件产品重新进行测试。其目的是要验证修改后的产品是符合需求的,而当没有自动化测试代码时,往往会由于各种各样的原因,回归不充分,导致bug遗漏。2) 提高测试效率软件系统的规模越来越大,功能点越来越多,开发人员的自测或者测试人员的人工测试非常耗时和繁琐,势必导致测试效率的低下,而自动化测试正好解决这些耗时繁琐的任务,在对外接口功能不变的情况下,达到了一次编写,永久使用的效果。3) 提高测试覆

46、盖通过手工测试很难测试到一些更深层次的异常和安全的问题,通过一些辅助的一些测试工具,能分析出代码的覆盖率,通过覆盖率的提高来提高测试的深度。4) 更好地重现软件缺陷由于每次执行都是相同的代码,一旦代码出错,必定回归出错5) 更好定位错误由于接口测试是一种自下向上的测试,因此一量出错,非常容易定位出错,不向系统测试那样了,一旦有Bug,需要几层验证之后才能确定出错位置6) 降低修改bug的成本接口测试基本和开发人员的编码平行工作,因此发现问题会比系统测试早很多,因此减少了修改bug的成本。7) 增进测试人员和开发人员之间的合作关系,测试工程师为了更好地开展工作,需要对开发技术有深入的理解和实践,有了与开发工程师更多的交流。8) 降低了项目不能按时发布的风险由于接口测试很早就介入,在提交给系统测试前对项目代码的核心模块已经做了详尽的测试,必定加速系统测试的时间,由此来保证项目的按时发布。9)提升测试人员的技能。做接口测试必须了解开发人员的开发流程

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 应用文书 > 技术指导

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服