温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

TestComplete中执行脚本时控件值未同步刷新问题

发布时间:2020-05-30 22:59:39 来源:网络 阅读:2713 作者:孤月2012 栏目:软件技术

今天写了一个程序安装的自动化脚本,调试的时候发现有些控件的值获取后一直未自动刷新,鉴于该问题,仔细分析和请教后,发现TestComplete不会自动刷新控件中变化的值,这需要我们自己去控制刷新。

1、定义一个延迟函数(参数:延迟秒数,执行延迟的条件)

Function TimeDelay(DelaySeconds,condition)
    Dim interval,startTime
    startTime=Time
    Do While CBool(condition)
        sleep(DelaySeconds*1000)
        interval=Second(Time - startTime)
        If interval =40 Then
            Log.Error("Time Out.")
            Exit Do
        End If   
    Loop
End Function

 

2、Namemapping 一个显示进度的控件(控件的value:0%-100%):

Set InstallProgress = Aliases.SQLNav.frmSQLNavWizard.panelMain.panelFrameHolder.SelectProduct.pnlNewProducts.pnlRightInstallProgress.labelInstallProgress

 

3、在脚本中调用函数:

Call TimeDelay(2,InstallProgress.Caption<>"100%")

发现会一直延迟,直到超过指定间隔Time Out,原因就是最上面分析的,控件InstallProgress.Caption的值没有动态刷新,获取的是调用时的值,后面一直未改变。

 

4、修改脚本:

对于具有动态值的控件,使用上面的延迟函数显然不合适,对于具有动态值的控件下的延迟处理,可单独写一段脚本处理,使用TestComplete自带的方法RefreshMappingInfo()只刷新该控件 :

    Dim beginTime
    beginTime = time
    Do While InstallProgress.Caption<>"100%"
        sleep(2000)
        InstallProgress.RefreshMappingInfo 
        If Second(time - beginTime) =40 Then
            Log.Error("Time Out.")
            Exit Do
        End If   
    Loop

或者是在函数中加入sys.refresh()刷新整个程序,不过不建议使用这种,整个刷新很耗性能的。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI