Webelement.Object.<method> 提供原始结果还是克隆?

Does Webelement.Object.<method> provide the original result, or a clone?

TDLR: 核心问题是:

对于 IE,Web 测试对象的 .Object 方法和所有 "sub-methods" 是否直接提供对原始 DOM 对象的访问,而 Chrome 和FireFox、UFT 不是 return 原始 DOM 对象实例,而是克隆、副本或其他一些代表性实例?

详情: 与 IE 一起工作的播放步骤,根据文档应该与所有支持的浏览器一起工作,没有充分理由与 Chrome 和 Firefox 一起失败。

分析表明这是由 UFT 中的意外行为或错误引起的。

所以我笼统地描述了这个问题。 (抱歉,还没有 SSCE。)

特别是:

如果我在测试对象的 UFT 级别上使用 T T.Object.parentNode 来引用父元素,然后在那里调用 .childNodes 以确定父元素的直接子元素,则适用以下内容:

预计: childNodes 提供的列表在其他可能的实例中还包含实例 T.Object.

实际: 仅当 IE 是 DOM 所在的浏览器时,childNodes 提供的列表才包含(在其他可能的子项中)T.Object。 如果使用 Chrome 或 Firefox,则 T.Object.parentNode.childNodes 提供的列表包含一个元素,该元素表示与 T.Object.parentNode 完全相同的 DOM 元素,但它不是同一对象实例,即 UFT VBScript 表达式 "E is T.Object.parentNode" 计算结果为 true 的子节点提供的列表中没有对象实例 E。

在JavaScript层可以证明假设"A.parentNode.childNodes returns a list containing the object instance A"总是满足(其中A是具有子元素的任何元素(根除外))。 但是,在 UFT 级别上,可以理解该假设仅适用于 IE,而不适用于 Chrome 或 Firefox。

但是 UFT 的文档声称可以通过 .object 直接访问本机 DOM 对象,由此我们得出结论,调用和 return 此类 DOM 方法的值对象必须直接通过。

相反,对于 Chrome 和 Firefox UFT 似乎有一种机制,例如,列表(如 childNodes 提供的 NodeList)不会作为函数结果原样传递,但列表元素被克隆,或类似的东西,所以它不是提供的本机实例,而只是 copies/representatives/clones.

这是真的吗?然后我认为这是一个错误,无论是在文档中,还是在 UFT 的 Chrome 和 Firefox 支持中。 有解决方法吗?

出于各种原因,我刚刚开始将 Chrome 和 Firefox 作为目标浏览器,并且由于上述情况,使用的中央通用代码中断,这对我来说非常意外,我不知道任何通用的解决方法,所以我必须为每个受影响的用途开发一个特定于案例的单独解决方法,其中我有数百个。

有什么建议吗?

的确,在 IE 中,UFT 通过 .Object 属性 公开了 IE 使用的实际 COM 对象。同样,对于所有其他浏览器(Firefox、Chrome、Edge、Mobile),UFT 创建一个包装器对象,将调用转发到浏览器的本机 DOM 元素(因为这些浏览器不公开其 DOM 作为 COM 对象)。

如果我对你的问题的理解正确,你依赖于 COM 的 object identity 规则。在以前的(专业)生活中,我曾为 UFT 开发 COM 包装器,但我不记得我们曾将其视为用例。您可能会为 UFT 打开一个缺陷,我不确定修复此问题的可行性如何,他们更有可能会说这是一个限制并更新文档。

如果您想检查 .Object 对象是否引用相同的底层 DOM 元素,我建议您自己设置一些 属性,例如:

counter = 0
Function UniqueValue(obj)
    If TypeName(obj.unique_value) = "Empty" Then
        obj.unique_value = "unique_value_" & counter
        counter = counter + 1
    End If
End Function

' After this The element will have "unique_value_0" and the link "unique_value_1"
UniqueValue Browser("Example Domain").Page("Example Domain").WebElement("Example Domain").Object
UniqueValue Browser("Example Domain").Page("Example Domain").WebElement("Example Domain").Object

UniqueValue Browser("Example Domain").Page("Example Domain").Link("More information...").Object