跳到主要內容

減少產生不必要的Log

Introduction

隨著testcases越來越多,我們這陣子開始有報表無法出現的問題。後來發現是由於output.xml就有46~50MB的大小,在產生報表時會發生out of memory。這大小光要透過編輯器打開就很吃力了;後來暫時解決方式是透過commandline自行產生報表:

java -jar robotframework.jar rebot output.xml

但這方法不治本,所以開始慢慢的調整我們的testcases。

How to?

我開始著手這問題時,RobotFramework已升級到3.0版本,而Selenium從SeleniumLibrary(2.9.1)升級到Selenium2Libary(1.7.4),接下來針對這兩個Library我們所做的調整做說明。會有大量log產生的兇手之一為Wait Until Keyword Succeeds,它會將你retry的內容記錄下來,但有時你並不需要它們:

等到網頁不包含XXX

在SeleniumLibrary時,會寫成這樣:

Wait Until Keyword Succeeds | ${timeout} | ${interval} | Page Should Not Contain Element | ${locator}

而Selenium2Library後,可以改成這樣:

Wait Until Page Does Not Contain Element | ${locator} | ${timeout}

可用Keywords: Wait Until Page Does Not Contain Element與Wait Until Page Does Not Contain

等到網頁包含XXX

不管在Selenium1還是2,可能都有人會透過以下寫法去做等到網頁包含XXX:

Wait Until Keyword Succeeds | ${timeout} | ${interval} | Page Should Contain Element | ${locator}

但其實Selenium本身已支援Wait Until:

Wait Until Page Contains Element | ${locator} | ${timeout}

可用Keywords: Wait Until Page Contains Element與Wait Until Page Contains。

檔案內容是否包含

有時我們會檢查某個檔案內容是否包含特定字串:

${content} | Get File | ${file}
Should Contain | ${content} | ${expect_str}

在發生錯誤時,會將整個檔案內容給log下來。如果檔案內容是值得參考的,也許你會直接log下來;但我會將當時的檔案複製一份,再透過log去連結它: link。如果抓取檔案不是問題,接下來就是減少錯誤發生時所造成的大量log。我透過Grep File,去取代Get File:

${ret} | Grep File | ${file} | ${expect_str}
Should Not Be Empty | ${ret}

另外一個方式是將,Should Contain的values參數設定為False:

${content} | Get File | ${file}
Should Contain | ${content} | ${expect_str} | values=False

不少判斷內容的keyword都支援此參數,缺點是Get File的動作還是會log部分內容。

可用Keywords: Grep File

設定Retry/Wait Keyword的Log Level

這部分可參考另外一篇:

Set Log Level

在某些retry動作內有包含log keyword時,可以在使用前透過Set Log Level為NONE去避免不必要的LOG,然後在teardown在回復成INFO。

使用--RemoveKeywords參數

以Wait Until Keyword Succeeds來說,Robot設計者已考量到大量log產生問題,因此可以在robot參數加入以下參數,去濾掉不必要的報表內容:

--RemoveKeywords WUKS

PS. output.xml中依然會有這些東西,但report.html中是被濾掉的。


留言

這個網誌中的熱門文章

PostgreSQL - Unattended installation on windows

Introduction 要將別人軟體包裝到自己軟體中,不可或缺的東西就是Unattended installation。以Unattended installation來說,我們可以選擇透過Installer的silent mode安裝,也可以透過把目標軟體做成portable的版本。本篇文章分享這兩種方法,教導大家如何將PostgreSQL透過Unattended installation方式安裝到目標系統成為service。 Note. 本篇以PostgreSQL 10.7為例。 Install with installer Tips 安裝程式或反安裝程式的參數,除了可以直接上官網搜尋Installation User Guide以外,也可以直接使用help參數查詢: postgresql- 10.7 - 2 -windows-x64.exe --help Windows安裝程式主要有EnterpriseDB與BigSQL兩種。BigSQL版本安裝元件是透過網路下載且支援參數不如EnterpriseDB版本多,以我們需求來說,我們傾向於使用EnterpriseDB版本。接下來分享給大家安裝與反安裝方法。 Installation @ echo off set INSTALL_DIR =C:\postgres10 set INSTALLER =postgresql- 10.7 - 2 -windows-x64.exe   rem options for installation set SSMDB_SERVICE =postgresql- 10 set MODE =--unattendedmodeui none --mode unattended   set DB_PASSWD =--superpassword postgres set DB_PORT =--serverport 5432   set SERVICE_NAME =--servicename % SSMDB_SERVICE %   set PREFIX =--prefix "%INSTALL_DIR%" set DATA_DIR =--datadir "%INSTALL_DIR%\data"   set OPTIONS =

How to install RIDE on Windows?

Introduction 多年沒在Windows上開發RobotFramework,趁著這次整理一下RIDE安裝方法。 目前RIDE最新版本與Python對應版本如下: (3.6 < python <= 3.11) Install current released version (2.0.8.1) with: pip install -U robotframework-ride 安裝Python 直接到Python官網找尋最新的3.11版本,我使用3.11.9: link 。安裝就是一直下一步而已。 安裝wxPython 每次安裝RIDE最困難的都是wxPython。看了一下 官網 描述,我就姑且相信一下: 接著進入下 載頁面 就有安裝教學。基本上就是到Python目錄下的Scripts直接執行以下command: pip install -U wxPython 安裝RIDE 接著就如RIDE官網所說,執行以下command: pip install -U robotframework-ride 啟動RIDE 直接在相同目錄下執行ride就可以啟動了,你也可以直接在桌面建ride連結,加快下次啟動時間。 沒想到這次這麼順利就安裝完成了。因為我是使用java去啟動robot framework,就不特別講要怎麼使用pip安裝robot framework了。

Hello World!

即將要搬家,因此舊網頁內容將慢慢轉移至Blogger。 如果要存取舊網頁,可以使用以下連結: https://wiki.tonylin.idv.tw/dokuwiki/doku.php