用于合成测试数据流的状态事件的系统、方法和设备技术方案

技术编号:2836448 阅读:238 留言:0更新日期:2012-04-11 18:40
本发明专利技术提供了用于合成测试数据流的状态事件的系统、方法和设备。在 一个实施例中,一种方法包括如下步骤:A)访问测试数据流,该测试数 据流包括1)多个状态事件和2)其间散布着所述多个状态事件的多个数 据事件;B)当访问一个数据事件时,确定该数据事件是否与当前测试状 态相一致;C)如果不一致,则1)缓存多个附加数据事件,并且2)如果 所述多个附加数据事件隐含在访问数据事件之前状态事件应当已被接收并 且状态改变应当已发生,则i)遵照所隐含的状态改变,合成并发布应当 已被接收的状态事件,ii)更新当前测试状态,iii)然后,发布数据事件。

【技术实现步骤摘要】

本专利技术涉及用于合成测试数据流的状态事件的系统、方法和设备
技术介绍
测试数据,例如由对多个被测试器件(DUT)执行测试的测试器所产生的测试数据,报告个体数据事件和将所述数据事件放入适当的上下文中的状态事件。现在的测试器和数据处理设备被证实具有高可靠性,然而,仍然会出现导致测试数据包含错误的问题。
技术实现思路
在一个实施方式中,一种方法,包括A)访问测试数据流,所述测试数据包括1)更新当前测试状态的多个状态事件和2)其间散布着所述多个状态事件中的一些状态事件的多个数据事件;B)当访问所述多个数据事件中的一个数据事件时,确定所述数据事件是否与所述当前测试状态一致;C)如果所述数据事件与所述当前测试状态一致,则发布所述数据事件;并且D)如果所述数据事件与所述当前测试状态不一致,则1)缓存多个附加数据事件;并且2)如果所述多个附加数据事件隐含在访问所述数据事件之前状态事件应当已被接收并且状态改变应当已发生,则i)遵照所述被隐含的状态改变,合成并发布所述应当被接收的状态事件;ii)根据所述被隐含的状态改变更新所述当前测试状态;并且iii)然后,发布所述数据事件。在另一个实施方式中,一种用于合成测试数据流的状态事件的系统,包括A)可操作用于访问测试数据流的接口,所述测试数据包括1)更新当前测试状态的多个状态事件和2)其间散布着所述多个状态事件中的一些状态事件的多个数据事件;B)数据存储器;和C)与所述接口和数据存储器通信的处理器,其可操作用于,1)当访问所述多个数据事件中的一个数据事件时,确定所述数据事件是否与所述当前测试状态一致;2)如果所述数据事件与所述当前测试状态一致,则发布所述数据事件;并且3)如果所述数据事件与所述当前测试状态不一致,则i)使所述数据存储装置缓存多个附加数据事件;并且ii)如果所述多个附加数据事件隐含在访问所述数据事件之前状态事件应当已被接收并且状态改变应当已发生,则a)遵照所述被隐含的状态改变,合成并发布所述应当被接收的状态事件;b)根据所述被隐含的状态改变更新所述当前测试状态;并且c)然后,发布所述数据事件。在另一个实施方式中,一个或多个在其上存储有指令序列的机器可读介质,当机器执行所述指令序列时能够使机器执行下列操作A)访问测试数据流,所述测试数据包括1)更新当前测试状态的多个状态事件和2)其间散布着所述多个状态事件中的一些状态事件的多个数据事件;B)当访问所述多个数据事件中的一个数据事件时,确定所述数据事件是否与所述当前测试状态一致;C)如果所述数据事件与所述当前测试状态一致,则发布所述数据事件;并且D)如果所述数据事件与所述当前测试状态不一致,则1)缓存多个附加数据事件;并且2)如果所述多个附加数据事件隐含在访问所述数据事件之前状态事件应当已被接收并且状态改变应当已发生,则i)遵照所述被隐含的状态改变,合成并发布所述应当被接收的状态事件;ii)根据所述被隐含的状态改变更新所述当前测试状态;并且iii)然后,发布所述数据事件。其它实施方式也被公开。附图说明附图中示出了本专利技术的示例性实施例,其中图1示出了用于合成测试数据流的状态事件的第一示例流程图;图2示出了用于合成测试数据流的状态事件的第二示例流程图;以及图3示出了一种可操作用于执行图1和图2所示的步骤的系统。具体实施例方式测试器是用于对多个被测试的器件(DTUs)执行测试的高可靠性的设备,但是复杂的测试环境仍然会使测试器所产生的测试结果包含错误。例如测试数据流中被误放的数据事件。测试器产生包含状态事件和数据事件本身的测试数据流,所述状态事件例如用于给后续数据事件提供上下文。数据事件提供测试结果自身(例如,”pin14=3.2v”,”continuity=false”)并且可以是单个数据元素或复杂的数据结构。如果状态事件提供了给定的上下文而后续测试数据并不属于该上下文,则导致错误。当状态事件本应被接收并从而触发对于当前测试状态的更新,但是该状态事件并不存在于测试数据中时,将会发生另一潜在错误。在不调整测试数据的情况下,如果数据事件在不合适的位置被测试数据的使用者(例如格式化者,分析者,报告者)所接收,例如当1)与不正确的状态事件相关联的数据事件被接收,或者2)没有任何相关联的状态事件的数据事件被接收时,则后面的测试数据将被认为是错误和不可用的。不可用的测试数据的量可能是后面的直至测试器被重启为止的所有测试数据,并且可能会出现在若干小时甚至若干天的测试中。通过分析数据事件,测试数据可以被调整以修复多个错误数据事件以增加测试数据的利用。如果大部分测试数据丢失,则数据事件仍然可能被舍弃,但是更可能的情况是在将状态事件插入测试数据中的适当位置时的小“故障(glitch)”。那些与不正确的状态事件相关联的数据事件可以具有被合成并且在适当位置插入到测试数据中的合适的状态事件。因此,测试数据的使用者可以看到他们想要的测试数据。图1示出了用于合成测试数据流的状态事件的第一示例流程图100。步骤102访问测试数据。步骤104确定该测试数据是否是数据事件,如果是,则进行步骤106,或者如果该测试数据不是数据事件(例如,状态事件),则流程图100结束。步骤106确定数据事件是否与当前测试状态相一致,如果是,则进行步骤108,如果不是,则进行步骤110。一旦从步骤106到达步骤108,步骤108发布与当前测试状态一致的数据事件。在步骤108发布数据事件之后,流程图100结束。步骤110缓存附加数据事件,然后步骤112确定附加数据事件是否隐含状态事件丢失并且状态改变应当已发生,如果是,则进行步骤114,如果不是,则流程图100结束。步骤114合成状态事件。步骤116发布状态事件。步骤118根据所隐含的状态事件更新当前测试状态,并且步骤108发布包括数据事件和在步骤110中被缓存的附加数据事件在内的数据事件。步骤110缓存附加数据事件。在一个实施例中,固定数目的数据事件被缓存,该固定数目与设计的选择有关。在另一实施例中,在状态事件之前的全部数据事件都被缓存。在又一实施例中,步骤110和步骤112被反复执行,其中一个附加数据事件被缓存并且被估计,以确定在给定的可靠度级别内能否得出一个关于状态事件是否丢失的结论。如果达不到该可靠度级别,则第二个附加数据事件被缓存。该循环一直重复到确定了足够的可靠度级别或者确定该可靠度级别肯定能够达到为止。在后面的情况中,数据事件可以被认为是不隐含状态事件丢失并且处理结束。在一个实施例中,如图所示,用于发布状态事件的步骤116在用于更新当前测试状态的步骤118之前。在另一实施例中,步骤116和118被颠倒。流程图100可以被重复,例如直至没有未访问的测试数据为止。图2示出了用于合成测试数据流的状态事件的第二示例流程图200。步骤202访问测试数据。步骤204确定该测试数据是否是数据事件,如果是,则执行步骤210,如果不是,则该测试数据是状态事件并执行步骤206。步骤206更新当前测试状态,然后步骤208发布状态事件。在另一个实施方式中,步骤206和208被颠倒。步骤210确定当前测试状态是否已知。如果当前测试状态未知,即当数据事件在当前测试状态的初始设置之前被接收时,则执行步骤222。如果状态已知,则执行步骤2本文档来自技高网...

【技术保护点】
一种方法,包括:访问测试数据流,所述测试数据包括1)更新当前测试状态的多个状态事件和2)其间散布着所述多个状态事件中的一些状态事件的多个数据事件;当访问所述多个数据事件中的一个数据事件时,确定所述数据事件是否与所述当前测试状态一致;如果所述数据事件与所述当前测试状态一致,则发布所述数据事件;并且如果所述数据事件与所述当前测试状态不一致,则缓存多个附加数据事件;并且如果所述多个附加数据事件隐含在访问所述数据事件之前状态事件应当已被接收并且状态改变应当已发生,则(A)遵照所述被隐含的状态改变,合成并发布所述应当已被接收的状态事件;(B)根据所述被隐含的状态改变更新所述当前测试状态;并且(C)随后,发布所述数据事件。

【技术特征摘要】
2006.4.7 US 11/399,7301.一种方法,包括访问测试数据流,所述测试数据包括1)更新当前测试状态的多个状态事件和2)其间散布着所述多个状态事件中的一些状态事件的多个数据事件;当访问所述多个数据事件中的一个数据事件时,确定所述数据事件是否与所述当前测试状态一致;如果所述数据事件与所述当前测试状态一致,则发布所述数据事件;并且如果所述数据事件与所述当前测试状态不一致,则缓存多个附加数据事件;并且如果所述多个附加数据事件隐含在访问所述数据事件之前状态事件应当已被接收并且状态改变应当已发生,则(A)遵照所述被隐含的状态改变,合成并发布所述应当已被接收的状态事件;(B)根据所述被隐含的状态改变更新所述当前测试状态;并且(C)随后,发布所述数据事件。2.如权利要求1所述的方法,还包括,如果所述多个附加数据事件未隐含状态事件应当已被接收并且状态改变应当已发生,则清除所述数据事件。3.如权利要求1所述的方法,还包括当访问所述多个状态事件中的一个状态事件时,根据所述状态事件更新所述当前测试状态;并且发布所述状态事件。4.如权利要求1所述的方法,其中发布所述数据事件还包括使所述数据事件对于所述测试数据的使用者是可用的。5.如权利要求1所述的方法,其中所述数据事件在所述当前测试的初始更新之前被访问,所述方法还包括确定所述数据事件是否指示状态;并且如果所述数据事件指示所述状态,则合成与所述被指示的状态相对应的状态事件;根据所述被指示的状态更新所述当前测试状态;并且随后,发布所述被合成的状态事件并发布所述数据事件。6.如权利要求1所述的方法,其中访问所述测试数据还包括接收所述测试数据。7.如权利要求1所述的方法,其中确定所述多个附加数据事件是否隐含状态改变还包含确定所述附加数据事件是否包含属性,其中所述属性与不同于所述当前测试状态的测试状态相一致。8.一种用于合成测试数据流的状态事件的系统,包括,可操作用于访问测试数据流的接口,所述测试数据包括1)更新当前测试状态的多个状态事件和2)其间散布着所述多个状态事件中的一些状态事件的多个数据事件;数据存储器;和与所述接口和数据存储器通信的处理器,其可操作用于,当访问所述多个数据事件中的一个数据事件时,确定所述数据事件是否与所述当前测试状态一致;如果所述数据事件与所述当前测试状态一致,则发布所述数据事件;并且如果所述数据事件与所述当前测试状态不一致,则(A)使所述数据存储装置缓存多个附加数据事件;并且(B)如果所述多个附加数据事件隐含在访问所述数据事件之前状态事件应当已被接收并且状态改变应当已发生,则(I)遵照所述被隐含的状态改变,合成并发布所述应当被接收的状态事件;(II)根据所述被隐含的状态改变更新所述当前测试状态;并且(III)随后,发布所述数据事件。9.如权利要求8所述的系统,其中所述处理器还可操作用来执行下列操作,如果所述多个附加数据事件未隐含状态事件应当已被接收并且状态改变应当已发生,则清除所述数据事件。10.如权利要求8所述的系统,其中所述处理器还可操作用来执行下列操作,当访问所述多个状态事件中的一个状态事件时,A)根据所述状态事件更新所述当前测试状态;并且B)发布所述状态事件。11.如权利要求8所...

【专利技术属性】
技术研发人员:瑞德·F·哈郝罗伯特·S·库尔曼
申请(专利权)人:韦瑞吉新加坡私人有限公司
类型:发明
国别省市:SG

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1