CN101689111A - 软件需求验证的自动化管理 - Google Patents

软件需求验证的自动化管理 Download PDF

Info

Publication number
CN101689111A
CN101689111A CN200880017725.4A CN200880017725A CN101689111A CN 101689111 A CN101689111 A CN 101689111A CN 200880017725 A CN200880017725 A CN 200880017725A CN 101689111 A CN101689111 A CN 101689111A
Authority
CN
China
Prior art keywords
demand
project
user
role
source code
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN200880017725.4A
Other languages
English (en)
Inventor
W·G·圣克莱尔
S·A·圣克莱尔
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
LDRA Technology Inc
Original Assignee
LDRA Technology Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by LDRA Technology Inc filed Critical LDRA Technology Inc
Publication of CN101689111A publication Critical patent/CN101689111A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3684Test management for test design, e.g. generating new test cases
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/10Requirements analysis; Specification techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3688Test management for test execution, e.g. scheduling of test suites
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3692Test management for test results analysis

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Software Systems (AREA)
  • Stored Programmes (AREA)

Abstract

一种以电子方式管理软件开发所用需求的示例性***包括:项目模块,需求模块,映射模块和验证模块。项目模块被配置为建立软件开发项目。需求模块,被配置为基于从需求源捕获的需求信息定义项目的需求。对于每个需求,项目模块被配置为将为该需求而开发的源代码和项目关联起来或者将该需求分配用于开发源代码。映射模块配置用于将源代码中识别出的过程映射到被定义需求。验证模块,配置为基于针对映射过程而开展的分析、代码覆盖测量和单元测试中的一或多个的结果验证项目的被定义需求。

Description

软件需求验证的自动化管理
技术领域
[0001]本发明涉及软件开发需求的管理。具体地说,本发明涉及分布式需求跟踪(traceability)和软件测试/验证整合的自动化技术和工具。
背景技术
[0002]在许多安全性要求严格(safety-critical)和任务性质关键(mission-critical)的行业,比如航空电子、医疗、国防和核工业里,与软件开发项目有关的需求跟踪和验证任务可以占据相当数量的项目预算。现有一些技术可用于从各种需求信息源自动地将用于软件开发项目的需求信息捕捉成为需求跟踪(traceability)矩阵(RTM)的形式,该矩阵可以用于跟踪这些需求在源代码中的实现。需求跟踪矩阵通常包含工程级、用户定义的需求(指定软件产品应该如何操作)以及底层设计约束(不包含代码级)和需求验证(指定软件产品应该如何验证)。此外,也存在一些技术,用于人工测试实现这些需求的源代码以及用于验证这些需求。因此,所需要的是一种将分布式软件开发项目的需求跟踪和测试/验证任务进行集成和自动化,并引入统一的用户接口以帮助管理高度复杂和高技术含量的软件开发项目的技术。
发明内容
[0003]本发明支持高度分布且异步的操作。本发明的多个示例性实施方案采用了中央集成库(depository),它们实质上(inherently)是集中化(centralize)的并且可以由管理者管理。本发明的各示例性实施方案将用户工作区和开发工件(artifact)按动态管理项目树链接(link)起来,从而综合各个进程(process)并且确保了它们的可重复性。用户将软件开发工件返回给中央集成库。因此,本发明的各个示例性实施方案建立并且维持了可证明的可跟踪性。本发明的示例性实施方案可以解决相关领域***中的一些问题,这些领域***中所执行的进程相当程度上是人工进行的、易发生错误并且一致性不好。请留意,本发明不限于或不被要求解决相关领域的这些问题。
[0004]一种以电子方式管理用于软件开发的需求的示例性方法包括:建立软件开发项目;基于从需求源捕获的需求信息定义用于该项目的需求;对于每个需求,将为该需求开发的源代码和该项目关联起来或者将该需求分配以便开发源代码;将源代码中标明的过程映射到用于所述项目的所述被定义需求;并且基于针对所映射过程而进行的单元测试、代码覆盖测量和分析中的一个或多个的结果,验证该项目的被定义需求。
[0005]利用可扩展标记语言(XML)以电子方式管理用于软件开发的需求的一种示例性方法包括对于为软件开发项目而定义的多个需求中的每个需求创建一个XML线程。每个线程包括描述该线程的各种属性的多个元素,和实现用于该项目的各被定义需求的可跟踪性的唯一标识符。该方法还包括实现XML包装器(wrapper),以允许各应用程序和XML线程互联。每个XML线程的各种属性包括该项目的一个对应的被定义需求,被映射到所述对应被定义需求的用于该项目的源代码过程,以及针对被映射过程而进行的单元测试、代码覆盖测量和分析中的一个或多个的结果。
[0006]一种以电子方式管理在用户网络上进行的软件开发需求的示例性***包括项目模块、需求模块、映射模块和验证模块。项目模块被配置为建立软件开发项目。需求模块被配置为基于从需求源捕获的需求信息来定义该项目的需求。对于每个需求,项目模块被配置将为该需求开发的源代码和该项目关联起来,或者将该需求分配用于开发源代码。映射模块配置为将源代码中标明的过程映射到被定义的需求。验证模块配置为基于针对被映射过程而进行的单元测试、代码覆盖测量和分析中的一个或多个的结果来验证被定义的需求。
[0007]一种以电子方式管理在用户网络上进行的软件开发需求的示例性***包括项目模块,被配置用于建立软件开发项目;需求模块,被配置为基于从需求源捕获的需求信息定义用于该项目的需求;建模模块,配置为包括构架性工件和执行工件;验证模块,配置为根据一或多个验证规则,并基于一或多个测试结果来验证该项目被定义的需求。该模块将被定义的需求和建模模块的构架性工件与执行工件链接起来。
[0008]一种以电子方式管理软件开发需求的示例性方法包括建立软件开发项目;基于从需求源捕获的需求信息来定义该项目的需求;建立包括构架性工件和执行工件的建模模块;根据一或多个验证规则,基于一或多个测试的结果验证用于该项目的被定义需求。被定义需求和相应的构架性工件与执行工件链接起来。
附图说明
[0009]结合附图阅读下文对优选实施方案的详细描述之后,本领域的普通技术人员将对本发明的其它目的和优点一目了然;附图中相似的参考标号用于指代相似的元素;并且,附图中:
[0010]图1A和1B分别示意了一个其中可以实现自动管理软件需求的***的示例性环境和自动需求验证工具的示例性实施方案;
[0011]图2示意一个处理流程图,它提供自动管理软件需求验证的方法的各示例性步骤;
[0012]图3A-3E示意了自动管理软件需求验证的***的一种示例性可扩展标记语言(XML)实现;
[0013]图4A-4J示意了自动管理软件需求验证的***的示例性图形用户接口的屏捕获;
[0014]图5示意了选择,创建,重新命名或者删除组视图的例子;
[0015]图6示意了编辑用于给定组的规则的一个例子;
[0016]图7示意了基于类型解析的例子;
[0017]图8示意了在微软MS Word文档下的需求的例子;
[0018]图9和图10示意了类型编辑器的例子;
[0019]图11示意了未编组需求和编组需求的例子;
[0020]图12示意了同级需求的例子;以及
[0021]图13示意了同级需求的另一个例子。
具体实施方式
***总揽
[0022]本发明应当结合示例性实施方案加以描述,但不是必需受限于此。对于本领域的普通技术人员来说在不偏离后附权利要求书所定义的发明范围的情况下会出现许多变化和变更。绝对的语句(开始以“必须(must)”)和有关各种优点或其它方面的语句适用于特定的示例性实施方案,而不是必然地应用于权利要求书所覆盖的所有实施方案。
[0023]这里给出了对软件需求进行自动管理的技术,这些技术可以在分布式用户工作区(例如,本发明的各实例所允许的工作目录)的网络上缩小高级需求跟踪工具和低级源代码测试工具之间的差距。下面结合示例性实施方案进行解释,但本发明不受限于此。
[0024]图1A示意了实施用于对软件需求验证进行自动管理的***100的示例性环境。如图1A所示,***100可以结合基于计算机的***使用,在该基于计算机的***中各元素可以按硬件、软件、固件或其组合的方式实施。如图1A所示,***100包括需求信息源105、需求捕获工具110、自动化需求验证工具115、静态分析&代码覆盖工具120、单元/集成测试工具125、网络130和用户135。软件开发项目(例如医院的账单***、商店的库存跟踪***,航天电子显示***,等)可以由需求定义。所述需求可以指明软件产品在其实施时应当如何操作。需求信息源105,如图1A所示,可以代表任何需求信息源,其中包括需求管理工具(例如Telelogic
Figure A20088001772500131
和IBM Rational
Figure A20088001772500132
),分析表程序(spread sheet programs)(例如Microsoft
Figure A20088001772500133
),文字处理程序(例如MS
Figure A20088001772500134
)。需求捕获工具110可以从需求信息源105捕获需求信息。该信息可以包括需求标识符和需求描述以及测试例标识符和测试例描述。
[0025]在一个实施方案中,需求捕获工具110可以使用自然语言解析需求信息。例如,需求捕获工具,比如来自Geensys(网址geensys.com)的ReqtifyTM工具,采用这样的技术从需求信息产生RTM。也可以采用诸如LDRA TBreqTM的产品或者定制的手工编码***来实现需求捕获工具110。对需求的解析可以基于类型来进行,下文将在段落″基于类型视图进行解析(Parsing Based On Types View)″处详细描述。
[0026]例如,如果为在线杂货店开发软件,那么需求信息源可能包括MS WordTM文件,该文件的一条需求规定“在线杂货店应当维持一个消费者账户”。在该例子中,需求捕获工具110可能从MS WordTM文件的文本中捕获需求信息“维持账户”。在另一个例子中,需求信息源可能包括DOORSTM模块,该模块的一条需求规定“软件必须为所有故障类型提供故障隔离”。在该例子中,需求捕获工具110可以从DOORSTM模块的文本中捕获需求信息“隔离故障”。
[0027]在一个示例性实施方案中,软件建模模块190可以结合需求捕获工具110使用。软件建模模块190可由软件建模工具,比如Telelogic RhapsodyTM,Mathworks SimulinkTM或National InstrumentsLabviewTM实现。在该示例性实施方案中,需求捕获工具110将各需求与构架性工件和执行工件在软件建模工具中190链接在一起。由此,这些构架性和执行工件被隐式映射到由建模工具所产生的源代码中。由此,每个需求和一或多个软件构架性模型元素关联起来。这些模型元素被传递到分布的验证模块,以便执行、测试和分析。
[0028]此外,可以使用建模工具或软件构架性模型来自动产生源代码,其中需求和源代码之间建立映射关系。换句话说,与构架性工件和执行工件链接在一起的各需求被隐式映射到建模工具所产生的源代码。
[0029]如果软件实现是人工编码的,那么需求到源代码的映射将利用基于建模工具所产生的执行工件的自动化需求验证工具115实现。下文将对自动需求验证工具115进行详细说明。
[0030]静态分析&代码覆盖工具120可以用于分析源代码文件(该文件此前由软件开发工具编写),以便识别源代码中的过程并且评估源代码与项目编码规则和质量度量的一致性。这里,“过程”描述的是编写用于实现某需求的一部分代码。例如,过程可能包括C编程语言中的函数和C++编程语言下的类和成员函数。可以采用各种自动化软件分析和测试产品,比如LDRA TestbedTM;Coverity(网址coverity.com)的Coverity Prevent Coverity Extend;ProgrammingResearch(网址programmingresearch.com)的QA-C,QA-C++和QA-MISRA;Gimple Software(网址gimpel.com)的PC-lint for C/C++和另一基于Lint的产品;Klocwork(网址klocwork.com)的inSpect,inSight,inTellect and inForce;Parasoft(网址parasoft.com)的C++Test,C++Test for Embedded Systems,Code Wizard with TestCase Sniffer;McCabe & Associates(网址mccabe.com)的McCabe IQ;Telelogic的Telelogic Logiscope,TAU/Tester和TAU/LogiscopeTestChecker;以及Testwell(网址testwell.fi)的CMT++,Complexity Measures Tool for C/C++,可用来实现静态分析&代码覆盖工具120的静态分析能力。
[0031]就在线杂货店的例子而言,用于实现捕获需求“维持账户”的示例性源代码文件“MaintainAcount.c”可能包括如下代码段:
float MaintainAccount Function()
{
   long accntNum;
   float balance,avgBalance,ratio;
   accntNum=GetSessionAccountNumber();
   if(accntNum==0){return-1;}
   balance=GetAccountBalance(accntNum);
   if(balance<=0){FatalError(″Balance too low″);}
   avgBalance=GetAverageAccountBalance(accntNum);
   ratio=balance/avgBalance;
   if(ratio<.2)
   {
     UserMessage(″Balance is running low″);
   }
   return 0;
}
在该例子中,静态分析&代码覆盖工具120可能识别下面的源代码基本块(块4-6):
60  4  balance=
61  4    GetAccountBalance(
62  4    accntNum);
63  4  if
64  4   (
65  4    balance<=0
66  4   )
67  5   {
68  5
69  5      FatalError(
70  5      ″Balance too low″);
71  5    }
72  6  avgBalance=
73  6    GetAverageAccountBalance(
74  6    accntNum);
75  6  ratio=balance/avgBalance;
76  6  if
77  6    (
78  6    ratio<.2
79  6    )
在分析源代码和项目编码规则的一致性之后,静态分析和代码覆盖工具120可能鉴定下面的代码为不一致性(M)命令:
------------------------------------------------------------
56  2    {
57  2     return
58  2     -1;
(M)STATIC VIOLATION:101 S:Function return typeinconsistent
------------------------------------------------------------
67  5    {
68  5
69  5    FatalError(
70  5    ″Balance too low″);
(M)VIOLATION:1 J:Unreachable Code found.
71  5   }
------------------------------------------------------------
72  6   avgBalance=
73  6    GetAverageAccountBalance(
74  6    accnt Num);
75  6   ratio=balance/avgBalance;
76  6   if
77  6    (
78  6    ratio<.2
(M)STATIC VIOLATION:96S:Use of mixed mode arithmetic:
float double ratio<.2
79  6     )
------------------------------------------------------------
以航空电子显示***为例。一个用于实现捕获需求“维持账户”的示例性源代码文件“CheckAvionicsDisplay.c”可能包含下列代码段:
int CheckAvionicsDisplay()
{
//试图启动各模块,如果一个模块和它的备份失败
//返回一个负数,表明该模块发生故障。
//
if(IBITestModule1()){if(!Ba ckupModule1())return-1;}
if(!BITestModule2()){if(!BackupModule2())return-2;}
if(!BITestModule3()){if(!BackupModule3())return-3;}
//所有模块均已启动。返回1表明成功。
return 1;
}
在此例子中,静态分析&代码覆盖工具120可能识别下列源代码基本块(块1-7):
37  1  int
38  1   CheckAvionicsDi splay()
39  1   {
40  1  //试图启动各模块。如果一个模块和它的备份失败
41  1  //返回一个负数,表明该模块发生故障
42  1
43  1    if
44  1     (
45  1     !
46  1       BITestModule1()
47  1     )
------------------------------------------------------------
48  2    {
49  2      if
50  2      (
51  2      !
52  2        BackupModule1()
53  2       )
------------------------------------------------------------
54  3      {
55  3       return
56  3       -1;
------------------------------------------------------------
57  4       }
------------------------------------------------------------
58  5   }
------------------------------------------------------------
59  6   if
60  6    (
61  6     !
62  6      BITestModule2()
63  6     )
------------------------------------------------------------
64  7    {
65  7    if
66  7        (
67  7     !
68  7     BackupModule2()
69  7    )
在分析源代码和项目编码规则的一致性之后,静态分析&代码覆盖工具120可能鉴定下列代码为不一致性(M)命令:
37  1  int
38  1    CheckAvionicsDisplay()
(M)STATIC VIOLATION:63 S Empty parameter list to procedure/funct.
39  1    {
40  1  //试图启动各模块。如果一个模块&它的备份失败
41  1  //返回一个负数,表明该模块发生故障
42  1  //
43  1     if
44  1       (
45  1         !
46  1          BITestModule1()
(M)STATIC VIOLATION:114 S:Expression is not Boolean.
47  1          )
------------------------------------------------------------
48  2         {
49  2           if
50  2            (
51  2            !
52  2          BackupModule1()
(M)STATIC VIOLATION:114 S:Expression is not Boolean.
53  2             )
------------------------------------------------------------
54  3            {
(M)STATIC VIOLATION:No brackets to then/else(added byanalysis)
55  3              return
56  3           -1;
------------------------------------------------------------
57  4        }
----------- -------------------------------------------------
58  5     }
------------------------------------------------------------
59  6  if
60  6    (
61  6    !
62  6     BITestModule2()
(M)STATIC VIOLATION:114 S:Expression is not Boolean.
63  6          )
67  7            !
68  7              BackupModule2()
(M)STATIC VIOLATION:114 S:MISRA-C:2004 12.6 13.2:Expression is not Boolean.
69  7            )
------------------------------------------------------------
此外,静态分析&代码覆盖工具120也可以用于测试和度量外部运行检验中的代码覆盖。静态分析&代码覆盖工具120对静态分析和代码覆盖(也称为动态分析)能力的集成为测试验证的三角测量和软件抽象的结构化覆盖提供了关键保障。
[0032]单元/集成测试工具125可以用于测试源代码是否符合需求。在一个实施方案中,单元/集成测试工具125可以运行测试用例,所述测试用例定义源代码各部分的输入和期望的输出,并且产生描述代码覆盖的结果。例如,源代码可以实现为多个函数。如果在单元/集成测试期间某个函数被调用并且执行,那么该函数可以描述为“被覆盖”。这样,通常希望被覆盖的源代码所占百分比比较高。另外,在单元/集成测试期间,可以对各种级别的覆盖进行测试,比如路径覆盖、语句覆盖、分支覆盖和变更的条件/判定覆盖(MC/DC)。可以采用各种自动化和集成测试软件产品来实现单元/集成测试工具125,比如LDRA TBrunTM;Parasoft(网址parasoft.com)的C++Test,C++Test for Embedded Systems,Code Wizard and Jest with Test CaseSniffer;Vector Software(网址vectorcast.com)的VectorCAST/Ada,VectorCAST/C,VectorCAST RSP for Real-timeEmbedded Testing和VectorCAST/Cover;IBM Rational(网址www-306.ibm.com/software/rational/)的Test RealTime;IPL(网址ipl.com)的Adatest95和Cantata++;Free Software Foundation(网址gnu.org)的Cunit,CPPunit和Junit;以及,Testwell(网址testwell.fi)的CTA++,C++Test Aider,CTC++,Test CoverageAnalyzer for C/C++。
[0033]以在线杂货店为例。一个示例性测试用例可能测试映射到需求“维持账户”的过程(比如浮点MaintainAccountFunction())是否符合该需求。在该例子中,测试用例可能规定:如果GetAccountBalance(accntNum)被调用时输入值=3201,则测试用例将返回值=1。在该例子中单元测试的覆盖结果可能表示如下:
-覆盖-
-语句-
期望的覆盖率(%):80
映射过程的通过率(%):89
-分支判定-
期望的覆盖率(%):60
被映射过程的通过率(%):63
-路径-
期望的覆盖率(%):70
被映射过程的通过率(%):72
[0034]以航空电子显示***为例,一个示例性测试用例可能测试映射到需求“隔离故障”的过程(比如int CheckAvionicsDisplay())是否符合该需求。在该例子中,测试用例可能规定如果函数BITestModule3()被设置为1并且BackupModule返回1。在该例子中的单元测试的覆盖结果可能表示如下:
--覆盖--
-语句-
期望覆盖率(%):80
被映射过程的通过率(%):61
-分支判定-
期望覆盖率(%):60
被映射过程的通过率(%):51
-路径-
期望覆盖率(%):50
被映射过程的通过率(%):48
[0035]对需求是否已经在源代码中实现的跟踪和对所实现的源代码是否按期望方式运作的验证可以人工方式进行,但是对大型软件开发项目来说可能有数以千计的需求,对需求的人工跟踪和验证很快便会变得不切实际并且无法管理。因此,如图1A所示,自动化的需求验证工具115可以实现,以缩短需求捕获工具110和静态分析和单元/集成测试工具120和125之间的差距。图1B示意了自动化需求验证工具115的一种示例性实现,它包括需求模块140、项目模块145、映射&分析模块150、验证模块155和网络接口模块160。本文中结合图4A-4J描述的LDRA TBmanagerTM工具可以用来实现自动化需求验证工具115。
[0036]需求模块140可以配置为基于需求捕获工具110从需求信息源105捕获的需求信息定义用于该软件开发项目的需求。被捕获的需求信息可以表示用户定义的,项目级的软件开发项目需求,这里称之为“高级”需求。在线杂货店的例子中,被捕获的需求“维持账户”是示例性高级需求。但是,高级需求并不描述实际实现该软件所需要的代码级设计需求。如此,需求模块140可以被配置为提供定义未被需求捕获工具110所捕获的其它需求的选项。
[0037]例如,需求模块140可以用于定义满足某高级需求的一部分的需求,本文称为“低级”需求。低级需求可以定义成规定软件的一部分应当如何实现。例如,一个低级需求可能集中在特定函数、目标或目的。以在线杂货店为例,可以为高级需求“维持账户”定义一种被称为“账户名”的低级需求,以便为该账户建立一个名字。在另一个例子,即航空电子显示***中,为高级需求“隔离故障”定义一个低级需求“启动被命名的冗余***”,以确保只有被识别为BuiltInTest的冗余模块被启用。
[0038]需求模块140也可以用于定义从高级需求或低级需求推断或衍生而来的需求,这里称之为“衍生”需求。因此,衍生需求可能不会由需求捕获工具110捕获,但是可以后续由自动化需求验证工具115创建并且管理。以在线杂货店为例,可以为高级需求“维持账户”定义一个被称为“取消账户”的衍生需求,以取消一个被维持的账户。在另一个例子即航空电子显示***中,可以为高级需求“隔离故障”定义一个称之为“损失评估”的衍生需求,以帮助恢复过程通知。
[0039]需求模块140还可以用于定义作为高级、低级或衍生需求的副本的需求,这里称之为“同级”需求。同级需求可以是出于需求多样化和任务管理(比如,用户135之一可能写源代码来实现某个低级需求,而用户135中的另一个可能验证所实现的源代码)的目的而创建的。如这里所述,同级需求可以由唯一标识符区别,尽管它在其它方面和作为它母体的基础的高级、低价或衍生需求并无不同。这样,需求模块140可以用于给RTM填充(populate)来自需求信息源105的被捕获的高级需求、以及其它的低级、衍生和同级需求,以便允许自动化需求验证工具115提供向下到源代码级的自动化需求跟踪工作。
[0040]同级需求可以被称为验证任务。一种额外的同级类型,或者验证任务,被称为目标(objective)。目标被定义为确保同处理目标或诸如需求验证或恰当计划和归档之类的量化评估的一致性。
[0041]另一种同级需求类型和缺陷报告生成及解决方案有关。作为需求的对立面,缺陷报告可以由用户使用静态分析&代码覆盖工具120或单元/集成测试工具125的自动产生。缺陷报告的分配导致产生一个同级或验证任务,该任务的唯一目的便是跟踪缺陷报告到其关闭为止。
[0042]项目模块145可以配置用于建立项目。如这里所述,项目模块145所建立的“项目”描述了真实世界软件开发项目的电子实现,其中被建立的项目可以提供一种电子机制使得现实世界的许多方面有机化和自动化,其中一些方面包括定义用于项目的需求,分配用户参加项目的工作、跟踪各需求的实现、分析和验证所开发用于实现所述需求的源代码文件、跟踪缺陷。所建立的项目可以包括相关的需求信息和为实现这些需求由开发者编写的源代码文件。在一个实施方案中,先前针对某需求开发的源代码可以和所述项目关联起来。如果该需求不存在已开发好的源代码,那么项目模块145可以推进基于需求的开发,其中在源代码开发之前将该需求分配给用户。
[0043]项目模块145可以配置为对已建立的项目的相关需求和源代码文件进行的分层显示,并且可以提供某需求的状态信息(比如,该需求是否已验证或未获验证,被分配参加该需求工作的用户,等等)。例如,图4C(这里结合一种示例性用户接口描述)示意了一种在线杂货店例子下的项目树412,图中给出了需求和源代码文件的分层体系。通过将高级需求和其低级实现进行关联,项目模块145可以允许项目管理者看到逐个需求的分解图示,了解哪些需求的实现符合编码约定(convention)、代码覆盖水平和函数测试准则。如此,项目模块145可以提供集成的需求跟踪和验证矩阵。在一个实施方案中,项目模块145可以产生状态报告,总结用于某个用户的需求信息,该状态报告可以随着项目的进展加以更新,以纳入诸如单元测试之后的代码覆盖结果之类的其它信息。
[0044]项目模块145可以配置为添加用户135到项目之中。用户135可以包括参加项目工作的任何人,比如项目经理、软件开发者、测试工程师等。在一个实施方案中,项目模块145可以基于被指定完成类似行为的用户135组为项目创建角色”,并且将所创建的角色分配给用户135。例如,可以创建开发者角色、测试工程师角色、独立验证和确认(validation)(IVV)角色和质量保证(QA)角色,以及其它角色。在一个实施方案中,项目管理者角色可以被创建,使得被分配项目管理者角色的用户可以对需求验证处理的几乎所有方面实施控制,并且可以创建其它角色,并且向用户135分配角色和需求。
[0045]在一个实施方案中,可以给角色分配各种权限,以定义被分配该角色的用户可以执行的动作。权限的例子包括创建低级需求权限、创建衍生需求权限、生成子项目权限(例如,当一个用户被分配了某个需求的时候可以建立一个子项目)、编辑线程属性权限(例如,可以给每个需求创建XML线程)、人工验证权限(比如,允许用户访问验证模块155,以审视本文所述的单元测试、代码覆盖和静态分析结果。)以及其它权限。
[0046]项目模块145也可以配置为允许用户具有必要的权限去向用户135分配需求模块140所定义的各种需求(即高级、低级、衍生和同级需求)。在一个实施方案中,向用户分配需求可以建立相应的子项目。这里所提到的“子项目”描述了一个用户可以访问执行和他们被分配角色有关的指定任务(例如,写源代码、分析源代码文件、测试源代码文件等等)的工作区。
[0047]在一个实施方案中,项目模块145可以调整子项目的操作状态,要求用户在对某子项目执行任何任务之前从项目模块145“签出”该子项目,并且在完成所述任务之后将子项目“签入”项目模块145。换句话说,为了签出某个子项目,用户可以出于远程完成任务的目的制作它们的子项目文件的副本,并且为了将子项目签入,用户可以将他们子项目文件的修改后内容复制回已立项项目的目录树中。如此,项目模块145可以通过在每次用户签入和签出它们的子项目的时候将子项目和RTM的当前状态进行同步,保持RTM的完整性。另外,如这里所述,可以分配一种创建子项目的权限,以允许用户通过项目模块145更新子项目。例如,受影响的子项目应当在它们相应的需求被更改(例如由于添加或删除用户的缘故)的时候加以更新。
[0048]如图1B所示的网络接口模块160可以配置为允许项目的全球(globally)分布,并且提供基于通信网络130(例如LAN、WAN、互联网等等)的集成处理。在一个实施方案中,网络接口模块160可以允许用户135从远方将它们的子项目签入和签出。可以实施一些安全措施,比如建立安全连接以及要求用户135登录并且提供密码。此外,验证状态报告可以做到全球可用。通过这些方式,网络接口模块160可以用于执行同步或异步操作并且实现基于全球动态更新的需求矩阵(跟踪和验证矩阵)。
[0049]图1B所示的映射&分析模块150可以配置用来调用静态分析&代码覆盖工具120。如本文所述,映射&分析模块150可以调用静态分析&代码覆盖工具120,将源代码中指明的过程映射到用于项目的各个被定义的需求。以在线杂货店为例,在示例性源代码文件″MaintainAccount.c″中指明的过程floatMaintainAccountFunction(),long GetSessionAccountNumber(),float GetAverageAccountBalance(long accntNum),floatGetAccount Balance(long accntNum),void FatalError(const char*msg),void UserMessage(const char*msg)可以被映射到高级需求“维持账户”。以航空电子显示***为例,过程有intCheckAvionicsDisplayO;int BITestModule1();intBITestModule2();int BITestModule3();int BackupModulel();intBackupModule2();int BackupModule3()。图4G示意了一种将过程映射到需求的示例性图形用户接口。
[0050]此外,映射&分析模块150可以允许用户通过指明分析需求验证方法和/或测试需求验证方法,来验证某个需求。例如,在一个实施方案中,映射&分析模块150可以用于调用静态分析&代码覆盖工具120来提供集成分析能力,包括分析被映射的过程是否符合项目编码规则和质量度量。此外,在另一个实施方案中,映射&分析模块150可以用于调用单元/集成测试工具125来测试被映射的过程是否符合需求,办法是运行测试用例并且产生描述代码覆盖的结果。在又一个实施方案中,映射&分析模块150可以用来装备代码,这些代码将被在外部执行,并且其执行结果(即代码覆盖结果)可以后续返回给映射&分析模块150以便进行事后代码覆盖分析。
[0051]如图1B所示的验证模块155可以配置为基于由静态分析&代码覆盖工具120对被映射过程分析的结果以及由单元/集成测试工具125对被映射过程进行单元测试的结果,来验证所述被定义的需求。例如,在一个实施方案中,具有必要权限的用户可以利用验证模块155来选择需求并且观看该选定需求的期望代码覆盖率和所获得的代码覆盖率(例如,获得期望覆盖率的被映射过程所占百分比)。如果用户对选定需求所取得的覆盖率满意,用户可以将选定需求的当前状态维持为已验证。但是,如果用户对选定需求所取得的覆盖率不满意,那么用户可以改变选定需求的当前状态为未经验证。由于未对某需求做验证即更改了该需求线程(如同本文结合示例性XML实现进行描述的那样),用户应当后续更新和该需求有关的任何子项目。
[0052]验证模块155也可以配置为在一个用户下创建多组,并且将需求和相应组管理起来。各组分别分配有验证规则,使得当一个需求被分配给某组时,为该(基本)需求产生用于每个验证规则的一个同级需求。对于测试验证规则,为每个和基本需求相关的测试用例创建一个同级或验证任务。所有需求可以在初始时是未编组的需求。然后,需求可以和一个或多个组关联起来。
[0053]在该示例性实施方案中,验证规则规定哪些验证任务必须在该需求可以认定为已验证之前完成。某个需求必须满足的内容由该需求所处的验证组决定。验证规则不仅规定什么验证任务必须完成,也规定谁应当去做。验证规则可以确定该需求是否通过代码审查(review),也可以进一步规定代码审查由特定用户或者特定角色(例如,“测试者”或“QA”)的用户来完成。各规则可以排序,排序将促使各规则按照验证组中列出的顺序完成。
[0054]当验证规则被定义的时候,可以应用一个或多个质量模型。一种质量模型可以设立一种标准,通过该标准用于某给定项目的软件的质量可以测量并且可视化。质量模型由代码审查和质量审查验证任务强制执行。
[0055]代码审查标准可以定义在一对文件中,报告文件(<language>report.dat)和处罚文件(<language>pen.dat)。报告文件包含完整的一组预先定义的编码规则。该组规则可以扩展,以便包容某个项目。该组规则的各个子组由公布的编码标准定义,它们是预先定义的,使得用户可以使用这些标准,而不必精通该标准的各个细节。通过报告文件,人们可以看到这些标准到规则的映射及其实施。处罚文件可以是代码审查配置的遗留(legacy)机制。
[0056]质量审查标准可以定义在′metpen.dat′中。该文件包含一系列的分析测量,这些分析测量是和容限(tolerance)阈值配对的。例如,秩(cyclomatic)复杂度测量、代码复杂度测量、不可达代码行测量、注释比例测量。如果复杂度超过某个预设的阈值,则质量审查报告将相应地给予标记。如同用于代码审查的′report.dat′文件那样,′metpen.dat′可以被定制以满足某个项目的需要。
[0057]对不同质量模型的选择可以通过对分配给各组的验证规则的组合实现。当调用同级需求进行代码或质量审查时,采用适当的质量模型进行测试。
[0058]如上文所提及,对于基本需求必须满足的每个验证规则可以产生某个验证任务的某个同级需求。例如,如果某需求的验证规则明确要求它需要通过代码审查,那么产生一个同级,并且如果该同级通过了代码审查,那么该需求被认为通过了代码审查。
[0059]相应地,可以在某个软件开发项目中采用自动化需求验证工具115,以便允许基于需求的开发和验证进程的自动化集成,并且为项目团队的所有成员(包括管理在内)提供对动态更新的跟踪和验证需求矩阵的全球访问。如本文所述,在一个实施方案中,自动化需求验证工具115可以利用可扩展标记语言(XML)实现。
[0060]为了使需求跟踪可重复处理自动化,必须支持一种对测试验证处理的三角测量(triangulation)。这种三角测量包括三个矢量:被映射的需求(包括某过程的静态关联、各过程的聚集体、类或者任何执行工件)、结构性覆盖(代码覆盖的动态度量和测试用例执行)以及测试用例(待执行的功能性)。需求跟踪的实现由于软件编程抽象(software programming abstractions)(比如重载、多重继承,通用参数化(generic parameterizations),和动态调度表)而极大地复杂化。本发明实现这一跟踪的办法是集成所需要的功能性规定的静态和动态矢量。本发明所实现的跟踪,包括对静态分析&代码覆盖工具120的利用,扩展到软件及其运行时间工件的各个用例。除了被映射的需求之外,测试用例(或使用例)必须明确映射为供任何待执行的基于测试的验证任务之用的谓词(predicate)。
处理回顾
[0061]图2示意了以电子方式管理软件开发需求的处理200示例性步骤。并不是图2的所有步骤都必须按照图示顺序出现,本领域的普通技术人员在阅读了本文的教导之后对这一点应当是一目了然的。结合下文的讨论,其它的操作性和结构性实施方案对本领域的普通技术人员来说也是一目了然的。这些步骤将在下文详细讨论。
[0062]在步骤205,建立软件开发项目。例如,结合图1B描述的项目模块145可以用来实现步骤205。在一个实施方案中,步骤205包括为项目识别各用户。在另一个实施方案中,步骤205包括基于被指定执行类似动作的用户组创建该项目的多个角色。例如,项目管理者角色可以创建为具有对处理200实施控制的权限,可以产生至少一个额外的角色,比如开发者角色、测试工程师角色、独立验证和确认(validation)角色、和质量保证角色。在该实施方案中,步骤205可以包括向各角色分配权限,以定义用户可以完成的各项动作,比如创建低价需求权限、创建衍生需求权限、生成子项目权限、编辑线程属性权限和人工验证权限,步骤205也可以包括为用户选择各角色。
[0063]在步骤210,基于从需求源捕获的需求信息来定义用于项目的各个需求。例如,结合图1B描述的需求模块140可以用来实现步骤210。在一个实施方案中,步骤210包括基于需求信息捕获用于该项目的高级需求,基于需求信息来定义该项目至少一个额外需求。所述的额外需求可以定义完成用于该项目的被捕获和分配的高级需求中一部分的低级需求、从用于该项目的被定义高级需求或者低价需求推断而得到的衍生需求,和/或作为用于该项目的被定义高级、低级或衍生需求的副本的同级需求。额外需求信息可以包括任何给定需求相关的测试用例。在被定义为原始需求信息的一部分测试用例不存在的情况下,在执行基于测试的验证任务之前用户必须输入一个测试用例。
[0064]在步骤212,对于每个需求,将已经针对该需求开发的源代码和该项目关联起来。例如,结合图1B描述的项目模块145可以用于实现步骤212。此外,如果还没有为某个需求开发源代码,则步骤212可以促进基于该需求的开发工作,其中需求分配在源代码实现之前完成。在该实施方案中,将源代码和项目的关联直到步骤215才会出现。在步骤212,相应的子项目可以在项目被定义的需求分配给用户的时候建立。
[0065]可选地,处理200可以包括为用户产生状态报告,该用户概括被分配给用户的被定义需求,并且在项目期间更新状态报告,以纳入分析、代码覆盖和单元测试相应结果的各个额外步骤。
[0066]在步骤215,源代码中指明的过程被映射到用于该项目的被定义需求。例如,结合图1B描述的映射&分析模块可以用于实现步骤215。在一个实施方案中,步骤215包括调用静态分析工具,比如结合图1A描述的静态分析&代码覆盖工具120,以分析源代码来识别源代码中的各个过程。在该实施方案中,静态分析工具也可以被调用来对源代码进行分析,包括对相关的源代码文件应用项目编码规则和质量度量。此外,该静态分析&代码覆盖工具120可以用于测试和度量外部运行检验中的代码覆盖。在另一个实施方案中,步骤215包括调用单位测试工具,比如结合图1A描述的单元/集成测试工具125,以便对被映射过程进行用例测试。
[0067]在步骤220,基于对被映射过程执行的分析、代码覆盖测量和单元测试中的一个或多个结果,来验证该项目的各被定义需求。例如,可以采用结合图1B描述的验证模块155来实现步骤220。在一个实施方案中,步骤220包括:如果分析的结果表明源代码和项目编码规则和质量度量一致的话,则验证该项目的被定义的需求。在该实施方案中,可以基于分析结果对未一致情况进行追踪,并且可以就未一致的情况提出报告,包括提供有关不一致的分布信息。在另一个实施方案中,步骤220包括如果测试用例产生所需的结果,则验证该项目的被定义需求。
[0068]在另一个实施方案中,步骤220包括下列额外步骤:提供用于该项目的被定义需求的状态,指明每个被定义需求是否被验证或未获验证;并且产生集成的需求跟踪和验证矩阵,以便动态跟踪被定义需求的实现情况和被定义需求的状态。在该实施方案中,项目的子项目可以通过将项目的被定义需求分配给参加项目工作的用户而建立,并且子项目可以与集成的需求跟踪和验证矩阵同步。
[0069]可选地,处理200进一步包括允许用户通过通信网络访问项目的步骤。例如,结合图1B描述的网络接口模块160可以用于实现该联网步骤。在一个实施方案中,需求跟踪和验证矩阵的完整性可以通过监视用户何时经通信网络签出和签入其相应的子项目的方式而保持。换言之,处理200可以支持一种单元测试工作流场景,该场景包括通过高级、低级和衍生需求而进行的需求跟踪和测试验证并且有助于将这些需求和源代码过程或方法映射在一起。映射后的需求可以后续提供给开发者或测试者进行测试规范(specification)创建和测试验证。处理200也可有助于从这些测试规范创建测试用例。处理200可以自动跟踪该单元测试场景的结果而追溯到需求源,以确保其调度中的需求跟踪矩阵(RTM)完整性和用户工作区(例如,项目/子项目)安全性和灵活性。在一个实施方案中,用户可以就“签入”的子项目展开工作,其中用户所执行的所有任务可以被动态跟踪并且与RTM的更新同步,或者用户可以就“签出”的子项目展开工作,其中可以在任何地点执行验证任务,并且可以后续在用户返回工作(签入的子项目时)将结果和当前RTM同步。
示例性XML实现的详细描述
[0070]正如本文所述,自动化需求验证工具115和自动化需求管理处理200可以用在软件开发项目中,以缩短高级需求跟踪工具和低级代码测试工具之间的差距,并且在一个实施方案中,它们可以利用XML结构实现。
[0071]例如,需求管理数据可以按被称为“线程”的XML构造方式维持,使得每个被跟踪的需求具有一个相应的XML线程。按照此种方式,如本文所指,术语“线程”和“需求”实质上是可以互换的,只是线程更准确地描述了基于需求的任务。例如,如图3A所示,线程305可以包括描述该需求以及和其它需求310之间关系的元数据,以及源代码文件中被映射到需求315的过程的有关原型信息和与该需求验证有关的分析与测试结果信息320。所有原型信息可以保持在线程自身中,包括利用<Prototypex/Prototype>XML块的代码覆盖信息。
[0072]除分层信息(即,线程关系数据可以放置在线程自身中,但是所有的线程一起构成有结合力的层次结构)外,一个线程的所有相关信息均可以放置在线程自身中。如此,一个线程可以在很大程度上成为一个自包含的对象,允许程序能够明智(sensibly)地使用线程信息,而无需关于线程所属项目的任何知识,包括用户、角色和权限信息。例如,图3C示意了一种项目机制340,并且可以看到线程XML文件345可以独立于项目XML文件350、355和360,而项目XML文件350、355和360可以用于创建有结合力项目并且将线程信息以有益和直观的方式呈现给用户。
[0073]线程的定义可以规定数据聚合称为“线程”适量(proper)和必须存在的字段(在XML特定范畴下也称为“元素”)最小数量及其排列。放入到这些字段中的信息是否和真实世界数据有任何相关性超出了线程定义的范围。线程的定义仅和唯一参考识别符(例如ref=””元数据)有关,而和线程可读所采用的实际字符串无关。
[0074]图3B示意了线程XML文件335可以由调用应用/程序325通过被称为CXML Wrapper的XML包装器类加以操控的情形。尽管可以直接从/往线程中读出/写入,CXML Wrapper可以用于强制执行ref=”“XML惯例(convention),由此确保线程按一致的符合标准的方式写和重写。
[0075]图3D示意了线程在存储器中的示例性表示。CXML Wrapper类是基于CGenericXMLWrapper XML包装器类的,后者可以实现用于将XML文件转换为被称为ReqDataContainer365的分层对象树。概念上来看,ReqDataContainer365可以维持关于其自身的分层信息(例如,其父母和子女是谁)以及关于自己数据的分层信息(例如,名字、唯一参考识别符和数据)。CGenericXMLWrapper类可以为读取XML文件时遭遇到的每个元素创建一个ReqDataContainer。该元素的名字和唯一参考号可以存储,有别于任何数据。分层信息可以基于相关因子(其中一个因子比如是,是否该元素具有数据和父元素)从上下文方面加以确定。如此,在ReqDataContainer的树中,每个ReqDataContainer都可以类似于一个具有指向树上同级的指针的节点。
[0076]在遭遇到不具有参考号的元素的情况下,可以给该元素分配一个参考号,以一个合理高的“未知界限”作为起点。如此,希望检索该元素的数据的程序必须提前了解未知界限的值(该值可以定义在XMLWrapper.h类中),以及有关多少未设参考号的元素正被读取以及已经被读取的其它因素。实际上,可以更有效地定义线程树,为线程的每个元素使用唯一参考号(或其它唯一识别符),而不是依赖于自动分配参考号。但是,自动分配参考号可以有助于避免由于程序的故障部分不向其新的元素分配参考号而导致整个线程(或_trace.xml文件)不能被访问的情形。
[0077]一旦CGenericXMLWrapper类创建了一个ReqDataContainer树,如图3D所示,调用程序可以完全自由地修改ReqDataContainer。例如,调用程序可以添加或去除ReqDataContainer,并且修改已有ReqDataContainer中的数据。在调用程序完成对ReqDataContainer树的修改之后,它可以调用该包装器类的一种被称为WriteAsXMLQ的XML方法,将wrapper class转换ReqDataContainer树返回XML文件,并且将XML文件写入存储设备。
[0078]ReqDataContainer365在设计时可以尽可能多地模仿XML。ReqDataContainer并不必需基于它们是否有数据、子容器、同级或任何其它上下文属性(property)而加以分类。但是,在实际中,ReqDataContainer之间应当有所区别,使得数据可以相应地加以组织。
[0079]ReqDataContainer树实现方案的灵活特性可以允许不同的程序将其自身的数据添加到线程中,而不会彼此干扰。例如,在一个实施方案中,缺陷跟踪信息和函数原型XML块可以添加到线程“范围”,而不会混淆其主要的载荷、个体需求。这些是随着个体跟踪需要增加(在此情况下,验证向下延伸到个别函数)而添加到线程中的数据的例子,并且在此方式下,将和需求有关的所有数据及其跟踪信息装入单个线程中的做法可以实现用户程序的灵活性和自由度。ReqDataContainer树实现也可以定义对数据编码的标准途径。如此,希望利用其它程序提供的特征程序仅需要理解所使用的XML块协定(convention),以便围绕它建立其自身功能性。
[0080]在一个实施方案中,可以采用被称为RDCPtr,iRDCPtr,和CwrapperLibrary的类,(1)将重复的XML块组织成“垂直数据”的“堆”,以避免和父节点接触的需要,(2)允许有顺序地访问同级,而不必和父节点通信,(3)提供ReqDataContainer和所存储的XML文件的单个元素之间的一对一关联。
[0081]避免依靠父节点获得子层次关系信息的做法可以改善代码的完整性。例如,程序通常需要访问某个XML块的所有实例,比如从某个线程中获得原型信息。不使用RDCPtr类便能从线程获得原型信息的函数的伪代码表示可以表达如下:
ReqDataContainer prototype_parent=
      current_thread.GetElement(REF_TEST_SPECIFICATION);
ReqDataContainer prototype=
     prototype_parent.GetElement(REF_PROTOTYPE);
  while(prototype!=NULL){
     PrintPrototypelnfo(prototype);
     prototype=prototype_parent.NextElement(prototype);
 }
使用RDCPtr类从线程获得原型信息的函数的伪代码表示可以表达如下:
RDCPtr prototype=current_thread
    .GetElement(REF_TEST_SPECIFICATION)
    .GetElement(REF_PROTOTYPE);
while(prototype!=NULL){
    PrintPrototypelnfo(prototype);
    prototype=prototype.GetNext();
}
[0082]两个实现之间无代码变动(cleanliness)方面的改进可以是显著的,如果考虑到仅需传递一个线程所具有的原型“列表”中的第一原型的RDCPtr,则可以将这一列表作为一个整体到处传递,这是因为该列表中的第一原型知道其它原型的位置。如此,不再需要由一个函数将两个ReqDataContainer指针(一个用于该元素,一个用于它的父元素)到处传递,相反仅需要将一个RDCPtr对象到处传递,便可以使每个函数访问所有的原型。此外,wrapper类仅需要服务(servie)一个应用调用(即得到第一原型的调用),而不必服务其它调用来获得任何额外的原型信息。如此,重复的XML数据块可以表示为“垂直”数据,如图3D和3E所示。第一原型可以和任何其它的XML块一样对待,而后续读取的原型块可以“堆”在第一原型的上面。RDCPtr类体现了ReqDataContainer堆这一理念。
[0083]如此,调用程序不必和ReqDataContainer直接接触。所有的数据访问可以由RDCPtr完成,后者可以实现如图3D和3E所示的唯一的“垂直数据”堆机制。由于它们可以充作智能指针,RDCPtr可以提供专有的访问ReqDataContainer的手段。即使某个元素没有垂直数据(即,只有该元素的一次迭代),它仍然可以采用RDCPtr的形式返回。这样,函数不必被重写来接受ReqDataContainer和RDCPtr,所有的函数可以简单地接受一个RDCPtr。通过传递一个较小的RDCPtr,整个调用程序可以随机或顺序地访问整个垂直数据堆。该特征可以促成更容易、较无变动(cleaner)且更准确的代码实现。此外,通过采用RDCPtr,调用程序不必向/从存储器创建或删除ReqDataContainer,如本文所述该过程可以完全自动地进行。
[0084]iRDCPtr类可以提供将ReqDataContainer“左和右”编排进列表的机制。iRDCPtr类不是由调用程序使用,但是可由后端(例如,用于和XML文件接口的包装器)使用来实现通过同级和写递归算法的顺序搜索法搜索ReqDataContainer树(ReqDataContainer不在ReqDataContainer树记录其同级)。调用程序可以通过索引(即通过唯一参考识别符)访问ReqDataContainer的子容器,但不能顺序地遍历ReqDataContainer的子容器以搜索找到它所需要的子容器,但是对于内部进程来说,CGenericXMLWrapper可以使用iRDCPtr来顺序地遍历ReqDataContainer的子容器。
[0085]调用程序应当使用CWrapperLibrary类来得到用于XML文件的包装器。出于存储器管理的目的,自动化需求验证工具115及其后端可以使用一个类来管理资源的分配和删除。例如,CXMLWrapper类可以用于创建所需要的ReqDataContainers、RDCPtrs和iRDCPtrs。调用程序可以基于请求获得RDCPtrs,并且由CXMLWrapper表示的整个XML文件可以由CXML Wrapper创建和删除。继而,CXMLWrapper可以注册利用GlobalRDCPool对象创建的所有对象(比如ReqDataContainers),GlobalRDCPool对象可以由调用程序在退出的时候清空。
[0086]此外,自动化需求验证工具115及其后端可以利用被称作CWrapperLibrary的类来管理CXMLWrappers,管理方式和GlobalRDCPool类管理RDCPtrs的方式相同。由于CWrapperLibrary的存在,调用程序根本不必创建包装器。相反,调用程序可以向ReqDataContainer树请求获得XML文件。如果还未为该请求的XML文件建立ReqDataContainer树,则可以使用CWrapperLibrary类来创建包装器,让包装器建立ReqDataContainer树,并且向调用程序返回一个指向所创建的包装器的指针。如此,CWrapperLibrary可以组织调用程序正在使用的所有CGenericXMLWrappers。例如,如果调用程序请求和“filel_trace.xml”对应的包装器,CXMLWrapper可以搜索已经建立的包装器库来查找filel_trace.xml的CXMLWrapper对象。如果用于filel_trace.xml的CXML Wrapper对象已经被创建,则CXMLWrapper可以简单地将指向已经生成的CXMLWrapper的指针返回给调用程序,否则CWrapperLibrary可以为filel_trace.xml产生一个新的CXMLWrapper对象,并且将指向新对象的指针返回给调用程序。
[0087]象RDCPtrs一样,CXMLWrapper对调用程序隐藏存储器的分配,使得调用程序不负责释放CWrapperLibrary传递回来的对象。同样,当调用程序使用CWrapperLibrary的时候,该程序的所有部分可以确定是工作在相同的ReqDataContainer树上(ReqDataContainer是XML文件中的单个元素,故此ReqDataContainer的树表示整个XML文件),并且调用程序并不必要遍历该程序实行同步。
[0088]通常,调用程序将调用GetFile()方法来检索RDCPtr中的文件根元素,并且将不会再对包装器作任何进一步的调用。调用程序不删除被创建的包装器。相反,EmptyWrappers()方法(它也将所有已被开启的包装器写入存储设备)可以用替代方式删除包装器。如此,CWrapperLibrary类可以用于确保自动化需求管理程序的所有工作都在相同的ReqDataContainer树上并且有助于存储器管理。
[0089]各个存储器管理类在一起使用的时候可以得到一个不间断存在的RDCPtrs(即,调用程序在会话开始时接收的RDCPtr与调用程序在会话期间后续时间接收的RDCPtr相同),以此允许调用程序使用的相同GlobalRDCPool和CWrapperLibrary各个部分将RDCPtrs到处传递。因此,调用程序决定要求存储器管理类清空它们自己的时间是一个重要的决策点。出于充分利用存储器的原因,在某些情况下,强制清空包装器和RDCPtrs甚至可以是可取的。这种存储器管理技术可以导致在程序的生命周期中存储器利用率的提高。一旦存储器利用率达到一定的水平,它不太可能进一步增加,但是对于在其生命周期中可能打开数十个或甚至数以百计XML文件的程序来说,强制清空存储器管理类可以是有益的。但是应当注意对存储器管理类所管理的资源的引用在对这些资源清空后将不再需要。
[0090]在一个实施方案中,线程可以转换为SQL格式,以便全局网络存储和访问。该进程可以由接受来自自动化需求验证工具115的上载请求的网络(web)服务支持。同一个网络服务可以基于来自网络用户的请求产生跟踪和验证报告。另外,该网络服务可以向自动化需求验证工具115提供下载请求。这些网络服务的结果是,可以促进全局项目同步。
示例性图形用户接口实现
[0091]图4A-4J示意了用于由LDRATM开发的软件需求管理工具TBmanagerTM的图形用户接口(GUI)的示例性实现。TBmanagerTM可以用于促进软件需求的管理和分配,以便开发、测试和验证。本领域的普通技术人员将理解到,GUI设计不必受限于图4A-4J中示意的设计,其它的GUI设计也可以采用。在该实施方案中,可以利用需求捕获工具(比如GeensysTM开发的TBreqTM)首先创建一个项目文件(例如,具有″.tbp″扩展),需求捕获工具可以从诸如Telelogic或IBM Rational
Figure A20088001772500372
MS
Figure A20088001772500373
MS
Figure A20088001772500374
的需求信息源和其它需求信息源捕获用于软件开发项目的需求信息。
定义角色和用户
[0092]图4A示意了在初始设置期间定义项目的角色的示例性GUI401。角色可以用于将执行类似或有关任务的用户编组在一起;例如,可以对项目的所有开发者创建并应用一个角色。每个用户可以分配一个角色。一个用户可以采用项目管理者的角色。项目管理者角色可以对需求管理进程的每个方面进行控制,可以负责创建角色和用户以及委托需求。例如,项目管理者可以创建和分配角色,授权其他用户创建角色和委托需求的能力。
[0093]如图4A所示,GUI401的新角色字段402可以用于输入新角色的名字,并且可以按压Add按钮添加该新角色。示例性角色403可以包括开发者角色、GUI设计者角色、独立验证和确认(IVV)角色、质量保证(QA)角色和测试工程师角色以及其它角色。如图4A所示,可以利用Remove Selected(去除选定)按钮来去除某个已添加角色,并且可以选择Import Roles From File(从文件引入角色)按钮来引进已经定义在文本文件或另一个项目中的角色。
[0094]可以给各角色分配权限,为相应的用户赋予不同级别的功能,比如定义用户可以访问的需求信息和他们可以完成的动作。如图4A所示,可以利用Assign Permission(分配权限)按钮将权限分配给角色403。示例性权限404可以包括“Create LowLevel(LL)Reqs”(创建低级需求),它可以被分配给某角色来允许相应的用户创建低级需求;″Create Derived(DV)Reqs″(创建衍生需求),它可以被分配给某角色来允许相应的用户创建衍生需求;“Make SubProjects(生成子项目)”,它可以允许相应用户为项目需求分配用户;″EditThread Properties″(编辑线程属性),它可以分配给某角色以允许相应的用户通过本文描述的Requirements View(需求视图)编辑可用的需求属性;以及,“Manual Verification”(人工验证),它可以被分配给某角色以便使相应用户访问本文描述的VerificationView(验证视图)。
[0095]角色可以用于使用户之间的分配需求多样化。如此,相同的需求(通过同级需求)可以被分配给两或多个不同角色的用户,而同时保持对开发和验证任务的跟踪。例如,相同的需求可以分配给开发者进行编码,给QA进行测试,给IVV进行独立的验证和确认。
[0096]类似地,图4B示意了为项目定义用户的示意性GUI405。如图4B所示,新的用户字段406可以用于为新用户输入名字,为该新用户选择相应的角色,并且可以通过按压Add按钮添加新用户。添加的用户可以显示在用户字段407。可以利用Remove Selected(去除选定)按钮从项目中去除所添加的用户,可以选择Import RolesFrom File(从文件引进角色)按钮来引进此前在另一文件定义的用户。
[0097]当跟随有本文描述的子项目更新时,在设立之后添加新用户和角色可以安全进行。但是一旦如本文所述为用户分配了需求,则用户和角色将不能删除。例如,删除一个角色将导致某用户丢失在项目工作的必要权限,删除用户将导致需求未被分配。因此,在删除角色和用户时应当留意。
基于类型视图进行解析
[0098]可以引进需求文档并且对之解析。解析工作可以基于类型进行。解析提要必须描述在类型文件中。如图7所示,许多类型文件可以预先定义,涵盖通常使用的工具,比如图表软件(Visio 702);需求管理工具(DOORS 704和706,以及Rational Requisite Pro 708);字处理程序(比如MS Word 710);电子表格程序(Excel 712);以及创作和出版软件(比如Framemaker 714)。类型文件可以是一个转换器,使得它可以理解需求如何描述在参考文件中。
[0099]图8示意了MS Word文件中的需求例子。如图8所示,必须给需求ID 802和需求文本804采用合适的样式(style),使得文件可以按作者希望的方式解析。
[0100]图9和图10示意了类型编辑器的例子。文档中采用的MSWord样式,包括需求ID 802和需求正文804在内,必须描述在类型编辑器字段902和1002中,以便MS字文件可以被正确解析。
组视图
[0101]项目的各验证组可以创建在一个用户下。图5示意了在“Verification Groups”对话框500下选择、创建、重新命名或删除组视图的例子。如图5所示,点击“New Group”(新组)按钮502创建验证组。当点击“New Group”按钮502的时候,对话框“EnterGroup Information”(输入组信息)518出现。可以在名字文本字段514输入验证组的名字。在此例子中,在名字文本字段514中输入组名字“High Priority(高优先级)”。此外,在描述文本字段516输入描述“Must be implemented in the current spiral”(必须在当前螺旋中实现)。当点击“OK”按钮的时候,一个验证组得以创建。
[0102]一旦创建了验证组,用户可以突显该组并且点击“Rules>”(规则)按钮508,为某个给定组编辑验证规则。图6示意了在“EditRules”(编辑规则)对话框600中为给定组编辑规则的例子。参看图6,当点击“New”(新)按钮610时,“New Rule”(新规则)对话框616出现。在“New Rule”对话框下,规则分别在文本字段602和604规定需求必须满足“Unit Testing”(单元测试),并且必须由“The Requirement′s Assignee”(需求受指派人)完成。可供选择的验证规则可以包括:代码审查、质量审查、***测试、单元测试、子***测试和集成测试。也可以判断被分配给该需求的用户是否被允许执行该测试,或者是否必须由另一用户执行该测试。当点击“OK”按钮606时,新规则便被创建在“High Priority”(高优先级)组下。“<Group”(组)608按钮可以用于返回“Verification Groups”(验证组)对话框500。“Save and Use”(保存和使用)按钮612可以用于保存这些规则,供将来之用。“Use Existing”(使用现有的)按钮614可以用于为给定组选择所保存的规则。
[0103]返回图5,“Rename Group”(重新命名组)按钮504可以用于对该组重新命名,如果它已经被创建的话。“Delete Group”(删除组)按钮506可以用于删除某个组。“Save and Use”(保存和使用)按钮可以用于保存组信息设置,供将来之用。“Use Existing”(使用现有的)按钮512可以用于为给定组选择所保存的组信息设置。
[0104]在按照上文对组定义之后,需求可以和该组关联起来。图11示意了未编组需求和编组需求的例子。在图11中,REQ 1 1102和REQ 2 1104是未编组需求。REQ 3 1106和REQ 4 1108被包含在命名为“Static Testing”(静态测试)的组别中。
同级需求视图
[0105]图12示意了同级需求视图的例子。在图12中,两个同级需求1202和1204对应于需求1206。同级需求1202供代码审查用,同级需求1204供质量审查用。
[0106]验证可以由该组同级需求驱动,并且每个同级需求都要求一个单独的测试运行被执行。需求只有在所有和该需求对应的同级需求被验证之后才算验证通过。
[0107]图13示意了同级需求视图的另一个例子。在图13中,同级需求1306位于与命名为“Sam Brown”的开发者有关的命名为“Static Testing”(静态测试)1304的组别之下。同级需求1306表明验证任务是代码审查。在该例子中,同级需求的验证状态1308是“Passed”。它也表明分别命名为CashRegister.cpp和Backbeat.cpp 1310和1312源文件和同级需求1306有关。
项目视图
[0108]如图4C所示,GUI可以有选项卡式的格式,为用户提供可供选择的不同视图(例如,项目、验证、定义需求、需求信息、分配用户、映射过程、以及过程)和可以基于其被分配角色而执行的动作。图4C示意了在选择Project View(项目视图)标签的时候可以显示的GUI 408。项目GUI 408可以显示被分配给用户和被用户分配的所有需求(例如,粗体的需求可以表示被分配给用户的需求,非粗体的需求可以表示为用户已经分配的需求)。
[0109]项目GUI 408包括当前需求下拉菜单409,该菜单可以用于选择和显示项目的特定需求。GUI 408也包括一些按钮,比如可以用于选择供上载的项目或子项目文件的Open Project(打开项目)按钮410a,可以选择用于利用对项目需求所做的近期修改来更新/同步所有当前签入的子项目的Update Sub-Projects(更新子项目)按钮410b,可以选择来基于项目的当前需求显示状态报告的Status Report(状态报告)按钮410c,可以选择用来对当前项目添加/上载代码源文件的Add Source(增加源)按钮410d,可以选择用来从当前项目去除当前选定的源代码文件的Remove Source(去除源)按钮410e,可以选择用来发布单元测试用的外部工具(比如LDRA TestbedTM和TBrunTM)的Unit Test(单元测试)按钮410f,以及如果当前用户有必要的权限的话可以选择来设立角色和用户的Setup Wizard(设置能手)按钮410g。项目GUI的其它元素分别包括可以选择用来显示用户指引的User Guide按钮411,以及可以选择用来分别退出工具和保存当前项目的Exit and Save(退出和保存)按钮413和414。
[0110]项目GUI 408也可以显示项目树412,列明被分配给用户的各个需求和添加到项目的任何源代码文件。需求树412可以按号码、名字、参考标识符和类型显示每个需求,这里可以采用不同的图标表示不同类型的需求。此外,“X”号可以覆盖在需求图标上,以表明相应的需求是未被验证的。为了观看某个需求的更多信息,用户可以选择本文描述的Requirement Information(需求信息)标签。
[0111]对子项目的更新可以进行,将对项目的各项需求的修改分发给受影响的子项目。为了更新子项目,用户应当首先签入他们的子项目。然后,在修改需求(例如重新分配需求,未验证需求等等)之后,可以选择Update Sub-Projects(更新子项目)按钮410b来散发该修改给所有受影响的签入子项目,使得当用户后来签出他们的子项目的时候,他们可以访问该修改。尽管只有工作在受需求修改影响的子项目的用户需要在更新子项目之前签入他们的子项目,但是所有用户应当签入它们的子项目以便完成对用户的修改(例如,当从/往项目去除/添加用户的时候)。
[0112]在一个实施方案中,用户可以通过按压Status Report(状态报告)按钮410c产生状态报告,以显示所有和用户相关的需求的当前状态。状态报告可以提供被分配给用户或由用户分配的需求的汇总,可以显示详细的需求属性,比如需求名称、需求号、需求文件、需求体、分配给需求的用户和被分配用户的角色。随着项目的进行以及过程被映射到需求,如本文所述,状态报告可以被更新,以便纳入每个需求的被映射过程表。该表可以显示被映射过程的详细属性,比如过程名字、源代码文件的名字和位置、所取得的路径覆盖、所取得的分支判决覆盖、所取得的MC/DC覆盖和所取得的语句覆盖。表中的取得覆盖字段可以保持为空,直至对被映射过程的测试已经完成,如本文所述。在单元测试完成之后,这些字段可以更新以显示所取得的覆盖。另外,在单元测试完成之后,状态报告可以指明取得所需覆盖的被测试映射过程的百分比。状态报告也可以配置为区分获验证和未获验证的需求被显示的方式,例如采用不同颜色的文本来加以显示。
[0113]在对需求定义并且将用户分配给所被定义需求(如本文所述)之后,可以通过选择Add Source(增加源)按钮410d,将已经由用户开放的源代码添加到项目中。一旦添加之后,源代码可以显示在项目树412中。值得注意,源代码文件可以添加到项目而不是需求自身,这是因为源代码文件中的过程,而不是源代码文件自身,可以被映射到需求中,如本文所述。也可以通过选择拟在Project Tree(项目树)412中去除的源代码文件并且按压Remove Source(去除源)按钮410e,将源代码文件从项目中去除。
需求信息视图
[0114]图4D示意了在Requirement Information(需求信息)标签被选择时可以显示的GUI 415。需求信息GUI 415可以显示有关当前选定需求的信息。具体地说,需求信息GUI 415可以将当前选定的需求的有关信息编组为三个关注区域:test configuration(测试配置)、test management(测试管理)和requirement nomenclature(需求命名)。Test Configuration下拉菜单416可以用于观看和编辑当前选定需求的测试配置特性的有关信息,Test Management下拉菜单418可以用于观看和编辑当前选定需求的测试管理特性,而Requirement Nomenclature下拉菜单417可以用于观看和编辑当前选定需求的需求命名的有关信息。需求信息GUI 415包括View/Edit(观看/编辑)区419,其中可以显示和/或编辑选定需求。当不允许用户编辑和被选定需求信息有关的数值或描述时,View/Edit区419可以变灰。
定义需求视图
[0115]在项目的寿命周期期间,可能需要引入新的需求或改进现有需求。为了定义某个需求,可以选择Define Requirement(定义需求)标签。图4E示意了在选定Define Requirement标签的时候可以显示的GUI 420。利用定义需求GUI 420,用户可以根据被分配给用户的相应角色的权限,创建并且添加低级或衍生需求到项目中去。如本文所述,高级需求包括被需求捕获工具所捕获并且引入项目中的需求。低级需求包括和高级需求有关的需求。衍生需求包括未被需求捕获工具捕获但在TBmanagerTM中定义并且由高级或低级需求推知或衍生得到的需求。
[0116]如图4E所示,定义需求GUI 420包括可以用于输入被定义需求的名字的Requirement Name(需求名字)字段421,可以用来选择被定义需求是否是衍生(DV)或低级(LL)需求的Requirement Type(需求类型)单选按钮422,可以在定义低级需求时使用来选择和该低级需求相关联的高级需求(否则可以选择NONE(DV需求))的Reference Requirement(参考需求)下拉菜单423。定义需求GUI 420也包括可以用来输入被定义需求的号码的Requirement Number(需求号)字段424。在一个实施方案中,项目的每个需求要求有唯一的识别号,它可以由TBmanagerTM自动填写。定义需求GUI 420也包括可以用来输入到详细描述被定义需求的文件的路径的RequirementDocument Path(需求文件路径)字段425(Browse按钮可以用于找到该文件),可以用来输入被定义需求的简短描述的Requirement Body(需求体)字段426,可以用来清除定义需求GUI 420的所有字段的Clear(清除)按钮427,和可以在按压后创建新需求的Create LL/DV(创建)需求按钮428。在一个实施方案中,在向项目引入需求的时候,TBmanagerTM可以自动使用规定在模板中的数值作为该新需求的期望代码覆盖的数值。新定义的低级或衍生需求可以显示在项目树412中。
[0117]在项目的寿命周期期间,可能有必要摒弃或忽略某个需求,以便它不再被考虑用于验证。用户可以通过项目GUI 408选择拟在项目树412中解除分配的需求,并且通过定义需求GUI 420利用De-allocate/Re-allocate Current Requirement(解除/重新分配当前需求)按钮429解除对选定需求的分配。De-allocate/Re-allocate Current Requirement按钮429可以配置为相对于选定需求的上下文相关的按钮,使得它根据需要在“De-Allocate CurrentRequirement”(解除当前需求)和“Re-allocate CurrentRequirement”(重新分配当前需求)之间切换。如此,用户可以通过项目GUI 408选择项目树412中的被解除分配的需求,按相似方式重新分配该被解除分配的需求,并且可以通过定义需求GUI 420利用De-allocate/Re-allocate Current Requirement按钮429重新分配被选定需求。
分配用户视图
[0118]已经建立项目的角色和用户之后,可以通过选择AssignUsers标签,为用户分配要工作的需求。图4F示意了在Assign Users标签被选定的时候可以显示的GUI 430。利用该分配用户GUI 430,具有必要权限的用户可以分配各用户给各个需求,并且创建同级需求。如本文所述,可以出于需求多样化和任务管理的需要,在TBmanagerTM中创建同级需求,并且代表项目的高级、低级或衍生需求的副本。拟分配的需求可以通过项目GUI 408从项目树412中选出,或者通过分配用户GUI 430从Current Requirement(当前需求)下拉菜单中选出。
[0119]分配用户GUI 430包括“Assigned to this Requirement”(分配给该需求)字段,它有一个可以显示被分配给当前需求的用户名字的User字段431和可以显示被分配给该用户的角色的Role字段432。分配用户GUI 430也包括“Assign User”(分配用户)字段,它有一个可以用于基于项目的用户435的相应角色434识别哪些用户可供选择的Filter by Role(按角色过滤)下拉菜单433。可以选择Assign to Requirement(分配给需求)按钮436来将识别出用户435中的一个选定用户分配给当前需求。
[0120]为了完成该分配并且为该用户创建一个子项目,可以通过项目GUI 408然后由Update Sub-Projects(更新子项目)按钮410b选择Save(保存)按钮414。在一个实施方案中,可以在项目目录中建立命名为“Sub-Projects(子项目)”的目录,以容纳所有该用户的子项目。每个用户可以具有单独的子项目目录,它可以在首次分配一个需求的时候自动创建。然后用户可以打开他们各自的子项目来就被分配的需求开展工作。用户可以将他们的子项目目录复制到不同的机器(例如他们自己的安装有TBmanagerTM的工作站或笔记本)来开展所分配需求的工作。用户然后可以在其机器上启动TBmanagerTM,通过项目GUI 408选择Open Project(打开项目)按钮410,导航到子项目目录,并且选择适当的子目录来开展工作。用户可以被要求在登陆时输入名字。然后,项目GUI 408可以刷新自身,以显示用户项目和所分配的需求。
[0121]分配用户GUI 430也可以用来创建同级需求,它是已有高级、低级或衍生需求的副本。同级需求可以,在除了被分配给该同级需求的唯一识别符以外,和相应的高级、低级或衍生基本需求相同。同级需求可以在被创建的时候复制基本需求线程。如此,同级需求可以允许用户将相同的需求分配给具有不同角色的多个用户(一个同级不能被分配给具有相同角色的两个用户)
[0122]为了创建同级需求,通过选择Create Sibling Req+Assign(创建同级需求+分配)按钮437,经分配用户GUI 430显示的用户435之一可以被选定并且分配给同级需求。在一个实施方案中,被分配给同级需求的用户应当具有不同于被分配给基本需求的用户的角色。新创建的同级需求可以通过项目GUI 408观看,并且在项目树412中将其显示为基本需求的子需求。仅仅有制作子项目权限的用户应当被允许创建同级需求。
[0123]由于同级需求可以被看成相应基本需求的严格副本,如果基本需求发生变化,则其所有的相关同级需求应当被解除分配,如本文所述。然后,修改后的基本需求的新同级需求可以被创建并且分配给适当的用户。如果基本需求有新过程分配给它,有它的需求体发生改变,或者任何其它的可能影响据以验证基本需求的条件的变化发生,那么应当创建新的同级需求。
映射过程视图
[0124]图4G示意了在选择Map Procedures(映射过程)标签的时候可以显示的GUI 438。在向项目添加用户开发的源代码文件之后,如本文所述,映射过程GUI 438可以用于选择一个添加的源代码文件,为可用的过程分析该选定源代码文件,并且将选定的过程映射到一个当前选定需求。可以利用Project Source Files(项目源文件)下拉菜单439,来选择已经被添加到当前项目的源代码文件并且返回在选定源代码文件中找到的过程列表442。例如,可用调用LDRA TestbedTM工具来分析选定源代码文件并且将识别出的过程列表442返回给TBmanagerTM
[0125]可以通过分别选择Analyze Procedures(分析过程)按钮440和Analyze Interactively(交互分析)按钮441,以静态和/或交互方式分析选定源代码文件与项目编码规则和质量度量之间的一致性。也可以调用LDRA TestbedTM来对选定源代码文件进行静态和/或交互的分析。如果希望采用交互分析,那么用户可以进行代码审查、质量审查和设计审查分析。完成分析之后,映射过程GUI 438可以显示在选定源代码文件中找到的识别过程442。利用Map to CurrentRequirement(映射到当前需求)按钮444,用户可以将某个识别出的过程442映射到当前需求,后者可以通过项目GUI 408利用CurrentRequirement(当前需求)下拉菜单或Project Tree(项目树)412选择。类似地,可以选择Unmap Selected(解除选定的映射关系)按钮443来解除某个识别出的过程442和当前需求的映射关系。在将过程映射到需求之后,用户可以选择Procedures(过程)标签来观看被映射到当前需求的过程的列表。
过程视图
[0126]用户可以选择当前需求的映射过程并且通过过程GUI 445观看其相应的输入和输出(I/O),如图4H所示。过程GUI 445包括一个Select Procedure下拉菜单446,它可以用于从映射到当前需求的各过程中选择一个过程。可以从Current Requirement(当前需求)下拉菜单或通过项目GUI 408从Project Tree(项目树)412选择当前需求。作为选择映射后过程的结果,过程GUI 445可以被更新,以显示I/O变量字段447中的选定被映射过程的I/O变量。另外,过程GUI 445包括可以用来为当前需求修改期望代码覆盖值(例如,语句、分支、MC/DC、和路径覆盖值)的Desired Coverage(所需覆盖)字段449,和可以用来在单元测试之后观看所取得覆盖的CoverageAchieved at Verification(验证所取得的覆盖)字段450。可以选择Unmap This Procedure(解除该过程的映射关系)448来解除选定被映射过程和当前需求之间的映射关系。
[0127]一旦各过程被映射给需求,就可以启动单元测试。首先,可以从Project Tree(项目树)412或通过项目GUI 408从CurrentRequirement(当前需求)下拉菜单409选择有待测试的被映射过程的需求。接下来,为了启动单元测试,在按压UnitTest(单元测试)按钮410f后,包含被映射到选定需求的过程的源代码文件可以被选择。然后,可以调用外部单元测试工具来完成单元测试。例如,LDRATBrunTM是可以经LDRA TestbedTM工具调用的单元测试工具。利用该外部测试工具,可以创建用于被映射过程的测试用例。然后,可以选择待测试的被映射过程,可以输入测试用例的各个输入和期望输出,并且运行测试用例。
[0128]如果测试用例的结果是令人满意的并且取得了期望的代码覆盖,那么应当确认需求验证结束。在确认需求验证的完成之前,对某个需求的每个被映射过程应当采用至少一个测试用例来进行测试。在关闭外部单元测试工具之后,TBmanagerTM可以刷新ProjectTree(项目树)412来显示该需求为通过验证的(例如,相应的需求图标在显示时可以不带“X”符号)。项目管理者现在可以审查项目的单元测试信息,评估用户的工作。
验证视图
[0129]一旦用户对某需求的各被映射过程进行了单元测试,就可以在Project Tree 412将该需求显示为“已获验证”,如项目GUI408所示。但是,由于对映射过程的单元测试可能没有取得期望的覆盖,项目管理者或具有必要权限的其它用户应当审查单元测试的结果,并且判断是否该需求实际上应当被视为已获验证。
[0130]取决于被分配给用户的权限,用户可以通过选择Verification标签来访问验证GUI 451,验证某需求是否已经达到期望的代码覆盖,如图4I所示。为了验证某个需求,用户可以经项目GUI 408或经验证GUI 451从Current Requirement下拉菜单,从Project Tree 412中选择拟验证的需求。验证GUI 451包括显示被选需求452的当前状态的Details(细节)字段453。Details字段453指明被分配给选定需求452的用户及其角色、期望的代码覆盖、和取得的代码覆盖,后者可以根据取得期望覆盖的被映射过程的百分比加以显示。如果用户对所选定需求取得的覆盖满意,那么用户可以按压Verify(验证)按钮454将选定需求的当前状态维持为已获验证。但是,如果用户对选定需求所取得的覆盖不满意,那么用户可以按压Un-verify(未验证)按钮455,将选定需求的当前状态改为未获验证。由于将需求标记为未获验证的做法改变了该需求,那么用户应当更新任何和该需求相关的子项目。
[0131]对于同级需求的验证,同级需求在相当程度上象低级需求。换言之,为了让基本需求被看作为已获验证,它的所有同级需求必须先获验证。例如,如果开发者用户已经分配了一个低级需求,它具有两个同级需求,一个用于IVV用户而另一个用于QA用户,开发者不能指明该低级需求是获验证的,直到IVV和QA用户将相应的同级需求标记为获验证。
[0132]一个TBmanagerTM的示例性用途场景如下文所述。首先,项目管理者可以基于捕获的高级需求建立一个项目、创建低级、衍生和同级需求(如果恰当的话),将各需求分配给各个用户。用户可以签出它们各自的子项目,所述子项目是在项目管理者将需求分配给用户时建立的。换言之,用户可以出于在远程展开子项目工作的考虑制作他们的子项目的副本。用户可以通过映射过程、测试和分析源代码等操作,修改子项目。然后,用户可以签入它们的修改的子项目。换言之,用户可以将子项目的更新内容复制回项目的目录树。项目管理者可以在后续登录,并且获得项目所有方面的完整的当前视图。
缺陷视图
[0133]图4J示意了当缺陷标签被选定时可以显示的GUI 456。在一个实施方案中,用户可以通过缺陷GUI 456跟踪项目源代码中的缺陷。例如,缺陷GUI 456可以用于基于静态分析工具所进行分析的结果,跟踪源代码中的缺陷(即不一致性)。如图4J所示,用户可以通过选择“Add Defect”(增加缺陷)按钮457,添加拟跟踪的缺陷。添加的缺陷458与该缺陷的有关信息以及缺陷处置信息一起显示,该有关信息包括例如缺陷号、创建日期、状态、和被分配给缺陷的用户。添加缺陷458也可以被选择用于编辑。
结论
[0134]上文结合多个示例性实施方案对本发明进行了描述,但是相关领域的普通技术人员易于理解的是有可能采用不同于前文描述的示例性实施方案的方式来实施本发明。这在不偏离本发明范畴的情况下是可行的。这些示例性的实施方案仅仅是示意性的,无论如何不应当看作为限制性的。本发明的范围由后附的权利要求书而不是前文的说明书限制,并且所有落入权利要求书范围之内的所有变化和等价物均被视为包含在内。

Claims (81)

1.一种以电子方式管理软件开发的需求的方法包括:
建立软件开发项目;
基于从需求源捕获的需求信息定义该项目的需求;
对于每个需求,将为该需求开发的源代码和该项目关联起来或者将该需求分配用于源代码的开发;
将源代码中标明的过程映射到所述项目的被定义的需求;并且
基于针对所映射过程而进行的单元测试、***测试、代码覆盖测量和分析中的一个或多个的结果验证该项目的被定义需求。
2.如权利要求1所述的方法,其中定义项目的各需求的步骤包括:基于需求信息捕获用于该项目的高级需求;并且,基于所述需求信息定义用于该项目的至少一个额外需求。
3.如权利要求2所述的方法,其中定义用于该项目的至少一个额外需求的步骤包括从由下列构成的组中选择定义用于该项目的至少一个额外需求:满足该项目的一个捕获高级需求的一部分的低级需求,从该项目的捕获的高级需求或定义的低级需求中推断出的衍生需求;作为该项目的高级、低级或衍生需求的副本的同级需求,所述项目定义了并能够执行一个验证任务。
4.如权利要求3所述的方法,其中建立软件开发项目的步骤包括:识别项目的用户;将项目的被定义需求分配给用户,以便建立相应的子项目。
5.如权利要求4所述的方法,还包括:为用户产生汇总被分配给用户的被定义需求的状态报告,并且在项目期间更新状态报告,以纳入分析、代码覆盖测量和单元测试的任何相应结果。
6.如权利要求4所述的方法,还包括:基于被分配执行类似动作的用户组创建多个用于项目的角色;将权限分配给所述角色,以定义用户可以完成的动作;并且,从所述多个创建角色中选择用于用户的角色。
7.如权利要求6所述的方法,其中创建多个角色的步骤包括:创建项目管理者角色,它具有对所述以电子方式管理软件开发用需求的方法实施控制的权限。
8.如权利要求7所述的方法,其中所述创建多个角色的步骤包括:从由下列角色组成的组中创建至少一个额外角色:开发者角色、测试工程师角色、独立验证和确认角色和质量保证角色。
9.如权利要求6所述的方法,其中对角色分配权限的步骤包括:分配从下列权限组成的组中选择出的至少一个权限:创建低级需求权限,创建衍生需求权限、生成子项目权限、编辑线程特性权限、和人工验证权限。
10.如权利要求1所述的方法,其中映射所述过程的步骤包括:调用静态分析工具来分析源代码以识别源代码中的过程。
11.如权利要求10所述的方法,其中映射所述过程的步骤还包括:调用静态分析工具以便对源代码进行分析,包括向源代码应用项目编码规则和质量度量。
12.如权利要求11所述的方法,其中验证项目的被定义需求的步骤包括:如果分析结果表明源代码和项目编码规则和质量度量一致,则验证通过所述的项目的被定义需求。
13.如权利要求12所述的方法,还包括:基于分析结果跟踪不一致性;报告所述不一致性,包括提供有关所述不一致性的处理的信息。
14.如权利要求10所述的方法,其中所述映射过程的步骤还包括:调用单元测试工具对所映射的过程运行测试用例。
15.如权利要求14所述的方法,其中验证项目的被定义需求的步骤包括:如果测试用例产生期望结果,则验证通过项目的被定义需求。
16.如权利要求1所述的方法,还包括提供项目的被定义需求的状态,指明每个被定义需求是已获验证或未获验证的。
17.如权利要求16所述的方法,还包括:产生集成需求跟踪和验证矩阵,以便动态跟踪被定义需求的实现和被定义需求的状态。
18.如权利要求17所述的方法,还包括:通过将项目的被定义需求分配给参加项目工作的用户来建立项目的子项目;并且将子项目和集成的需求跟踪和验证矩阵同步。
19.如权利要求18所述的方法,还包括:允许用户通过通信网络访问项目;并且通过监视用户何时经通信网络签入和签出相应的子项目来维持需求跟踪和验证矩阵的完整性。
20.一种以电子方式管理软件开发的需求的***,包括:项目模块,被配置为建立软件开发项目;需求模块,被配置为基于从需求源捕获的需求信息定义项目的需求,其中对于每个需求,项目模块被配置为将为该需求而开发的源代码和项目关联起来或者将该需求分配用于开发源代码;映射模块,配置用于将源代码中识别出的过程映射到被定义需求;以及,验证模块,配置为基于针对映射过程而开展的分析、代码覆盖测量和单元测试中的一或多个的结果验证被定义需求。
21.如权利要求20所述的***,其中需求模块经配置为捕获用于该项目的高级需求;并且,基于所述需求信息定义用于该项目的至少一个额外需求。
22.如权利要求21所述的***,其中需求模块被配置为定义从由下列需求构成的组中选出的用于该项目的所述至少一个额外需求:满足该项目的一个捕获高级需求的一部分的低级需求,从该项目的捕获的高级需求或定义的低级需求中推断出的衍生需求;作为该项目的高级、低级或衍生需求的副本的同级需求。
23.如权利要求20所述的***,其中项目模块被配置为识别项目的用户;并且将项目的被定义需求分配给用户,以便建立相应的子项目。
24.如权利要求23所述的***,其中项目模块被配置为基于被指定执行类似动作的用户组创建多个用于项目的角色;将权限分配给所述角色,以定义被分配给该角色的用户可以完成的动作;并且,将角色分配给用户。
25.如权利要求24所述的***,其中所述角色包括具有对所述以电子方式管理软件开发用需求的***实施控制的权限的项目管理者角色,和从由下列角色组成的组中选择出的至少一个额外角色:开发者角色、测试工程师角色、独立验证和确认角色和质量保证角色。
26.如权利要求25所述的***,其中所述角色具有由拥有创建角色的权限的用户之一定义的角色。
27.如权利要求24所述的***,其中所述权限从下列权限组成的组中选择出:创建低级需求权限,创建衍生需求权限、生成子项目权限、编辑线程特性权限、和人工验证权限。
28.如权利要求20所述的***,其中映射模块被配置为调用静态分析工具来识别源代码中的过程。
29.如权利要求28所述的***,其中映射模块被进一步配置为调用静态分析工具以便对测试中的源代码的代码覆盖进行测试和度量。
30.如权利要求29所述的***,其中验证模块被配置为在代码覆盖测量产生所需结果的情况下,则验证通过所述的项目的被定义需求。
31.如权利要求28所述的***,其中映射模块被进一步配置为,通过向源代码应用项目编码规则和质量度量,调用静态分析工具以便对源代码进行分析。
32.如权利要求31所述的***,其中验证模块被配置为,如果分析结果表明源代码与项目编码规则和质量度量一致,验证通过所述的项目的被定义需求。
33.如权利要求32所述的***,其中验证模块进一步配置为基于分析结果跟踪不一致性;报告所述不一致性,提供有关所述不一致性的处理的信息。
34.如权利要求28所述的***,其中映射模块被配置为调用单元测试工具对所映射的过程运行测试用例。
35.如权利要求34所述的***,其中验证模块被配置为,如果测试用例产生期望结果,则验证通过项目的被定义需求。
36.如权利要求20所述的***,其中项目模块被配置为:跟踪项目的被定义需求的状态,该状态指明每个被定义需求是已获验证或未获验证的。
37.如权利要求36所述的***,其中项目模块被进一步配置用于产生集成需求跟踪和验证矩阵,以便动态跟踪被定义需求的实现和被定义需求的状态。
38.如权利要求37所述的***,其中通过将项目的被定义需求分配给参加项目工作的用户来建立项目的子项目;并且将子项目和集成的需求跟踪和验证矩阵同步。
39.如权利要求1所述的***,其中该项目模块被配置用于基于该跟踪和验证矩阵产生状态报告。
40.如权利要求37所述的***,还包括网络接口模块,它配置用于允许用户通过通信网络访问项目;其中项目模块被配置用于通过监视用户何时经网络接口模块签入和签出相应的子项目来维持需求跟踪和验证矩阵的完整性。
41.一种利用可扩展标记语言以电子方式管理软件开发需求的方法,包括:对于为软件开发项目而定义的多个需求的每个需求创建一个XML线程,其中每个线程包括描述该线程的各种特性的多个元素,和允许该项目的各被定义需求可跟踪的唯一标识符;实施XML包装器,以允许应用和XML线程接口;其中每个XML线程的各元素包括该项目的一个对应的被定义需求,被映射为所述对应被定义需求的项目源代码的过程,以及针对被映射过程而进行的单元测试、代码覆盖测量和分析中的一个或多个的结果。
42.如权利要求41所述的方法,还包括:将每个XML线程转换为由多个容器对象构成的分层树,其中每个容器对象对应于该XML线程的一个元素并且具有唯一识别号。
43.如权利要求42所述的方法,还包括:实现一个XML类,以帮助访问容器对象。
44.如权利要求42所述的方法,还包括:实现一个XML类,以帮助顺序搜索容器对象构成的该分层树。
45.如权利要求42所述的方法,还包括:将XML线程组织成多个文件类型,以促进对该项目的处理。
46.如权利要求45所述的方法,其中所述处理包括:更新被定义需求的一个跟踪和验证矩阵,该矩阵指明每个所述被定义需求是经验证或未获验证的,并且跟踪不一致性。
47.如权利要求41所述的方法,还包括:将XML线程转换为SQL格式,供经网络存储和访问。
48.一种以电子方式管理软件开发的需求的方法,包括:建立软件开发项目;基于从需求源捕获的需求信息定义项目的需求;对于每个需求,将为该需求开发的源代码一个或多个部分和该项目关联起来或者将该需求分配用于源代码的开发;将源代码中标明的过程映射到所述项目的被定义要求;并且根据一或多个验证规则基于一个或多个测试的结果验证该项目的被定义需求。
49.如权利要求48所述的方法,其中被定义需求的同级需求是通过将该同级需求和验证规则关联而创建。
50.如权利要求48所述的方法,其中被定义需求的同级需求是通过将该同级需求和用户关联而创建。
51.如权利要求48所述的方法,还包括:创建一个组;将验证规则的一个或多个和该组关联起来;并且将被定义需求的一个或多个和该组关联起来。
52.如权利要求51所述的方法,其中对于和该组关联的一个需求,为和该组关联的每个所述验证规则产生一个同级需求。
53.如权利要求48所述的方法,其中验证规则包括代码审查、质量审查、***测试、单元测试、子***测试和集成测试。
54.如权利要求48所述的方法,其中验证规则规定被分配给一个被定义需求的用户是否被要求执行该需求的验证,或被分配给所述被定义需求的用户以外的用户被要求执行验证。
55.如权利要求48所述的方法,其中项目的被定义需求包括基于需求信息的类型和格式解析需求信息。
56.如权利要求55所述的方法,其中需求信息的类型和格式由一个用户规定。
57.如权利要求55所述的方法,其中需求信息的类型和格式预先定义。
58.一种以电子方式管理软件开发的需求的***,包括:
项目模块,被配置为建立软件开发项目;
需求模块,被配置为基于从需求源捕获的需求信息定义项目的需求;
映射模块,将源代码的一个或多个部分和一个被定义需求关联起来;和,
验证模块,被配置为根据一或多个验证规则基于一个或多个测试的结果验证该项目的被定义需求。
59.如权利要求58所述的***,其中被定义需求的同级需求是通过将该同级需求和验证规则关联而创建。
60.如权利要求58所述的***,其中被定义需求的同级需求是通过将该同级需求和用户关联而创建。
61.如权利要求48所述的***,其中验证模块创建一个组;将所述验证规则的一个或多个和该组关联起来;并且将所述被定义需求的一个或多个和该组关联起来。
62.如权利要求61所述的***,其中对于和该组关联的一个需求,为和该组关联的每个所述验证规则产生一个同级需求。
63.如权利要求58所述的***,其中需求模块基于需求信息的类型和格式解析该需求信息。
64.如权利要求58所述的***,其中需求的类型和格式由一个用户规定。
65.如权利要求58所述的***,其中需求的类型和格式预先定义。
66.如权利要求58所述的***,还包括将一或多个测试用例分配给约束(circumscribe)期望功能的每个需求。
67.如权利要求48所述的***,其中被定义需求的同级需求是通过将该同级需求和确保与进程对象或质量评估一致的一个对象关联而创建的。
68.如权利要求67所述的***,其中进程对象或质量评估包括需求确认、计划或归档(documentation)。
69.如权利要求48所述的***,其中被定义需求的同级需求是通过将同级需求和被定义需求的一个故障项关联而创建的。
70.如权利要求58所述的***,其中被定义需求的同级需求是通过将该同级需求和确保与进程对象或质量评估一致的一个对象关联而创建的。
71.如权利要求70所述的***,其中所述进程对象或质量评估包括需求确认、计划或归档(documentation)。
72.如权利要求58所述的***,其中被定义需求的同级需求是通过将同级需求和被定义需求的一个故障项关联而创建的。
73.如权利要求58所述的***,其中被定义需求的同级需求是针对一个和该被定义需求关联的测试用例而创建的。
74.如权利要求48所述的方法,其中被定义需求的同级需求是针对一个和该被定义需求关联的测试用例而创建的。
75.如权利要求1所述的方法,其中额外需求包括和一个被定义需求相关联的测试用例。
76.一种以电子方式管理软件开发所用需求的***,包括:项目模块,被配置为建立软件开发项目;需求模块,被配置为基于从需求源捕获的需求信息定义项目的需求;建模模块,被配置用于包括构架性工件和执行工件;以及,验证模块,配置为根据一或多个验证规则基于一或多个测试的结果验证项目的被定义需求;其中需求模块将被定义需求和建模模块的相应构架性工件与执行工件链接起来。
77.如权利要求76的***,其中构架性工件和执行工件自动产生用于所述被链接的被定义需求的源代码。
78.如权利要求76的***,还包括一个映射模块,被配置用于将人工产生的源代码的一个或多个部分和被定义需求关联。
79.一种以电子方式管理软件开发的需求的方法,包括:建立软件开发项目;基于从需求源捕获的需求信息定义项目的需求;建立包括构架性工件和执行工件的建模模块;根据一个或多个验证规则,基于一个或多个测试的结果验证项目的被定义需求;其中被定义需求和相应的构架性工件与执行工件链接起来。
80.如权利要求79的方法,其中构架性工件和执行工件自动产生用于所述被链接的被定义需求的源代码。
81.如权利要求76的***,还包括一个映射模块,被配置用于将人工产生的源代码的一或多个部分和被定义需求关联。
CN200880017725.4A 2007-04-03 2008-04-03 软件需求验证的自动化管理 Pending CN101689111A (zh)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US90747407P 2007-04-03 2007-04-03
US60/907,474 2007-04-03
PCT/US2008/004349 WO2008124038A1 (en) 2007-04-03 2008-04-03 Automated management of software requirements verification

Publications (1)

Publication Number Publication Date
CN101689111A true CN101689111A (zh) 2010-03-31

Family

ID=39831255

Family Applications (1)

Application Number Title Priority Date Filing Date
CN200880017725.4A Pending CN101689111A (zh) 2007-04-03 2008-04-03 软件需求验证的自动化管理

Country Status (5)

Country Link
US (2) US8949770B2 (zh)
EP (1) EP2145252A4 (zh)
CN (1) CN101689111A (zh)
IL (1) IL201368A0 (zh)
WO (1) WO2008124038A1 (zh)

Cited By (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102486808A (zh) * 2010-12-03 2012-06-06 北京晶智意达科技有限公司 集成电路后端验证工具的一种集成方法
CN102662980A (zh) * 2012-01-13 2012-09-12 河北省电力勘测设计研究院 发电厂投标文件自动生成方法
CN102739470A (zh) * 2012-05-29 2012-10-17 百度在线网络技术(北京)有限公司 一种实现hadoop***测试的方法和装置
CN103246948A (zh) * 2012-02-14 2013-08-14 华为技术有限公司 需求管理的方法及装置
CN104461743A (zh) * 2014-12-17 2015-03-25 用友软件股份有限公司 资源和配置的自动生成装置和方法
CN106445824A (zh) * 2016-09-30 2017-02-22 南京途牛科技有限公司 一种基于角色的接口综合性管理***
CN106775704A (zh) * 2016-12-12 2017-05-31 广州视源电子科技股份有限公司 软件属性需求检验方法及装置
CN107025114A (zh) * 2017-04-17 2017-08-08 广州视源电子科技股份有限公司 一种软件需求信息匹配度检查方法和***
CN107368407A (zh) * 2016-05-11 2017-11-21 北京京东尚科信息技术有限公司 信息处理方法和装置
CN107908420A (zh) * 2017-11-16 2018-04-13 泰康保险集团股份有限公司 一种代码处理方法、装置及***
CN107992414A (zh) * 2017-11-28 2018-05-04 曲明成 一种基于测试用例获取进程模块间依赖关系的方法
US9971676B2 (en) 2012-08-30 2018-05-15 Toyota Motor Engineering & Manufacturing North America, Inc. Systems and methods for state based test case generation for software validation
CN108920362A (zh) * 2018-05-30 2018-11-30 邵阳学院 一种计算机软件的测试***
CN109582576A (zh) * 2018-11-28 2019-04-05 中国航空工业集团公司西安飞行自动控制研究所 一种民机飞控***需求追踪性的检查方法
CN110770658A (zh) * 2017-06-14 2020-02-07 西门子工业公司 楼宇自动化***中的故障检测和诊断规则的配置
CN110806977A (zh) * 2019-10-30 2020-02-18 泰康保险集团股份有限公司 基于产品需求的测试用例集生成方法、装置及电子设备
CN111190406A (zh) * 2019-12-25 2020-05-22 中国航空工业集团公司西安飞机设计研究所 一种起落架控制***软件的测试方法
CN111813697A (zh) * 2020-08-26 2020-10-23 四川新网银行股份有限公司 一种基于测试对象调用标记的测试覆盖率统计方法
CN112381370A (zh) * 2020-11-03 2021-02-19 中国直升机设计研究所 一种基于doors***的需求分配自动化方法
CN112631554A (zh) * 2020-12-30 2021-04-09 中国农业银行股份有限公司 一种项目需求管理方法、装置及设备
US11100009B2 (en) 2020-01-03 2021-08-24 Bank Of America Corporation Intelligent detection and ejection of unused application components
CN113886278A (zh) * 2021-12-08 2022-01-04 卡斯柯信号(北京)有限公司 一种需求属性自动导出和验证的方法和装置
CN114546845A (zh) * 2022-02-14 2022-05-27 重庆长安汽车股份有限公司 一种功能安全软件工具链的鉴定方法

Families Citing this family (124)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050137926A1 (en) * 2003-12-17 2005-06-23 International Business Machines Corporation Method and apparatus for dynamic device allocation for managing escalation of on-demand business processes
US8713524B2 (en) * 2005-04-06 2014-04-29 Microsoft Corporation Memory management configuration
US8510596B1 (en) 2006-02-09 2013-08-13 Virsec Systems, Inc. System and methods for run time detection and correction of memory corruption
US8196100B2 (en) * 2007-04-06 2012-06-05 International Business Machines Corporation Content management system for computer software with dynamic traceability between code and design documents
US8312415B2 (en) * 2007-04-17 2012-11-13 Microsoft Corporation Using code analysis for requirements management
CN101430643B (zh) * 2007-11-05 2012-06-27 国际商业机器公司 提供项目开发环境的方法和装置,以及项目开发***
US8627287B2 (en) * 2007-11-29 2014-01-07 Microsoft Corporation Prioritizing quality improvements to source code
US8176464B2 (en) * 2007-12-24 2012-05-08 Infosys Technologies Limited Method and framework for securing a source code base
US9495132B2 (en) * 2008-07-15 2016-11-15 Oracle International Corporation Release management systems and methods
EP2335155A1 (en) * 2008-10-09 2011-06-22 Siemens Aktiengesellschaft Method and apparatus for test coverage analysis
US8549491B2 (en) * 2008-12-05 2013-10-01 Electronics And Telecommunications Research Institute Apparatus and method for application testing of embedded system
US8359568B2 (en) * 2008-12-22 2013-01-22 International Business Machines Corporation Method and system for automatically adding generic change log to legacy application
US8612938B2 (en) * 2009-01-05 2013-12-17 Tata Consultancy Services Limited System and method for automatic generation of test data to satisfy modified condition decision coverage
US20110271253A1 (en) * 2010-04-28 2011-11-03 International Business Machines Corporation Enhancing functional tests coverage using traceability and static analysis
CN103038752B (zh) * 2010-05-19 2016-04-13 谷歌公司 一种用于管理软件问题报告的方法、***和设备
US8782626B2 (en) * 2010-06-30 2014-07-15 International Business Machines Corporation Search suggestions for static code analysis
US9122803B1 (en) * 2010-10-26 2015-09-01 Interactive TKO, Inc. Collaborative software defect detection
US20120246609A1 (en) 2011-03-24 2012-09-27 International Business Machines Corporation Automatic generation of user stories for software products via a product content space
US8438532B2 (en) 2011-04-19 2013-05-07 Sonatype, Inc. Method and system for scoring a software artifact for a user
US8935654B2 (en) * 2011-04-21 2015-01-13 Accenture Global Services Limited Analysis system for test artifact generation
US9348735B1 (en) * 2011-05-08 2016-05-24 Panaya Ltd. Selecting transactions based on similarity of profiles of users belonging to different organizations
US9134961B1 (en) * 2011-05-08 2015-09-15 Panaya Ltd. Selecting a test based on connections between clusters of configuration changes and clusters of test scenario runs
US9201772B1 (en) * 2011-05-08 2015-12-01 Panaya Ltd. Sharing test scenarios among organizations while protecting proprietary data
US9170809B1 (en) * 2011-05-08 2015-10-27 Panaya Ltd. Identifying transactions likely to be impacted by a configuration change
US9201773B1 (en) * 2011-05-08 2015-12-01 Panaya Ltd. Generating test scenario templates based on similarity of setup files
US9092579B1 (en) * 2011-05-08 2015-07-28 Panaya Ltd. Rating popularity of clusters of runs of test scenarios based on number of different organizations
US9069904B1 (en) * 2011-05-08 2015-06-30 Panaya Ltd. Ranking runs of test scenarios based on number of different organizations executing a transaction
US9170925B1 (en) * 2011-05-08 2015-10-27 Panaya Ltd. Generating test scenario templates from subsets of test steps utilized by different organizations
US9317404B1 (en) * 2011-05-08 2016-04-19 Panaya Ltd. Generating test scenario templates from test runs collected from different organizations
US9201774B1 (en) * 2011-05-08 2015-12-01 Panaya Ltd. Generating test scenario templates from testing data of different organizations utilizing similar ERP modules
US8612936B2 (en) 2011-06-02 2013-12-17 Sonatype, Inc. System and method for recommending software artifacts
US8639668B2 (en) 2011-07-05 2014-01-28 International Business Machines Corporation Structured requirements management
US8627270B2 (en) 2011-09-13 2014-01-07 Sonatype, Inc. Method and system for monitoring a software artifact
US8473894B2 (en) 2011-09-13 2013-06-25 Sonatype, Inc. Method and system for monitoring metadata related to software artifacts
US9141378B2 (en) 2011-09-15 2015-09-22 Sonatype, Inc. Method and system for evaluating a software artifact based on issue tracking and source control information
US8819638B2 (en) * 2011-09-20 2014-08-26 Alcatel Lucent Application protoyping suite
US8943470B2 (en) * 2011-09-23 2015-01-27 The Mathworks, Inc. Requirements framework
US20130080140A1 (en) * 2011-09-23 2013-03-28 The Mathworks, Inc. Using a requirements framework
US8799869B2 (en) * 2011-10-03 2014-08-05 Accenture Global Services Limited System for ensuring comprehensiveness of requirements testing of software applications
US8543444B2 (en) 2011-10-21 2013-09-24 NeighborBench LLC Method and system for assessing compliance risk of regulated institutions
US8776012B2 (en) * 2011-10-25 2014-07-08 International Business Machines Corporation Automatic scheduling of review meetings
US8656343B2 (en) * 2012-02-09 2014-02-18 Sonatype, Inc. System and method of providing real-time updates related to in-use artifacts in a software development environment
US8869096B2 (en) * 2012-02-14 2014-10-21 Huawei Technologies Co., Ltd. Requirement management method and apparatus
US8762946B2 (en) * 2012-03-20 2014-06-24 Massively Parallel Technologies, Inc. Method for automatic extraction of designs from standard source code
US9324126B2 (en) 2012-03-20 2016-04-26 Massively Parallel Technologies, Inc. Automated latency management and cross-communication exchange conversion
US9053442B2 (en) * 2012-05-08 2015-06-09 International Business Machines Corporation Multiple project areas in a development environment
US8825689B2 (en) 2012-05-21 2014-09-02 Sonatype, Inc. Method and system for matching unknown software component to known software component
US9323923B2 (en) * 2012-06-19 2016-04-26 Deja Vu Security, Llc Code repository intrusion detection
US9141408B2 (en) 2012-07-20 2015-09-22 Sonatype, Inc. Method and system for correcting portion of software application
US9208062B1 (en) 2012-08-14 2015-12-08 Amazon Technologies, Inc. Promotion determination based on aggregated code coverage metrics
US20140052757A1 (en) * 2012-08-17 2014-02-20 International Business Machines Corporation Techniques providing a software fitting assessment
US9639442B2 (en) * 2012-08-29 2017-05-02 Hcl Technologies Limited Modified condition/decision coverage test case automation
US9286187B2 (en) * 2012-08-30 2016-03-15 Sap Se Static enforcement of process-level security and compliance specifications for cloud-based systems
US10089463B1 (en) * 2012-09-25 2018-10-02 EMC IP Holding Company LLC Managing security of source code
US9396342B2 (en) 2013-01-15 2016-07-19 International Business Machines Corporation Role based authorization based on product content space
US9659053B2 (en) 2013-01-15 2017-05-23 International Business Machines Corporation Graphical user interface streamlining implementing a content space
US9087155B2 (en) 2013-01-15 2015-07-21 International Business Machines Corporation Automated data collection, computation and reporting of content space coverage metrics for software products
US9063809B2 (en) 2013-01-15 2015-06-23 International Business Machines Corporation Content space environment representation
US9111040B2 (en) 2013-01-15 2015-08-18 International Business Machines Corporation Integration of a software content space with test planning and test case generation
US9081645B2 (en) 2013-01-15 2015-07-14 International Business Machines Corporation Software product licensing based on a content space
US9141379B2 (en) * 2013-01-15 2015-09-22 International Business Machines Corporation Automated code coverage measurement and tracking per user story and requirement
US9075544B2 (en) 2013-01-15 2015-07-07 International Business Machines Corporation Integration and user story generation and requirements management
US9069647B2 (en) 2013-01-15 2015-06-30 International Business Machines Corporation Logging and profiling content space data and coverage metric self-reporting
US9218161B2 (en) 2013-01-15 2015-12-22 International Business Machines Corporation Embedding a software content space for run-time implementation
US9135263B2 (en) 2013-01-18 2015-09-15 Sonatype, Inc. Method and system that routes requests for electronic files
WO2015038944A1 (en) 2013-09-12 2015-03-19 Virsec Systems, Inc. Automated runtime detection of malware
JP6209985B2 (ja) * 2014-02-10 2017-10-11 富士通株式会社 製品設計支援プログラム、製品設計支援方法および製品設計支援装置
US9262134B2 (en) * 2014-03-21 2016-02-16 International Business Machines Corporation Analysis of source code changes
US10853536B1 (en) * 2014-12-11 2020-12-01 Imagars Llc Automatic requirement verification engine and analytics
WO2015179705A1 (en) * 2014-05-21 2015-11-26 Quantum Fuel Systems Technologies Worldwide, Inc. Enhanced compliance verification system
US10354074B2 (en) * 2014-06-24 2019-07-16 Virsec Systems, Inc. System and methods for automated detection of input and output validation and resource management vulnerability
US9851949B2 (en) * 2014-10-07 2017-12-26 Kevin D. Howard System and method for automatic software application creation
US20160104259A1 (en) * 2014-10-10 2016-04-14 CLAIRE Technologies Practitioner career management method and tool
CN104317711A (zh) * 2014-10-22 2015-01-28 牟永敏 一种基于路径的软件实现与设计一致性验证方法及***
CN104572833B (zh) * 2014-12-10 2019-01-29 中车青岛四方机车车辆股份有限公司 一种映射规则创建方法及装置
US9383976B1 (en) * 2015-01-15 2016-07-05 Xerox Corporation Methods and systems for crowdsourcing software development project
US9449292B1 (en) * 2015-01-16 2016-09-20 Amdocs Software Systems Limited System, method, and computer program for automatic high level testing project planning
CN104615540A (zh) * 2015-02-10 2015-05-13 上海创景计算机***有限公司 代码规范管理***
US11061705B2 (en) * 2015-03-16 2021-07-13 Bmc Software, Inc. Maintaining virtual machine templates
US10223654B2 (en) * 2015-03-23 2019-03-05 Accenture Global Services Limited Automated, accelerated prototype generation system
US9946785B2 (en) 2015-03-23 2018-04-17 International Business Machines Corporation Searching code based on learned programming construct patterns and NLP similarity
US9639450B2 (en) * 2015-06-17 2017-05-02 General Electric Company Scalable methods for analyzing formalized requirements and localizing errors
EP3113016A1 (en) 2015-06-29 2017-01-04 itemis AG Tracing dependencies between development artifacts in a development project
CN105487867B (zh) * 2015-11-26 2019-03-22 中国空间技术研究院 一种轻量级可视化卫星测试程序设计***及方法
US9811439B1 (en) * 2016-04-18 2017-11-07 Color Genomics, Inc. Functional testing of code modifications for read processing systems
US10853130B1 (en) 2015-12-02 2020-12-01 Color Genomics, Inc. Load balancing and conflict processing in workflow with task dependencies
US9747085B2 (en) * 2015-12-11 2017-08-29 Paypal, Inc. Source code generation from prototype source
US9990183B2 (en) * 2015-12-28 2018-06-05 Wipro Limited System and method for validating software development requirements
CN105677332A (zh) * 2015-12-30 2016-06-15 上海玖镕信息科技有限公司 软件开发需求管理***
CA3015032A1 (en) * 2016-02-18 2017-08-24 Blueprint Software Systems Inc. System and method for defining and generating requirement data from input records
US9990270B2 (en) * 2016-03-16 2018-06-05 Fair Isaac Corporation Systems and methods to improve decision management project testing
US9807101B1 (en) * 2016-04-29 2017-10-31 Oracle International Corporation Inferring security-sensitive entities in libraries
CA3027728A1 (en) 2016-06-16 2017-12-21 Virsec Systems, Inc. Systems and methods for remediating memory corruption in a computer application
US10409706B2 (en) * 2016-09-30 2019-09-10 Arizona Board Of Regents On Behalf Of Arizona State University Automated test generation for structural coverage for temporal logic falsification of cyber-physical systems
US10732965B2 (en) * 2016-10-13 2020-08-04 Tata Consultancy Services Limited Systems and methods for dynamic generation of questionnaires on programming concepts
US10338892B2 (en) * 2016-11-22 2019-07-02 Accenture Global Solutions Limited Dynamic provisioning of a set of tools based on project specifications
AU2018200523A1 (en) 2017-03-09 2018-09-27 Accenture Global Solutions Limited Smart advisory for distributed and composite testing teams based on production data and analytics
AU2018200643A1 (en) * 2017-03-09 2018-09-27 Accenture Global Solutions Limited Smart advisory for distributed and composite testing teams based on production data and analytics
US10466979B1 (en) 2017-06-01 2019-11-05 Nationwide Mutual Insurance Company Software requirements creating and tracking system and method
US10459694B2 (en) 2017-10-16 2019-10-29 Bank Of America Corporation Intelligent checking engine
US11561770B2 (en) * 2018-05-07 2023-01-24 Nec Corporation System configuration derivation device and system configuration derivation method
CN108958792A (zh) * 2018-07-03 2018-12-07 郑州云海信息技术有限公司 一种软件研发过程中产品需求管理方法与***
US11763321B2 (en) 2018-09-07 2023-09-19 Moore And Gasperecz Global, Inc. Systems and methods for extracting requirements from regulatory content
US10977156B2 (en) * 2018-10-10 2021-04-13 International Business Machines Corporation Linking source code with compliance requirements
US10977169B2 (en) * 2018-12-21 2021-04-13 Ncr Corporation Point of sale platform process crawler
US10860294B2 (en) * 2019-01-25 2020-12-08 Rockwell Collins, Inc. Requirements tracing precision validation tool
US11138366B2 (en) * 2019-02-25 2021-10-05 Allstate Insurance Company Systems and methods for automated code validation
US11093365B2 (en) 2019-07-15 2021-08-17 Bank Of America Corporation System for splicing and formatting code via machine learning
US11029948B1 (en) * 2019-12-05 2021-06-08 Bank Of America Corporation System for normalizing data dependency effects across an electronic network environment
CN114327372B (zh) * 2020-09-29 2024-05-31 腾讯科技(深圳)有限公司 一种质量需求配置方法、装置、设备和介质
US11314922B1 (en) * 2020-11-27 2022-04-26 Moore & Gasperecz Global Inc. System and method for generating regulatory content requirement descriptions
CN112817843B (zh) * 2021-01-25 2024-05-17 上海哔哩哔哩科技有限公司 项目管理方法和***
US11455161B2 (en) * 2021-02-01 2022-09-27 Accenture Global Solutions Limited Utilizing machine learning models for automated software code modification
US11785015B2 (en) 2021-02-24 2023-10-10 Bank Of America Corporation Information security system for detecting unauthorized access requests
US20220308988A1 (en) * 2021-03-25 2022-09-29 International Business Machines Corporation Generating project requirements using test scripts
US20220342663A1 (en) * 2021-04-22 2022-10-27 Nadav Barkaee Systems and method for analyzing software and testing integration
CN113485913B (zh) * 2021-06-10 2023-04-07 上海百胜软件股份有限公司 一种分支管理方法、***、设备和存储介质
CN113791757B (zh) * 2021-07-14 2023-08-22 北京邮电大学 软件需求和代码映射方法及***
US11977858B2 (en) 2022-02-07 2024-05-07 T-Mobile Usa, Inc. Centralized intake and capacity assessment platform for project processes, such as with product development in telecommunications
CN115049211A (zh) * 2022-05-12 2022-09-13 中国电子科技集团公司第十五研究所 一种电子元器件通用质量特性验证方法及装置
CN114840430A (zh) * 2022-05-17 2022-08-02 重庆长安汽车股份有限公司 自动化汽车软件测试***及测试方法
CN114896824B (zh) * 2022-07-12 2022-10-11 南昌航空大学 联合仿真集成测试验证方法、装置、可读存储介质及设备
US11823477B1 (en) 2022-08-30 2023-11-21 Moore And Gasperecz Global, Inc. Method and system for extracting data from tables within regulatory content
US11823133B1 (en) * 2023-04-28 2023-11-21 Citibank, N.A. Core decision engine for managing software development lifecycles

Family Cites Families (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5892947A (en) * 1996-07-01 1999-04-06 Sun Microsystems, Inc. Test support tool system and method
US6226784B1 (en) * 1998-10-14 2001-05-01 Mci Communications Corporation Reliable and repeatable process for specifying developing distributing and monitoring a software system in a dynamic environment
US6332211B1 (en) * 1998-12-28 2001-12-18 International Business Machines Corporation System and method for developing test cases using a test object library
US7000187B2 (en) * 1999-07-01 2006-02-14 Cisco Technology, Inc. Method and apparatus for software technical support and training
US8104017B2 (en) * 2001-10-25 2012-01-24 The Mathworks, Inc. Traceability in a modeling environment
US7228524B2 (en) * 2002-12-20 2007-06-05 The Boeing Company Method and system for analysis of software requirements
US8225302B2 (en) * 2003-02-13 2012-07-17 Lawrence Taylor Waugh System and method for managing source code and acquiring metrics in software development
EP1665034B1 (en) * 2003-08-13 2017-03-22 National Instruments Corporation Creating a graphical user interface for selected parameters of a graphical program
US7689970B1 (en) * 2003-10-31 2010-03-30 The Mathworks, Inc. System and method for generating source code from a graphical model
US7490319B2 (en) * 2003-11-04 2009-02-10 Kimberly-Clark Worldwide, Inc. Testing tool comprising an automated multidimensional traceability matrix for implementing and validating complex software systems
US7949738B2 (en) * 2004-02-12 2011-05-24 Sap Aktiengesellschaft Graphical interface for generating and previewing a rule
US7810070B2 (en) * 2004-03-29 2010-10-05 Sas Institute Inc. System and method for software testing
US7640532B2 (en) * 2004-08-25 2009-12-29 International Business Machines Corporation Mapping software code to business logic
US7680632B1 (en) * 2005-03-31 2010-03-16 The Mathworks, Inc. Test precondition items for automated analysis and test generation
US7958454B2 (en) * 2005-04-19 2011-06-07 The Mathworks, Inc. Graphical state machine based programming for a graphical user interface
KR100711264B1 (ko) * 2005-05-03 2007-04-25 삼성전자주식회사 전자기기 및 그 제어방법
US7752606B2 (en) * 2005-08-10 2010-07-06 Capital One Financial Corporation Software development tool using a structured format to generate software code
US7853882B2 (en) * 2006-04-11 2010-12-14 International Business Machines Corporation Portlets having different portlet specific enablement states
US7729894B1 (en) * 2006-05-12 2010-06-01 The Mathworks, Inc. Test postcondition items for automated analysis and test generation
US8332827B2 (en) * 2006-12-01 2012-12-11 Murex S.A.S. Produce graph oriented programming framework with scenario support
US8015509B2 (en) * 2007-11-14 2011-09-06 International Business Machines Corporation Selectively locking GUI controls to prevent accidental operations in a computing environment

Cited By (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102486808A (zh) * 2010-12-03 2012-06-06 北京晶智意达科技有限公司 集成电路后端验证工具的一种集成方法
CN102662980B (zh) * 2012-01-13 2014-02-26 河北省电力勘测设计研究院 发电厂投标文件自动生成方法
CN102662980A (zh) * 2012-01-13 2012-09-12 河北省电力勘测设计研究院 发电厂投标文件自动生成方法
CN103246948B (zh) * 2012-02-14 2016-08-10 华为技术有限公司 需求管理的方法及装置
CN103246948A (zh) * 2012-02-14 2013-08-14 华为技术有限公司 需求管理的方法及装置
CN102739470A (zh) * 2012-05-29 2012-10-17 百度在线网络技术(北京)有限公司 一种实现hadoop***测试的方法和装置
US9971676B2 (en) 2012-08-30 2018-05-15 Toyota Motor Engineering & Manufacturing North America, Inc. Systems and methods for state based test case generation for software validation
CN104461743A (zh) * 2014-12-17 2015-03-25 用友软件股份有限公司 资源和配置的自动生成装置和方法
CN104461743B (zh) * 2014-12-17 2018-10-16 用友网络科技股份有限公司 资源和配置的自动生成装置和方法
CN107368407B (zh) * 2016-05-11 2021-05-25 北京京东尚科信息技术有限公司 信息处理方法和装置
CN107368407A (zh) * 2016-05-11 2017-11-21 北京京东尚科信息技术有限公司 信息处理方法和装置
CN106445824A (zh) * 2016-09-30 2017-02-22 南京途牛科技有限公司 一种基于角色的接口综合性管理***
CN106445824B (zh) * 2016-09-30 2019-06-25 南京途牛科技有限公司 一种基于角色的接口综合性管理***
CN106775704A (zh) * 2016-12-12 2017-05-31 广州视源电子科技股份有限公司 软件属性需求检验方法及装置
CN107025114A (zh) * 2017-04-17 2017-08-08 广州视源电子科技股份有限公司 一种软件需求信息匹配度检查方法和***
CN110770658A (zh) * 2017-06-14 2020-02-07 西门子工业公司 楼宇自动化***中的故障检测和诊断规则的配置
CN110770658B (zh) * 2017-06-14 2023-03-21 西门子工业公司 楼宇自动化***中的故障检测和诊断规则的配置
CN107908420A (zh) * 2017-11-16 2018-04-13 泰康保险集团股份有限公司 一种代码处理方法、装置及***
CN107992414A (zh) * 2017-11-28 2018-05-04 曲明成 一种基于测试用例获取进程模块间依赖关系的方法
CN108920362A (zh) * 2018-05-30 2018-11-30 邵阳学院 一种计算机软件的测试***
CN109582576A (zh) * 2018-11-28 2019-04-05 中国航空工业集团公司西安飞行自动控制研究所 一种民机飞控***需求追踪性的检查方法
CN110806977A (zh) * 2019-10-30 2020-02-18 泰康保险集团股份有限公司 基于产品需求的测试用例集生成方法、装置及电子设备
CN111190406A (zh) * 2019-12-25 2020-05-22 中国航空工业集团公司西安飞机设计研究所 一种起落架控制***软件的测试方法
US11100009B2 (en) 2020-01-03 2021-08-24 Bank Of America Corporation Intelligent detection and ejection of unused application components
CN111813697B (zh) * 2020-08-26 2021-07-16 四川新网银行股份有限公司 一种基于测试对象调用标记的测试覆盖率统计方法
CN111813697A (zh) * 2020-08-26 2020-10-23 四川新网银行股份有限公司 一种基于测试对象调用标记的测试覆盖率统计方法
CN112381370A (zh) * 2020-11-03 2021-02-19 中国直升机设计研究所 一种基于doors***的需求分配自动化方法
CN112631554A (zh) * 2020-12-30 2021-04-09 中国农业银行股份有限公司 一种项目需求管理方法、装置及设备
CN112631554B (zh) * 2020-12-30 2024-07-23 中国农业银行股份有限公司 一种项目需求管理方法、装置及设备
CN113886278A (zh) * 2021-12-08 2022-01-04 卡斯柯信号(北京)有限公司 一种需求属性自动导出和验证的方法和装置
CN114546845A (zh) * 2022-02-14 2022-05-27 重庆长安汽车股份有限公司 一种功能安全软件工具链的鉴定方法
CN114546845B (zh) * 2022-02-14 2024-05-24 重庆长安汽车股份有限公司 一种功能安全软件工具链的鉴定方法

Also Published As

Publication number Publication date
US20150095890A1 (en) 2015-04-02
WO2008124038A1 (en) 2008-10-16
EP2145252A4 (en) 2011-12-21
WO2008124038A8 (en) 2008-12-31
EP2145252A1 (en) 2010-01-20
US8949770B2 (en) 2015-02-03
US20080263505A1 (en) 2008-10-23
IL201368A0 (en) 2010-05-31

Similar Documents

Publication Publication Date Title
CN101689111A (zh) 软件需求验证的自动化管理
Anquetil et al. A model-driven traceability framework for software product lines
WO2011031328A2 (en) Systems and methods for management of projects for development of embedded systems
Bashir et al. Testing object-oriented software: life cycle Solutions
JP2008171391A (ja) 組み込みシステムのための要求記述を生成する方法
WO2007124057A2 (en) Computer program generating
Rocha Silva et al. Ensuring the consistency between user requirements and task models: A behavior-based automated approach
Elaasar et al. VPML: an approach to detect design patterns of MOF-based modeling languages
Mäder et al. Ready-to-use traceability on evolving projects
Cagnin et al. PARFAIT: Towards a framework-based agile reengineering process
Zaheri et al. Towards checking consistency-breaking updates between models and generated artifacts
Roldán et al. Operation‐based approach for documenting software architecture knowledge
Falchi IT tools for the management of multi—Representation geographical information
Woestenenk et al. Capturing design process information in complex product development
Malavolta Software Architecture Modeling by Reuse, Composition and Customization
Kundu Software Engineering: A Systematic Approach
Priggouris et al. The system design life cycle
Caffiau et al. Generating interactive applications from task models: A hard challenge
Paz et al. Supporting consistency in the heterogeneous design of safety-critical software
Schwarz Universal Traceability. A Comprehensive, Generic, Technology-Independent, and Semantically Rich Approach
Busch An Architecture-based Approach for Change Impact Analysis of Software-intensive Systems
Haidrar et al. On the use of model transformation for requirements trace models generation
Paukkunen Development of metrics and automation for product model verification
Popoola Change Analysis Across Version Histories of Systems Models
Desai Reusable Monterey Phoenix Code Libraries for Behavior Models and Model Segments

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C41 Transfer of patent application or patent right or utility model
TA01 Transfer of patent application right

Effective date of registration: 20110907

Address after: Atlanta USA

Applicant after: LDRA Technology Inc.

Address before: The Wirral

Applicant before: LDRA Technology Inc.

C02 Deemed withdrawal of patent application after publication (patent law 2001)
WD01 Invention patent application deemed withdrawn after publication

Application publication date: 20100331