+1

Automation test với RobotFramework - Sử dụng Eclipse (Phần 2-Tích hợp Selenium)

Tiếp nối series phần trước, như đã nói bài này mình sẽ viết về việc tích hợp Selenium vào project RobotFramework để có thể thực hiện automation với các ứng dụng web

Trình tự thực hiện trong bài này gồm:

  • 🐬 Download & add thư viện Selenium vào Project
  • 🥗 Bài toán tìm kiếm trên Google
  • 🌼 Bài toán Login

1. Download và add thư viện Selenium vào Project

Step 1: Đầu tiên bạn mở cmd trên máy windows và cài đặt thư viện SeleniumLibrary theo các câu lệnh sau:

pip install robotframework-seleniumlibrary

Để kiểm tra việc cài đặt đã thành công chưa, bạn dùng câu lệnh: pip list

Tại đây sẽ hiển thị danh sách các thư viện bạn đã cài đặt. Nếu thấy dòng robotframework-seleniumlibrary như ảnh trên nghĩa là bạn đã cài đặt thư viện thành công

Step 2: Mở project của bạn ra và add thư viện vào thôi 😄

Bạn chọn vào file red.xml => double click vào "... add new library file" => chọn thư viện 'seleniumlibrary'

2. Bài toán tìm kiếm trên Google - Tìm kiếm từ khóa "Sun Asterisk" trên Google

Tiếp nối bài toán ở Phần 1 - Đầu tiên phải add thư viện Selenium vào trong TestSuite

*** Setting ***
Library    SeleniumLibrary  
  • Tạo tên Testcase mới => đặt tên tùy thích (mình đặt là FirstSeleliumTest)
  • Để giải quyết bài toán tìm kiếm trên Google ta cần các bước như sau:

+ Step 1: Mở trình duyệt => mở url
Để mở 1 trình duyệt ta sử dụng từ khóa Open Browser url {browser}
Trong đó browser là name tương ứng trong bảng sau:

Browser Name(s)
Firefox firefox, ff
Google Chrome googlechrome, chrome, gc
Headless Firefox headlessfirefox
Headless Chrome headlesschrome
Internet Explorer internetexplorer, ie
Edge edge
Safari safari
Opera opera
Android android
Iphone iphone
PhantomJS phantomjs
HTMLUnit htmlunit
HTMLUnit with Javascript htmlunitwithjs

Ví dụ: Bạn muốn mở link google bằng Chrome thì dùng:

Open Browser https://www.google.com chrome

+ Step 2: Nhập từ khóa vào ô tìm kiếm
Như các bài viết trước của mình cũng đã hướng dẫn cách lấy phần tử trên trình duyệt, nên bài này mình sẽ không hướng dẫn chi tiết nữa

Inspect element vào phần tử cần lấy thuộc tính và lấy điểm đặc trưng của nó. Như ô tìm kiếm trên google điểm đặc trưng là name=q

Câu lệnh dùng trong bước này sẽ là: Input Text name=q Sun Asterisk với 'Input Text' là từ khóa 'name=q' là phần tử cần nhập text 'Sun Asterisk' là value cần tìm

+ Step 3: Click vào button Tìm kiếm và xem hiển thị kết quả

Đầu tiên là lấy phần tử của button Tìm kiếm và lấy điểm đặc trưng của button name=btnK

Click vào button ta dùng câu lệnh: Click Button name=btnK

=> Từ 3 bước trên ta sẽ có đoạn code như sau:

*** Setting ***
Library    SeleniumLibrary    
*** Test Cases ***

FirstSeleliumTest
    Open Browser    https://www.google.com    chrome
    Set Browser Implicit Wait    5
    Input Text    name=q    Sun Asterisk  
    Click Button    name=btnK 
    Sleep     2   

Trong đó câu lệnh Set Browser Implicit Wait 5 là đặt thời gian chạy ngầm cho trình duyệt load xong là 5s
câu lệnh Sleep 2 là đợi hiển thị load kết quả sau khi click vào button 2s

Chạy bài toán trên ta được kết quả như sau:

3. Bài toán Login 🌼 - Login trang Viblo

Tương tự với bài toán tìm kiếm trên ta cũng liệt kê các bước cần phải làm như sau:

+ Step 1: Open trang Viblo => Open link Login

Đầu tiên mở url trang Viblo: https://viblo.asia/
Sau đó tìm phần tử của hyperlink: Sign In/Sign up như ảnh dưới. Để cho nhanh và chính xác thì bạn có thể dụng tool hỗ trợ lấy phần tử ChroPath (trước đây mình cũng có viết bài này rồi, bạn có thể đọc lại)

Mã lệnh cho Step 1 là như sau:

Open Browser    https://viblo.asia/    chrome
Click Element    XPath=//span[contains(text(),'Sign In/Sign up')] 

Kết quả Step 1 là mở được trang Login như sau:

+ Step 2: Input username & password

Lấy phần tử username bằng tool ChroPath như ảnh dưới

Lấy phần tử password bằng tool ChroPath như ảnh dưới Mã lệnh cho Step 2 là như sau:

Input Text    XPath=//body/div[1]/div[1]/div[1]/div[1]/div[1]/div[1]/div[3]/form[1]/div[1]/div[1]/div[1]/input[1]    phamhangxxx@gmail.com
Input Password    XPath=//body/div[1]/div[1]/div[1]/div[1]/div[1]/div[1]/div[3]/form[1]/div[2]/div[1]/div[1]/input[1]    12345678

Để test thử mình đang sử dụng email và password invalid. Bạn có thể thử với trường hợp valid nhé 😂

+ Step 3: Click button Login và kiểm tra kết quả

Lấy phần tử button Login bằng tool ChroPath như ảnh dưới

=> Mã lệnh của bài toán này là như sau:

LoginSelenium
    Open Browser    https://viblo.asia/    chrome
    Click Element    XPath=//span[contains(text(),'Sign In/Sign up')]    
    Input Text    XPath=//body/div[1]/div[1]/div[1]/div[1]/div[1]/div[1]/div[3]/form[1]/div[1]/div[1]/div[1]/input[1]    phamhangxxx@gmail.com
    Input Password    XPath=//body/div[1]/div[1]/div[1]/div[1]/div[1]/div[1]/div[3]/form[1]/div[2]/div[1]/div[1]/input[1]    12345678
    Click Button    XPath=//body/div[1]/div[1]/div[1]/div[1]/div[1]/div[1]/div[3]/button[1]   

Kết quả sau khi login với acc & password invalid sẽ như sau:

note: nếu bạn muốn đóng trình duyệt sau mỗi lần chạy thì dùng từ khóa Close Browser ở cuối Testcase là được

=> Trên đây là bài viết về việc tích hợp Selenium và project RobotFramework, kèm 2 bài toán đơn giản để bạn thực hành. Hy vọng bài viết sẽ có ích cho bạn. Bài sau mình sẽ hướng dẫn làm 1 bài toán với nhiều loại items khác nhau hơn 😄 . Cảm ơn bạn đã đọc bài


All rights reserved

Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí