Chào các bạn!
Đã lâu rồi mình mới quay lại viết blog :D
Tại bài trước, chúng ta đã làm quen với testcase đầu tiên trong robotFW.
Đã lâu rồi mình mới quay lại viết blog :D
Tại bài trước, chúng ta đã làm quen với testcase đầu tiên trong robotFW.
Hôm nay chúng ta sẽ tìm hiểu về Data Driven Testing trong Robot Framework.
Các thư viện cần có:
Các thư viện cần có:
- SeleniumLibrary
- ExcellentLibrary
- Tạo file excel chứa data test:
- Chú ý: Do lib excel được viết từ openpyxl nên chỉ hỗ trợ excel có đuôi xlsx
- Chúng ta chú ý các tên cột, tên file và tên sheet trong excel
Ok, chúng ta bắt đầu thôi.
Kịch bản của chúng ta như sau:
Chú ý:
Kịch bản của chúng ta như sau:
- vào trang web http://demo.guru99.com/insurance/v1/index.php
- nhập email và pass
- click button login
- get text của thông báo hiện lên
- compare text thông báo mong muốn trong excel và text show trên web
Đây là code của tips này:
*** Settings *** Library ExcellentLibrary Library SeleniumLibrary Library Collections *** Test Cases *** login Open Browser http://demo.guru99.com/insurance/v1/index.php chrome Maximize Browser Window Open Workbook Resources/data.xlsx Switch Sheet login @{all}= Read Sheet Data @{data}= Get Slice From List ${all} 1 : FOR ${i} IN @{data} \ Clear Element Text email \ Input Text email ${i[0]} #first columns in excel \ Clear Element Text password \ Input Password password ${i[1]} \ Click Button name = submit \ Wait Until Element Is Visible css=div> span \ ${lblActual}= Get Text css=div> span \ Should Be Equal As Strings ${lblActual} ${i[2]} Close Browser
Chú ý:
- các biến như ${i[0]} - do email là cột đầu tiên của excel, nhưng khi lấy về mảng, thì giá trị đầu tiên là 0. nếu email ở cột số 2 thì trong code sẽ là Input Text email ${i[1]}
- tại dòng số 13 : @{data}= Get Slice From List ${all} 1 : do khi đọc data ở excel, data trả về sẽ lấy cả header của excel, tức là giá trị (email, pass, expected), nên cần dùng lệnh này để bỏ đi giá trị đầu tiên đó. các bạn xem thêm tại đây nhé
- file data.xlsx để trong thư mục Resources
OK, vậy là xong rồi. có thắc mắc các bạn hãy để lại bình luận bên dưới nhé!
Hẹn gặp lại các bạn vào các bài tiếp theo!