Skip to main content

Automation test for phone

Project description

Qa automation phone get screen by UI, screen short:

Mục đích:

Dự án này kết nối từ laptop tới server trên điện thoại Android, thực hiện dump màn hình và trả dữ liệu về laptop hoặc lấy màn hình điện thoại về nhận diện vị trí của text, button.

Sơ đồ:

                 ┌──────────────┐
                    Start                       └──────┬───────┘
                               ┌───────────────┴───────────────────┐
                                             ┌────▼───────┐                     ┌────▼───────┐
   Dump UI                          Take          to get                           Screenshot    button pos                      └────┬──────┘
  └────┬───────┘                                                                                                  ┌─────────────────────┐
  ┌─────────┐                   Split into 2 paths     Analyze                   ├───────────┬────────┤
   UI                         Path 1     Path 2   └────┬────┘                                                      ┌──────────┐  ┌──────────────┐
                          OCR          Image         ┌──────────┐             detect       template       Get                   button       matching      button               └────┬──────┘  └──────┬──────┘
   position                                   └────┬─────┘                                                         ┌──────────┐    ┌──────────┐
                          Get            Get        ┌───────────┐            button         button      Compare               position       position    results              └────┬──────┘    └────┬──────┘
  └────┬──────┘                                                                                 ┌──────────────────────┐   ┌──────────────┐  ┌──────────────┐
   Send command to          Send command    Send command    button                  to button       to button      └─────────┬───────────┘   └────┬─────────┘  └────┬─────────┘
                                                        ┌──────────┐           ┌───────────┐   ┌───────────┐
         End                   End           End            └──────────┘           └───────────┘   └───────────┘
  • Laptop: Gửi yêu cầu dump màn hình qua điệnh thoại.
  • Điện thoại (Server trên điện thoại): Nhận yêu cầu, thực hiện dump màn hình và gửi kết quả về laptop.

Thư viện được build dựa trên thư viện Uiautomator2 mình dùng function dump_hierarchy để lấy ui về xử lý

các bạn có thể tha khảo link của thư viện U2 ở đây: thu viện u2

Cài đặt thư viện:

  1. Cài đặt Qa-automation-phone trên PC:
pip install QA-automation-phone

Tiến hành chạy thử trên phone:

Test tốc độ click trên model cũ

❌ lưu ý để màn hình điện thoại có Button Settings để test

import time
import QA_automation_phone as qa
connect = qa.connect()
start = time.time()
connect.connect(text="Settings").click()
print(time.time() - start)

Test tốc độ click trên model mới:

import time
import QA_automation_phone as qa
connect = qa.connect()
start = time.time()
connect.click_element(value="Settings")
print(time.time() - start)

model mới được tối ưu hơn chạy nhanh hơn 1 chút

Lấy text, content cần chạy 1 server:

cần cài đặt 1 websever để lấy màn hình điện thoại

pip install -U webitor

sau đó chạy ứng dụng

python -m weditor

giao diện weditor

Cách sử dụng chạy thử với đa luông:

import time
import QA_automation_phone as qa
import threading
devicess = qa.get_devices()

def open_card_health(connect, index: int = 0, type_element: str="content-desc", value: str=""):
    if not connect.wait_for_element(value="Home", wait_time=2):
        connect.open_app(package="com.sec.android.app.shealth")
        time.sleep(2)
    a = connect.scroll_up_and_down_find_element(value=value, type_element=type_element,index=index, duration=800, click=True)
    if a:
        time.sleep(2)
        if connect.wait_for_element(value=value, wait_time=2):
            time.sleep(2)
            connect.press_back()
            return True

def check_youtobe(connect):
    connect.click_element(type_element="content-desc", value="Search")
    time.sleep(2)
    if  connect.adb_send(content="Bac Bling"):
        print("input done")
    else:
        print("input fail")
    connect.press_enter()
    time.sleep(2)

def run(device_id):
    print("start")
    connect = qa.connect(device=device_id)

    if connect.open_app(package="com.sec.android.app.shealth"):
        print("Opened")

    open_card_health(connect=connect,value="Steps",index=1 )
    time.sleep(2)
    open_card_health(connect=connect,value="Daily")
    time.sleep(2)
    open_card_health(connect=connect,value="Sleep")
    time.sleep(2)
    open_card_health(connect=connect,value="Food")
    time.sleep(2)
    open_card_health(connect=connect,value="Water")
    connect.close_app(package="com.sec.android.app.shealth")
    time.sleep(3)
    # open tiktok app
    connect.open_app(package="com.google.android.youtube")
    time.sleep(3)
    check_youtobe(connect=connect)
threads = []
for device_id in devicess:
    thread = threading.Thread(target=run, args=(device_id,))
    threads.append(thread)
for thread in threads:
    thread.start()

Thao tác với orc:

Hiện tại orc chỉ click vào được một từ đơn nếu giữa text có dấu cách thì sẽ không cick được.
VD:

import QA_automation_phone as qa
devices = qa.get_devices()
cn = qa.connect(devices[0])
a= cn.orc_find_text(target_text="Samsung", lang="eng", index=1,click=True)
print(a)

code trên sẽ tìm chữ Samsung ở trên màn hình với lần xuất hiện là thứ 2 nếu target_text="Samsung Health" thì thư viện chưa hỗ trợ mình sẽ update sau

❌ Code này sẽ không tìm được text là Samsung Health.

import QA_automation_phone as qa
devices = qa.get_devices()
cn = qa.connect(devices[0])
a= cn.orc_find_text(target_text="Samsung Health", lang="eng", index=1,click=True)
print(a)

các hàm hay dùng trong orc:

import QA_automation_phone as qa
devices = qa.get_devices()
cn = qa.connect(devices[0])
a= cn.orc_find_text(target_text="Samsung", lang="eng", index=1,click=True)
cn.orc_find_text(target_text="Settings", lang="eng", index=1,click=True)
cn.orc_scroll_find_text(target_text="Heart rate", click=True)
cn.orc_scroll_up_and_dow_find_text(target_text="Heart rate", click=True)
print(a)

Thao toác với ảnh:

để thao tác với ảnh các bạn cần có môt mẫu để so sánh thi viện của mình sẽ chuyển hết chúng về đen trắng để so sánh. để lấy ảnh mẫy từ màn hình cách bạn chạy hàm dưới đây:

import QA_automation_phone as qa
import time, threading
devices = qa.get_devices()
connect = qa.connect(device=devices[0])
connect.get_crop_image(x1=795, y1=1564, width=200, height=300, output_path="./picture1.png")

x, y là tọa độ điểm đầy phái trên bên trái của button
width, height là độ rộng và cao của button
sau khi chạy xong check ảnh picture1.png xem đúng chưa.

tiến hành chạy thử nhận diện tìm kiếm vị trí của anh:

import QA_automation_phone as qa
import time, threading
devices = qa.get_devices()
connect = qa.connect(device=devices[0])
connect.find_button_by_image(template_path="./picture1.png", threshold=0.8,click=True)

các hàm hay dùng trong tìm kiếm vị trí của ảnh để click:

import QA_automation_phone as qa
import time, threading
devices = qa.get_devices()
connect = qa.connect(device=devices[0])
connect.find_button_by_image(template_path="./picture1.png", threshold=0.8,click=True)
connect.scroll_find_images(template_path="./picture1.png",type_scroll="up",click=True)
connect.scroll_up_and_dow_find_images(template_path="./picture1.png",click=True)

👉 Nếu các bạn test có các issue quay lại video hay tạo issue trên repore này rồi gửi cho mình mình sex fix nhé !

Lưu ý:

  • Điện thoại cần bật chế độ nhà phát triển và cấp quyền ADB.
  • Đảm bảo server đang chạy trên điện thoại.

Nếu thấy hay và giúp ích cho các bạn bạn có thể gửi quà cho mình nhé Thanks!

QR Pay

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

qa_automation_phone-0.1.6.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

qa_automation_phone-0.1.6-py3-none-any.whl (14.8 kB view details)

Uploaded Python 3

File details

Details for the file qa_automation_phone-0.1.6.tar.gz.

File metadata

  • Download URL: qa_automation_phone-0.1.6.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.5

File hashes

Hashes for qa_automation_phone-0.1.6.tar.gz
Algorithm Hash digest
SHA256 03fbf629e876f3eb84c36fd0871bb9a1b7d89aedd3c1dcb54cabe21a4d5a2788
MD5 96e820386db37e321c9f82194c8b98b9
BLAKE2b-256 7d1a8c1afe6360165fd4507603640c9ffee838686c0719741c6c56ca2963c1f7

See more details on using hashes here.

File details

Details for the file qa_automation_phone-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for qa_automation_phone-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 673ba406baa0834e3b862ae6309e820fab10afeb384a065957a4314127646944
MD5 c0ab01a78f25dbcfc520b76547e17431
BLAKE2b-256 96613880c2eaeaf6250ccdfbd6ecf5ea0d031880a036b7c55c97e9aeb797e317

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page