bytes.cat

La wiki d'FP d'informàtica

Eines de l'usuari

Eines del lloc


Barra lateral

ASIX Administració de Sistemes Informàtics i Xarxes
Tots els mòduls del cicle
MP01 Implantació de sistemes operatius
Totes les UFs del modul
MP02 Gestió de bases de dades
Totes les UFs del modul
MP03 Programació bàsica
Totes les UFs del modul
MP04 Llenguatges de marques i sistemes de gestió d'informació
Totes les UFs del modul
MP05 Fonaments de maquinari
Totes les UFs del modul
MP06 Administració de sistemes operatius
Totes les UFs del modul
MP07 Planificació i administració de xarxes
Totes les UFs del modul
MP08 Serveis de xarxa i Internet
Totes les UFs del modul
MP09 Implantació d'aplicacions web
Totes les UFs del modul
MP10 Administració de sistemes gestors de bases de dades
Totes les UFs del modul
MP11 Seguretat i alta disponibilitat
Totes les UFs del modul
MP12 Formació i orientació laboral
Totes les UFs del modul
MP13 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP14 Projecte
Totes les UFs del modul
DAM Desenvolupament d’aplicacions multiplataforma
Tots els mòduls del cicle
MP01 Sistemes informàtics
Totes les UFs del modul
MP02 Bases de dades
Totes les UFs del modul
MP03 Programació bàsica
Totes les UFs del modul
MP04 Llenguatges de marques i sistemes de gestió d'informació
Totes les UFs del modul
MP05 Entorns de desenvolupament
Totes les UFs del modul
MP06 Accés a dades
Totes les UFs del modul
MP07 Desenvolupament d’interfícies
Totes les UFs del modul
MP08 Programació multimèdia i dispositius mòbils
Totes les UFs del modul
MP09 Programació de serveis i processos
Totes les UFs del modul
MP10 Sistemes de gestió empresarial
Totes les UFs del modul
MP11 Formació i orientació laboral
Totes les UFs del modul
MP12 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP13 Projecte de síntesi
Totes les UFs del modul
MPDual Mòdul Dual / Projecte
DAW Desenvolupament d’aplicacions web
Tots els mòduls del cicle
MP01 Sistemes informàtics
Totes les UFs del modul
MP02 Bases de dades
Totes les UFs del modul
MP03 Programació
Totes les UFs del modul
MP04 Llenguatge de marques i sistemes de gestió d’informació
Totes les UFs del modul
MP05 Entorns de desenvolupament
Totes les UFs del modul
MP06 Desenvolupament web en entorn client
Totes les UFs del modul
MP07 Desenvolupament web en entorn servidor
Totes les UFs del modul
MP08 Desplegament d'aplicacions web
Totes les UFs del modul
MP09 Disseny d'interfícies web
Totes les UFs del modul
MP10 Formació i Orientació Laboral
Totes les UFs del modul
MP11 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP12 Projecte de síntesi
Totes les UFs del modul
SMX Sistemes Microinformàtics i Xarxes
Tots els mòduls del cicle
MP01 Muntatge i manteniment d’equips
Totes les UFs del modul
MP02 Sistemes Operatius Monolloc
Totes les UFs del modul
MP03 Aplicacions ofimàtiques
Totes les UFs del modul
MP04 Sistemes operatius en xarxa
Totes les UFs del modul
MP05 Xarxes locals
Totes les UFs del modul
MP06 Seguretat informàtica
Totes les UFs del modul
MP07 Serveis de xarxa
Totes les UFs del modul
MP08 Aplicacions Web
Totes les UFs del modul
MP09 Formació i Orientació Laboral
Totes les UFs del modul
MP10 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP11 Anglès
Totes les UFs del modul
MP12 Síntesi
Totes les UFs del modul
CETI Ciberseguretat en Entorns de les Tecnologies de la Informació
Tots els mòduls del cicle
CiberOT Ciberseguretat en Entorns d'Operació
Tots els mòduls del cicle
android_test

Tests funcionals amb Android

Emprarem la llibreria https://appium.io

Podrem fer tests funcionals de forma molt similar a com utilitzem Selenium per a web.

Articles previs:


Android Studio

Android Studio és l'eina oficial que Google recomana per a desenvolupa en Android.


Instal·lació

Necessitarem NodeJS versió LTS:

# apt install nodejs npm
# npm install -g n
# n lts

Tanqueu i obriu de nou el terminal, i comproveu la versió de NodeJS:

$ node --version

Instal·lem la llibreria Appium i el Driver UIAutomator2

$ sudo npm i -g appium
$ appium driver install uiautomator2

Provem servidor en una shell a part (escoltarà al port 4723):

$ appium

El podem parar amb CTRL+C.

També hem d'instal·lar:

  • Android Studio IDE
  • Android SDK (podem emprar el SDK Manager de l'Android Studio).
  • Java SDK >=11 per a Android SDK>=30
  • Crear un emulador Android i engegar-lo (podem emprar AVD Manager).

Emulador

L'emulador Android es pot iniciar des de CLI:

$ cd Andrid/Sdk/emulator
$ ./emulator -avd "Pixel_XL_API_34"

Si hem de fer els autotests en una servidor podem afegir la opció -no-window perquè funcioni en mode headless:

$ ./emulator -avd "Pixel_XL_API_34" -no-window


Exemple Python

La documentació oficial de Appium ens ofereix un exemple en Python i altres llenguatges (Javascript, Java, Ruby).

Revisa que estiguis consultant la documentació de la versió actual.

Creem un virtualenv per no interferir la instal·lació del sistema operatiu:

$ python -m venv envtest
$ source envtest/bin/activate
(envtest) $ pip install Appium-Python-Client pytest

Prenem aquest codi d'exemple que obre l'aplicació com.android.settings i cerca la opció Battery amb Xpath:

test_example.py
import unittest
from appium import webdriver
from appium.webdriver.common.appiumby import AppiumBy
 
# Import Appium UiAutomator2 driver for Android platforms (AppiumOptions)
from appium.options.android import UiAutomator2Options
 
capabilities = dict(
    platformName='Android',
    automationName='uiautomator2',
    deviceName='Android',
    appPackage='com.android.settings',
    appActivity='.Settings',
    language='en',
    locale='US'
)
 
# Converts capabilities to AppiumOptions instance
capabilities_options = UiAutomator2Options().load_capabilities(capabilities)
 
appium_server_url = 'http://localhost:4723'
 
class TestAppium(unittest.TestCase):
    def setUp(self) -> None:
        self.driver = webdriver.Remote(command_executor=appium_server_url,options=capabilities_options)
 
    def tearDown(self) -> None:
        if self.driver:
            self.driver.quit()
 
    def test_find_battery(self) -> None:
        el = self.driver.find_element(by=AppiumBy.XPATH, value='//*[@text="Battery"]')
        el.click()
 
if __name__ == '__main__':
    unittest.main()

Shell 1

Assegura't que disposes de la variable $ANDROID_SDK_ROOT. Si no la tens, sol ser:

$ export ANDROID_SDK_ROOT=~/Android/Sdk/

Engeguem el servidor Appium (escoltarà al port 4723):

$ appium

Shell 2

Si estem treballant amb Android Studio i tenim l'emulador engegat, no cal aquest apartat.

Si no tenim cap emulador engegat, podem posar-ho en marxa amb (substituir pel AVD pertinent):

$ cd ~/Android/Sdk/emulator
$ ./emulator -avd "Pixel_3a_API_34_extension_level_7_x86_64"

Shell 3

Engeguem els tests:

$ source env/bin/activate
(envtest) $ python3 test_example.py

…i podrem veure com entra als Settings de l'emulador i clica en la secció «Battery» (sempre i quan l'emulador estigui en anglès).

android_test.txt · Darrera modificació: 2024/04/23 14:45 per enric_mieza_sanchez