溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

自動化測試框架:擁抱Ruby

發(fā)布時間:2020-04-03 14:00:43 來源:網(wǎng)絡(luò) 閱讀:332 作者:xiammy 欄目:編程語言

目前,自動化測試框架已經(jīng)基本成型。朋友們的一些建議,還在陸續(xù)消化中,在不久的將來或許都會加入到其中,謝謝大家的鼓勵和支持。

最近,在一次技術(shù)交流會中,我的一位同事向我提起QTP(QuickTest Pro),肯定了它的描述性編程和我們框架中的設(shè)計有類似之處,并指出QTP的可擴展性比較強,比如流程控制(IF、LOOP、SWITCH等)。特別是裝載數(shù)據(jù)批量操作軟件方面比較強。我深以為然。

因此,我開始和我的另一位同事小賈琢磨。我們有兩種選擇,一是在腳本編輯中擴展有關(guān)流程的節(jié)點(這點很像FinalBuilder),還有就是支持腳本語言。我們選擇了后者,因為第一種雖然可以擴展,但最終畢竟還是不靈活。

在對編程語法方面,一開始考慮的是PascalScript,因為我們都是使用的Delphi。但是考慮到測試人員并不是熟悉Delphi的,況且,對于腳本化編程,我最先想到的是Ruby,而不是Delphi。因此我做了一個大膽的假設(shè),如果在我們引擎中,加入對Ruby的支持,應(yīng)該怎么做呢?

首先是引擎調(diào)用Ruby腳本。我查找了一下資料。發(fā)現(xiàn)Delphi下有現(xiàn)成的開源控件,而且Ruby其實已經(jīng)公布了API了。因此這不是問題了。

那么下面就是最重要的問題了,Ruby腳本如何調(diào)用引擎去控制控件?我將所有針對引擎的操作,都歸結(jié)于控件的操作,這簡化了依賴性。但是關(guān)鍵的問題還是在于技術(shù)上如何實現(xiàn)調(diào)用。

必須承認,我對Ruby的了解很少,這方面小賈是專家。在和小賈討論過程中,發(fā)現(xiàn)Delphi寫Ruby的擴展沒有明確的幫助,倒是有C的實現(xiàn)方式。我相信研究一下C的實現(xiàn)方式,應(yīng)該可以找到Delphi的實現(xiàn)方式。

但在這個時候,我們忽然提到了Http。這讓我想起了引擎中已經(jīng)存在的一個Http的Server。因此我提出直接通過Http調(diào)用引擎。這樣就跨越了語言的障礙。我們顯然是抓住了RPC的精髓。這個方案一下子得到了小賈的支持。

并且我還想到另外一個理由:先實現(xiàn)了再說(Do it First)。這點小賈更是同意。

在這個基礎(chǔ)上,小賈更是提出了利用Ruby定義DSL的方式,來進行編程。對于Ruby定義DSL我也是不怎么了解。在簡單研究過范例之后,發(fā)現(xiàn)有一定的可行性,但是難度也確實不小。

下面是我和小賈討論的一些內(nèi)容,也能初步看出其中的難度。

有關(guān)DSL,還真麻煩。我考慮這樣的情況:DSL可以轉(zhuǎn)換成窗體實現(xiàn)。但是窗體實現(xiàn)并不完全對應(yīng)DSL描述。事實上,對于客戶的應(yīng)用來說,一個確定按鈕往往不是他的DSL描述的內(nèi)容,包括所謂的Edit啊,Grid啊都不是的。這些只是實現(xiàn)某類DSL的方式。從反推的方式來設(shè)計DSL,確實有難度啊??丶恼{(diào)用必須做到自動識別了。

比如一個簡單的Input對話框,只有一個Value的Edit控件。那么對于DSL描述,我希望是這樣的:在沒彈出對話框之前,就應(yīng)該是:設(shè)置 屬性 新值。對于對話框的彈出是在DSL中不可預(yù)計的

可見,DSL的實現(xiàn)還是比較有挑戰(zhàn)的。而且這里面也存在一個疑問,DSL適合測試嗎?或者說我說的DSL原本是設(shè)計給需求人員或者程序員的,而不是特別給測試的。真正在自動化測試中的DSL,應(yīng)該使用一種全新的方式去定義DSL。

不管怎么說,實現(xiàn)的方案已經(jīng)基本成熟了。我們也可以展望一下如果實現(xiàn)了Ruby的腳本支持,會帶來什么。

  1. 對于Ruby,我計劃是作為一個測試步驟(TestStep)加入到原有腳本中。這樣既不會丟掉原有腳本編輯的優(yōu)勢,又同時擁有了強大擴展能力。
  2. 如果DSL實現(xiàn)了,那么編程就會變得更加簡單。按照小賈的意思,用戶可能會放棄我原來的腳本編輯器。不過我不同意:)
  3. Ruby腳本的易用性,是經(jīng)過眾多網(wǎng)友驗證的。而我們就會同時擁有這方面的優(yōu)勢。其學(xué)習(xí)成本也是很低的。世界上有一個強大的社區(qū)在支持著它。而且現(xiàn)在眾多廠商也開始退出Ruby的編輯器,比如Borland最近推出的3rdRail™。這樣我們編寫Ruby的腳本,就不需要我們自己造一個輪子了。

Anyway,擁抱Ruby的這個選擇,也許會讓我們這個系統(tǒng)走向世界也說不定。 

 

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI