Showing posts with label ios. Show all posts
Showing posts with label ios. Show all posts

Find your elements faster ios appium in robotframework

Chào các bạn!
Nếu ai đã từng auto cho ios sử dụng appium, thì sẽ nhận ra rằng sử dụng xpath sẽ chậm hơn khá nhiều so với dùng ID hoặc Name.
Hiện tại chúng ta có thể cải thiện tốc độ bằng cách hạn chế sử dụng Xpath.
Thay vào đó chúng ta có thể tìm theo iOS PredicateClass Chain
Bài viết này sẽ hướng dẫn các bạn tăng tốc độ tìm element với ios trong robotframework.
Trước tiên chúng ta sẽ xem tốc độ của xpath so với iOS Predicate và Class Chain là như nào với ví dụ dưới đây



Có thể chúng ta thấy tốc độ chênh lệch nhau không nhiều trong 1 TC. nhưng nếu chúng ta có 100 hay 200 testcase thì chúng ta cũng tiết kiệm được kha khá thời gian đấy :D

ok, giờ chúng ta sẽ đi vào chi tiết như sau:

Cách dùng iOS Predicate 

1. trường hợp đơn giản nhất là button có label là Scrolling

type == 'XCUIElementTypeButton' AND label == "Scrolling"

2. như trường hợp 1 nhưng muốn thêm visiable vào thì như sau:

type == 'XCUIElementTypeButton' AND label == "Scrolling" AND visible == 1

3. trường hợp muốn tìm button có label bắt đầu bằng chữ Scroll

type == 'XCUIElementTypeButton' AND label BEGINSWITH 'Scroll' AND visible == 1

4. trường hợp mà muốn tìm button có chứa Scroll

type == 'XCUIElementTypeButton' AND label CONTAINS 'Scroll' AND visible == 1

Thông tin chi tiết thì các bạn xem thêm ở đây nhé.

Cách dùng Class Chain

1. chọn button thứ 3 sau thằng cha

**/XCUIElementTypeWindow/XCUIElementTypeButton[3]

2. chọn tất cả các các Cell, trong đó name bắt đầu bằng 'B'

**/XCUIElementTypeCell['name BEGINSWITH "B"']

Nhiều cách sử dụng hơn thì xem tại đây nhé

Qua bài viết này, chúng ta có thêm lựa chọn để tăng tốc độ tìm kiếm element trong ios khi dùng appium. Qua đó làm giảm thời gian chạy testcase bằng cách dùng iOS Predicate  và Class Chain để thay thế xpath trong 1 số trường hợp.

Mọi góp ý xin để lại dưới bình lựng!
Xin cảm ơn và hẹn gặp lại các bạn trong các bài tiếp theo!

Code ví dụ có trên github, các bạn clone ở đây nhé


Automation Testing iOS App With Robotframework On Mac OS using Appiumlibrary

Chào các bạn!
Hôm nay 24/12, mình ở nhà trông con, nhân lúc con ngủ thì chúng ta lại gặp nhau trong loạt bài automation testing mobile application.
Bài trước chúng ta đã tìm hiểu cách Automation Testing Android With Robotframework, bài viết này chúng ta sẽ tìm hiểu cách Automation Testing iOS App With Robot framework using Appiumlibrary
Các công cụ cần thiết
  1. Brew
  2. Python
  3. Node JS
  4. Appium server
  5. Cấu hình Xcode lần đầu tiên cài đặt
  6. Cài đặt robot framework
  7. IDE hoặc editor để code robot framework
Bước 1: Cài Brew tại trang chủ
https://brew.sh/ 
Brew là gì? hiểu ngắn gọn nó là trình quản lý các gói phần mềm trên mac os, có thể cài các phần mềm được hỗ trợ = 1 dòng lệnh mà ko cần phải lên tìm, down và cài phần mềm đó.
Truy cập trang chủ, copy và paste dòng đó vào terminal để cài đặt brew.
Sau khi cài xong thì cài thêm các thư viện sau


brew install ideviceinstaller
brew install carthage
brew install libimobiledevice --HEAD
sudo gem install xcpretty    

Bước 2: Cài python 
Cài python qua brew bằng lệnh sau

brew install python

Bước 3: Cài Node JS
Cài node JS qua brew bằng lệnh sau

brew install node

Chú ý: khi cài node js, nếu cần phân quyền thì chạy lệnh sau

sudo chmod 755  /usr/local/lib/node_modules/

Bước 4: Cài Appium server
Cài thông qua node js bằng lệnh sau
4.1 : Để cài phiên bản mới nhất thì chạy lệnh này

npm install -g appium

- Để cài một phiên bản cụ thể thì chạy lệnh này

npm install -g appium@1.9.1

- Cài các thành phần khác liên quan:

npm install -g ios-deploy
npm install -g deviceconsole

4.2:  Nên cài cả Appium Desktop để có thêm lựa chọn selector element
Vào trang chủ, tải và cài đặt Appium desktop http://appium.io/


Bước 5: Cài đặt Xcode
Đăng ký tài khoản, tải và cài đặt Xcode từ trang chủ https://developer.apple.com/xcode/
Sau khi cài đặt xong, chạy Xcode lên và cấu hình như sau:
5.1 : Vào menu Xcode > Preferences > Locations
Mặc định là combobox Command Line Tools sẽ bị trống, click vào ô đó để hiển thị phiên bản hiện tại của xcode


Bước 6: Cài đặt robot framework và appium library
Chạy các lệnh sau để cài đặt robot FW và thư viện Appiumlibrary

pip install robotframework
pip install robotframework-appiumlibrary
pip install six

Bước 7:  Editor để code robotframework
Mình khuyến khích dùng atom, vì gợi ý keyword khá ok

7.1: down và cài đặt Atom tại trang chủ https://atom.io/
7.2: sau khi cài xong, thì chạy lần lượt các lệnh sau trên terminal

apm install language-robot-framework
apm install autocomplete-robot-framework
apm install hyperclick
apm install hyperclick-robot-framework

Bước 8: Viết test case đơn giản cho ios simulator
Mình sẽ làm 1 testcase đơn giản là tạo mới 1 contact trong ứng dụng contact trên ios simualtor
8.1: Bật ios simulator bằng cách mở Xcode lên, vào menu Xcode > Open Developer Tool > Simulator
8.2: Mở appium desktop để bắt element

cách để bắt element trên ios
8.3: Sau khi đã có các element cần thiết thì viết test case đơn giản


*** Settings ***
Library           AppiumLibrary
*** Variables ***
${REMOTE_URL}          http://127.0.0.1:4723/wd/hub
${PLATFORM_NAME}    iOS
${PLATFORM_VERSION}    12.0
${DEVICE_NAME}    iPhone 8 Plus
${BUNDLE_ID}      com.apple.MobileAddressBook
${AutomationName}    XCUITest

*** Keywords ***
Open App Contact
    Open Application    ${REMOTE_URL}    platformName=${PLATFORM_NAME}    platformVersion=${PLATFORM_VERSION}    deviceName=${DEVICE_NAME}      bundleId=${BUNDLE_ID}

Input Phone Number
    [Arguments]     ${phoneNumber}
    Input Text    //XCUIElementTypeTextField[@name="home"]     ${phoneNumber}

Add New Contact
    Wait Until Element Is Visible    //XCUIElementTypeNavigationBar/XCUIElementTypeButton[2]
    Click Element    //XCUIElementTypeNavigationBar/XCUIElementTypeButton[2]


Add New Information
    Wait Until Element Is Visible     //XCUIElementTypeTextField[@name="First name"]
    Input Text    //XCUIElementTypeTextField[@name="First name"]     nguyen    #input first name
    Input Text    //XCUIElementTypeTextField[@name="Last name"]    hai       #input last name
    Capture Page Screenshot
    Click Element    //XCUIElementTypeCell[@name="add phone"]       #click icon add phone
    Input Phone Number    123456679
    Capture Page Screenshot
    Click Element    //XCUIElementTypeButton[@name="Done"]         #click button Done

Verify add new contact success
    Sleep    3s
    Element Should Be Visible    //XCUIElementTypeNavigationBar[@name="CNContactView"]
    Capture Page Screenshot


*** Test Cases ***
TC1_add new contact
    Open App Contact
    Add New Contact
    Add New Information
    Verify add new contact success
    Close Application


code trên atom nhìn khá thích :D
Kết quả sau khi chạy TC, nó thêm vào contact nguyen hai như trong ảnh
Chú ý:
bundleId lấy ở đâu? Nếu là app mặc định của ios, thì google sẽ có :D ví dụ với ios 12 , còn nếu là app do công ty làm thì hỏi dev cho nhanh nhé 

Hẹn gặp các bạn ở bài tiếp theo!
Bài sau mình sẽ giới thiệu các cách bắt element trên ios và android app nhé!