Tutorial IO del controlador web amb un lloc web en directe i exemples de treball: 8 passos
Tutorial IO del controlador web amb un lloc web en directe i exemples de treball: 8 passos
Anonim
Tutorial IO del controlador web mitjançant un lloc web en directe i exemples de treball
Tutorial IO del controlador web mitjançant un lloc web en directe i exemples de treball

Tutorial IO del controlador web mitjançant un lloc web en directe i exemples de treball

Última actualització: 2015-07-26

(Torneu a comprovar-ho sovint mentre actualitzo aquest instructable amb més detalls i exemples)

Antecedents

Fa poc em van presentar un repte interessant. Necessitava introduir proves automàtiques a un departament de Q / A amb molt poca experiència tècnica i sense antecedents de programació.

Es tractava realment de dos (2) reptes separats. El primer era identificar les tecnologies per realitzar les proves automatitzades. El segon consistia a formar el departament Q / A.

L’article només abordarà les tecnologies utilitzades i el que vaig aprendre en el procés.

Les tecnologies funcionaven bé, però realment vaig haver de buscar informació i vaig passar moltes hores descobrint problemes.

Em va costar trobar informació a Internet sobre aquestes tecnologies que treballaven totes juntes.

Volia compartir aquesta informació, així que vaig escriure aquest article juntament amb exemples de prova de scripts de treball i un lloc web de prova per executar-los.

Tots els scripts de prova es poden trobar a github i el lloc de prova de treball es troba a Web Driver IO Tutorial Test Site

Espero que us sigui útil. Si ho feu, si us plau, aviseu-me.

Objectius: Utilitzar tecnologies per:

  • Proveu la funcionalitat del lloc web
  • Proveu la funcionalitat de JavaScript
  • Es pot executar manualment
  • Es pot executar automàticament
  • Llenguatge fàcil d'aprendre per a no programadors

    Personal Q / A amb coneixements bàsics d'HTML i JavaScript

  • Utilitzeu només programari de codi obert

Tecnologies

Llista de tecnologies que trio:

  • mocha - test runner - executa els scripts de prova
  • shouldjs - biblioteca d'assercions
  • webdriverio - enllaços de control del navegador (enllaços d'idioma)
  • seleni: fàbrica d’abstracció i execució del navegador
  • Controladors de navegadors / mòbils + navegadors

    • Firefox (només navegador)
    • Chrome (navegador i controlador)
    • IE (navegador i controlador)
    • Safari (connector del navegador i del controlador)

Pas 1: Instal·lació del programari

Per començar, heu de tenir instal·lat el servidor independent Node JS, Web Driver IO, Mocha, Should i Selenium.

Aquí teniu instruccions d’instal·lació per a Windows 7.

(Sóc usuari de Mac / Linux, però vaig haver d’instal·lar-ho tot a les màquines Windows 7, per això l’he inclòs com a referència. El procediment d’instal·lació en un Mac / Linux és similar. Consulteu les referències en línia per obtenir més informació informació.)

Des d'un navegador:

  • Instal·la Node que inclou NPM (Node Package Manager)
  • vés a
    • Feu clic a Instal·la
    • Deseu i executeu el fitxer
    • Estableix el camí i la variable (NODE_PATH)
    • Aneu a Tauler de control-> Sistema i seguretat-> Sistema
      • Configuració avançada del sistema
      • Configuració d'entorn (variables d'usuari)

        • Afegeix a PATH

          C: / Users {USERNAME} AppData / Roaming / npm;

        • Afegiu el NODE_PATH (variables del sistema)

          C: / Users {USERNAME} AppData / Roaming / npm / node_modules

Nota: He instal·lat tot el programari següent amb l'opció global npm (-g). Normalment no es recomana això, però per a aquesta instal·lació calia instal·lar-ho globalment, ja que s'utilitzaria en diversos projectes.

Obre el símbol del sistema (cmd):

(administrador d'usuaris locals)

  • Instal·leu selenium "controlador web IO"

    • npm install webdriverio -g

      Això instal·larà el controlador web IO de forma global a la vostra màquina

  • Instal·leu el programari del corredor de prova “mocha”

    • npm instal·la mocha -g

      Això instal·larà mocha globalment a la vostra màquina

  • Instal·leu la biblioteca d'assercions "hauria de"

    • npm install hauria de -g

      Això s'instal·larà "hauria" globalment a la vostra màquina

  • Instal·leu Selenium Stand Alone Server

    • Aneu a
    • Descarregueu el fitxer jar i moveu-lo al directori "seleni".
  • Instal·leu navegadors i controladors de navegador per provar-los

    • Des de l'indicador cmd:

      • Creeu un directori "seleni"
      • C: / Users {USERNAME} seleni
      • Ordres:

        • cd C: / Usuaris {USERNAME}
        • seleni de mkdir
      • Firefox

        • Instal·leu el navegador Firefox, si encara no està instal·lat.
        • El camí s’ha d’establir per iniciar Firefox des de l’indicador d’ordres (cmd).
        • Tauler de control-> Sistema i seguretat-> Sistema
          • Configuració avançada del sistema
          • Configuració de l'entorn
          • Afegiu (afegiu ús de punt i coma) a la variable de ruta
          • C: / Program Files (x86) Mozilla Firefox
        • No es necessita cap controlador web especial per a Firefox.
      • Chrome

        • Instal·leu el navegador Chrome, si encara no està instal·lat.
        • Es pot configurar el camí per iniciar Chrome des de l'indicador d'ordres (cmd).
        • Proveu primer: chrome.exe des del símbol del sistema (cmd)
        • Si Chrome no s'inicia, feu el següent:
        • Tauler de control-> Sistema i seguretat-> Sistema
          • Configuració avançada del sistema
          • Configuració de l'entorn
          • Afegiu (afegiu ús de punt i coma) a la variable de ruta
          • C: / Program Files (x86) Google / Chrome / Application / chrome.exe
        • Cal un controlador web especial per a Chrome.

          Aneu a chromium.org i descomprimiu el controlador de 32 bits al directori "seleni"

      • Internet Explorer (només per a Windows: no funcionarà en altres plataformes)

        • Es necessita un controlador web especial per a IE.

          • Aneu a
          • Descarregueu i descomprimiu el controlador de 64 bits al directori "selenium".

Pas 2: Script bàsic de prova

Comencem amb alguns conceptes bàsics.

Aquí teniu un simple script mocha que obrirà un lloc web i verificarà el títol.

// tutorial1.js

// // Es tracta d’un script de prova senzill per obrir un lloc web i // validar el títol. // biblioteques obligatòries var webdriverio = require ('webdriverio'), should = require ('should'); // es descriu un bloc de scripts o un conjunt de proves ("Prova de títol per al controlador web IO - Lloc web de la pàgina de prova del tutorial", funció () {// estableix el temps d'espera a 10 segons aquest. timeout (10000); var driver = {}; // ganxo per executar-se abans de les proves anteriors (funció (fet) {// carregueu el controlador per al controlador del navegador = webdriverio.remote ({desitjatCapacitats: {nom del navegador: 'firefox'}}); controlador.init (fet);}); // a spec spec - "specification" it ('should be load page and title', function () {// load page, then call function () return driver.url ('https://www.tlkeith.com/WebDriverIOTutorialTest.html ') // obté el títol i, a continuació, passa el títol a function ().getTitle (). després (function (title) {// verifica el títol (title).should.be.equal ("Web Driver IO - Tutorial Page Test "); // descomentari per a la depuració de la consola // console.log ('Títol de la pàgina actual:' + títol);});}); // un" ganxo "per executar-se després de totes les proves d'aquest bloc després (funció (fet) {driver.end (done);});});

Observacions:

  • Primer heu de notar que l’escriptura de prova està escrit en JAVASCRIPT (acaba en extensió.js).
  • L'estructura bàsica és gairebé idèntica per a tots els scripts de prova.

    • Comentaris de capçalera (//)
    • Biblioteques obligatòries
    • Opcions de configuració (opcional)
    • Ganxo: carrega el controlador del navegador
    • Suite de proves (descripció)
    • Especificacions de prova (poden ser moltes especificacions en una suite)
    • Ganxo: netejar
  • El conjunt de proves comença amb una funció de descripció que pren dos paràmetres:

    • Cadena: descripció del conjunt de proves

      • "Reviseu la pàgina per comprovar el verb"
      • "Verificar les operacions del botó d'opció"
    • funció: bloc de codi a executar

      describe ("Descripció del conjunt de proves", function () {});

  • El conjunt de proves contindrà una o més especificacions de prova (especificació)
  • Les especificacions comencen amb la funció que pren dos paràmetres:

    • Cadena: descripció de l'especificació de la prova
      • "Ha de ser correcte el text de l'enllaç i l'URL de l'enllaç"
      • "Ha de contenir un verb correcte (còpia)
    • funció: bloc de codi a executar
    • it (‘Descripció de l’especificació de la prova’, function () {});
  • Una especificació conté una o més expectatives que posen a prova l'estat del codi
  • S’anomenen afirmacions

    La biblioteca "hauria de" proporcionar les afirmacions

  • En gairebé tots els casos, haureu de localitzar un o més elements mitjançant un selector i, a continuació, realitzar alguna operació als elements.

    • Exemples:

      • Cerqueu text en una pàgina i verifiqueu-lo
      • Empleneu un formulari i envieu-lo
      • Verifiqueu el CSS d’un element

Vegem més de prop l’exemple amb comentaris

Carregueu les biblioteques necessàries: controlador web IO i hauria de.

// biblioteques necessàries

var webdriverio = require ('webdriverio'), should = require ('should');

Definiu el conjunt de proves. Aquesta suite es diu: "Prova de títol per al controlador web IO - Lloc web de la pàgina de prova de prova"

// un bloc o un script de prova

describe ("Títol de prova per al controlador web IO - Pàgina web de prova de tutoria", funció () {…});

Establiu el temps d'espera a 10 segons perquè l'script no s'espiri en carregar la pàgina.

// Estableix el temps d'espera a 10 segons

this.timeout (10000);

Enganxeu per carregar el controlador del navegador abans d'executar les "especificacions" de les especificacions. El controlador de Firefox es carrega en aquest exemple.

// enganxa per córrer abans de les proves

before (funció (fet) {// carregueu el controlador per al controlador del navegador = webdriverio.remote ({funcions desitjades: {nom del navegador: 'firefox'}}); controlador.init (fet);});

Definiu l'especificació de la prova.

// una especificació de prova: "especificació"

it ('s'hauria de carregar la pàgina i el títol correctes', funció () {…});

Carregueu la pàgina del lloc web

.url ('https://www.tlkeith.com/WebDriverIOTutorialTest.html')

Obteniu títol i, a continuació, passeu-lo a la funció ()

.getTitle (). then (function (title) {

… });

Verifiqueu el títol utilitzant la biblioteca should assertion.

(title).should.be.equal ("IO del controlador web - pàgina de prova del tutorial");

Enganxeu per deixar el controlador i netejar-lo quan hàgiu acabat.

// un "ganxo" per executar-se després de totes les proves d'aquest bloc

after (function (done) {driver.end (done);});

Pas 3: executeu l'script de prova

Executeu l'script de prova
Executeu l'script de prova
Executeu l'script de prova
Executeu l'script de prova

Ara vegem què fa el guió de prova quan s’executa.

Primer inicieu el servidor autònom Selenium:

  • Per a Windows utilitzeu la línia d'ordres (cmd):

    • java -jar
    • # java -jar selenium-server-standalone-2.46.0.jar
  • Per a Mac o Linux, obriu el terminal:

    • java -jar
    • $ java -jar selenium-server-standalone-2.46.0.jar
  • Vegeu la captura de pantalla anterior

A continuació, executeu l'script de prova:

  • Per a Windows utilitzeu la línia d'ordres (cmd):

    • moca
    • # mocha tutorial1.js
  • Per a Mac o Linux, obriu el terminal:

    • moca
    • $ mocha tutorial.js
  • Vegeu la captura de pantalla anterior

Llavors què va passar?

Mocha invoca l'script "tutorial1.js". El controlador va iniciar el navegador (Firefox), va carregar la pàgina i va verificar el títol.

Pas 4: Exemple de lloc web

Exemple de lloc web
Exemple de lloc web

Tots els exemples s’executen en aquest lloc.

El lloc web d'exemple es troba a: Web Driver IO Tutorial Test Page

Tots els scripts de prova es poden descarregar des de github.

Pas 5: exemples específics

Tot el codi està disponible a github: Web Driver IO Tutorial a github

  • Verifiqueu l'enllaç i el text de l'enllaç en una llista no ordenada: "linkTextURL1.js"

    • La llista no ordenada té un i l'enllaç és el quart element de la llista.
    • L'URL ha de ser "https://tlkeith.com/contact.html"

// Verifiqueu el text de l'enllaç de contacte amb nosaltres

it ('hauria de contenir text d'enllaç de contacte amb nosaltres', function () {return driver.getText ("// ul [@ id = 'mylist'] / li [4] / a"). then (function (link) {console.log ('Enllaç trobat:' + enllaç); (enllaç).should.equal ("Contacteu amb nosaltres");});}); // Verifiqueu-ne l'URL de contacte ("ha de contenir l'URL de contacte", funció () {return driver.getAttribute ("// ul [@ id = 'mylist'] / li [4] / a", "href").then (function (link) {(link).should.equal ("https://tlkeith.com/contact.html"); console.log ('URL trobada:' + link);});});

  • Verifiqueu el text sobre drets d'autor: "Copyright1.js"

    • El copyright es troba al peu de pàgina. Aquest exemple mostra dues maneres diferents de localitzar el text del copyright:

      • pel selector d'elements
      • mitjançant xpath com a selector d'elements

// Verifiqueu el text del copyright amb l'identificador com a selector d'elements

it ('hauria de contenir text de copyright', function () {return driver.getText ("# copyright"). then (function (link) {console.log ('Copyright found:' + link); (link).should. igual ("Tony Keith - tlkeith.com @ 2015 - Tots els drets reservats.");});}); // Verifiqueu el text de Copyright fent servir xpath com a selector d'elements ("ha de contenir text de Copyright", funció () {return driver.getText ("// peu de pàgina / centre / p"). Després (function (enllaç) {console.log ('Copyright trobat:' + enllaç); (enllaç).should.equal ("Tony Keith - tlkeith.com @ 2015 - Tots els drets reservats.");});});

  • Empleneu camps de formulari i envieu - "formFillSubmit1.js"

    • Empleneu el nom, el cognom i envieu-lo i espereu els resultats.
    • En aquest exemple es mostren 3 mètodes per omplir el camp d'entrada del nom:

      • per identificador
      • per xpath des de l'entrada
      • per xpath des de forma-> entrada
    • També mostra com esborrar un camp d'entrada

// Estableix el primer nom amb l'identificador a: Tony

it ('hauria d'establir el primer nom a Tony', function () {return driver.setValue ("# fname", "Tony").getValue ("# fname"). then (function (e) {(e)..be.equal ("Tony"); console.log ("Nom:" + e);});}); // Esborreu el nom amb id it ("hauria d'esborrar el nom", function () {return driver.clearElement ("# fname").getValue ("# fname"). Then (function (e) {(e).should.be.equal (""); console.log ("Nom:" + e);});}); // Estableix el primer nom amb xpath de l'entrada a: Tony it ('hauria de definir el nom a Tony', function () {return driver.setValue ("// input [@ name = 'fname']", "Tony").getValue ("// input [@ name = 'fname']"). then (function (e) {(e).should.be.equal ("Tony"); console.log ("First Name:" + e);});}); // Esborreu el nom amb xpath de l'entrada ("hauria d'esborrar el nom", funció () {return driver.clearElement ("// input [@ name = 'fname']").getValue ("// input [@ name = 'fname'] "). then (function (e) {(e).should.be.equal (" "); console.log (" First Name: "+ e);});}); // Estableix el primer nom amb xpath de formulari a: Tony it ('hauria de definir el nom a Tony', function () {return driver.setValue ("// form [@ id = 'search-form'] / input [1] "," Tony ").getValue (" // form [@ id = 'search-form'] / input [1] "). Then (function (e) {(e).should.be.equal ("Tony"); console.log ("Nom:" + e);});}); // Establiu el cognom amb id: Keith it ('hauria de definir el cognom a Keith', function () {return driver.setValue ("# lname", "Keith").getValue ("# lname"). (funció (e) {(e).should.be.equal ("Keith"); console.log ("Cognom:" + e);});}); // Envieu el formulari i espereu els resultats de la cerca. Envieu el formulari de cerca ');}).waitForVisible ("# search-results", 10000).then (function (e) {console.log (' Search Results Found ');});});

  • Feu clic al botó Mostra / Amaga i verifiqueu el text: "showHideVerify1.js"

    • El text es troba en un element mostrar / amagar. El botó controla l'estat.
    • Aquest exemple mostra:

      • Feu clic al botó per expandir-lo
      • Espereu que l'element sigui visible (ampliat)
      • Verifica el text (còpia)

// feu clic al botó "Més informació" i verifiqueu el text de l'element ampliat

it ('hauria de fer clic al botó més informació i verificar el text', function () {return driver.click ("# moreinfo"). then (function () {console.log ('Clicked More Info button');}).waitForVisible ("#collapseExample", 5000).getText ("// div [@ id = 'collapseExample'] / div"). then (function (e) {console.log ('Text:' + e); (e).should.be.equal ("Totes les coses bones van aquí!");});});

  • Validar els errors de camp del formulari: "formFieldValidation.js"

    • Utilitzeu scripts de prova per verificar que es produeixen missatges d’error correctes.
    • Aquest exemple mostra:

      Verifiqueu els missatges de text d'error i verifiqueu la ubicació (posició de la llista no ordenada)

it ('ha de contenir 5 errors: primer / últim / adreça / ciutat / estat', funció () {

return driver.getText ("// ul [@ class = 'alert alert-danger'] / li [1]"). then (function (e) {console.log ('Error found:' + e); (e).should.be.equal ('Introduïu el nom');}).getText ("// ul [@ class = 'alert alert-danger'] / li [2]"). then (function (e) {console.log ('Error trobat:' + e); (e).should.be.equal ('Introduïu el cognom');}).getText ("// ul [@ class = 'alert alert-danger '] / li [3] "). then (function (e) {console.log (' Error trobat: '+ e); (e).should.be.equal (' Introduïu l'adreça ');}). getText ("// ul [@ class = 'alert alert-danger'] / li [4]"). then (function (e) {console.log ('Error found:' + e); (e)..be.equal ('Si us plau introduïu ciutat');}).getText ("// ul [@ class = 'alert alert-danger'] / li [5]"). then (function (e) {console.log ('Error trobat:' + e); (e).should.be.equal ('Introduïu l'estat');}); });

  • Bucle de dades per validar l'enllaç / text / pàgina de l'URL - "LoopDataExample1.js"

    • En aquest exemple es mostra: Utilitzeu una matriu de dades JSON per emmagatzemar l'enllaç i el nom i, a continuació, iterar

      • Verifiqueu cada text i enllaç de l'URL
      • Feu clic a l'enllaç i carregueu la pàgina

// Enllaç de dades: enllaç i text

var linkArray = [{"link": "https://github.com/onewithhammer/WebDriverIOTutorial/blob/master/tutorial1.js", "name": "tutorial1.js"}, {"link": "https://github.com/onewithhammer/WebDriverIOTutorial/blob/master/linkTextURL1.js "," name ":" linkTextURL1.js "}, {" link ":" https://github.com/onewithhammer/WebDriverIOTutorial/blob/ master / copyright1.js "," name ":" copyright1.js "}, {" link ":" https://github.com/onewithhammer/WebDriverIOTutorial/blob/master/formFillSubmit1.js "," name ":" formFillSubmit1.js "}, {" link ":" https://github.com/onewithhammer/WebDriverIOTutorial/blob/master/showHideVerify1.js "," name ":" showHideVerify1.js "}, {" link ":" https://github.com/onewithhammer/WebDriverIOTutorial/blob/master/dynamicBrowser.js "," name ":" dynamicBrowser.js "}, {" link ":" https://github.com/onewithhammer/WebDriverIOTutorial/ blob / master / callbackPromise.js "," name ":" callbackPromise.js "}, {" link ":" https://github.com/onewithhammer/WebDriverIOTutorial/blob/master/debugExample1.js "," name ": "debu gExample1.js "}, {" link ":" https://github.com/onewithhammer/WebDriverIOTutorial/blob/master/formFieldValidation.js "," name ":" formFieldValidation.js "}, {" link ":" https://github.com/onewithhammer/WebDriverIOTutorial/blob/master/common/commonLib.js "," name ":" commonLib.js "}, {" link ":" https://github.com/onewithhammer/ WebDriverIOTutorial / blob / master / dataLoopExample1.js "," name ":" dataLoopExample1.js "}];…url ('https://www.tlkeith.com/WebDriverIOTutorialTest.html').getTitle (). then (function (title) {// verify title (title).should.be.equal ("Web Driver IO - Pàgina de prova de tutorial ");}) // trobeu l'URL.getAttribute ('a =' + d.name," href "). Then (function (link) {(link).should.equal (d.link); console.log ('URL trobat:' + d.link);}) // vés a la pàgina d'URL i comprova que existeix.click ('a =' + d.name).waitForVisible ("# js-repo-pjax- contenidor ", 10000).then (function () {console.log ('Github Page Found');});});});

  • Bucle de dades estàtiques per omplir camps de formulari: "loopDataExample2.js"

    • Aquest exemple mostra: Utilitzeu una matriu de dades JSON per emmagatzemar el nom / cognom

      • Cerqueu les dades per omplir els camps del formulari i, a continuació, envieu el formulari
      • Espereu la pàgina de resultats
      • Verifiqueu el nom / cognom a la pàgina de resultats

// matriu de dades - firstName i lastNamevar dataArray = [{"firstName": "Tony", "lastName": "Keith"}, {"firstName": "John", "lastName": "Doe"}, {"firstName ":" Jane "," lastName ":" Doe "}, {" firstName ":" Don "," lastName ":" Johnson "}];.. /www.tlkeith.com/WebDriverIOTutorialTest.html ').getTitle (). then (function (title) {// verify title (title).should.be.equal ("Web Driver IO - Tutorial Test Page");}).setValue ("# fname", d.firstName).getValue ("# fname"). then (function (e) {(e).should.be.equal (d.firstName); console.log ("First Nom: "+ e);}).setValue (" # lname ", d.lastName).getValue (" # lname "). Then (function (e) {(e).should.be.equal (d.lastName); console.log ("Cognom:" + e);}).submitForm ("# search-form"). then (function () {console.log ('Submit Search Form');}).waitForVisible ("# search-results", 10000).then (function () {console.log ('Result Page Found');}).getText ("// h1"). then (function (link) {console.log ('Text trobat:' + enllaç); (enllaç).should.equal ("Benvinguda" + d.firstName + "" + d.lastName + ".");});});});

  • Valideu les propietats CSS: "cssValidation1.js"

    • Aquest exemple mostra com:

      • Valideu les propietats CSS següents:

        • color
        • encoixinat (part superior, inferior, dreta, esquerra)
        • color de fons

it ('ha de contenir el color correcte del text d'error', function () {return driver.getCssProperty ("// ul [@ class = 'alert alert-danger'] / li [1]", "color"). then (function (result) {console.log ('Color found:' + result.parsed.hex + "or" + result.value); (result.parsed.hex).should.be.equal ('# a94442'); });});

it ('ha de contenir un farcit correcte a la cel·la de la taula', function () {

return driver // padding: top right bottom left left.getCssProperty ("// table [@ id = 'filelist'] / thead / tr [1] / td [1]", "padding-top"). then (function (result) {console.log ('padding-top found:' + result.value); (result.value).should.be.equal ('10px');}).getCssProperty ("// table [@ id = 'filelist'] / thead / tr [1] / td [1] "," padding-bottom "). then (function (result) {console.log ('padding-bottom found:' + result.value); (result.value).should.be.equal ('10px');}).getCssProperty ("// table [@ id = 'filelist'] / thead / tr [1] / td [1]", "padding- right "). then (function (result) {console.log ('padding-right found:' + result.value); (result.value).should.be.equal ('5px');}).getCssProperty ("// table [@ id = 'filelist'] / thead / tr [1] / td [1]", "padding-left"). then (function (result) {console.log ('padding-left found: '+ result.value); (result.value).should.be.equal (' 5px ');}); });

it ('ha de contenir el color de fons correcte a la capçalera de la taula', function () {

return driver.getCssProperty ("// table [@ id = 'filelist'] / thead", "background-color"). then (function (result) {console.log ('background color found:' + result.parsed. hex); (result.parsed.hex).should.be.equal ('# eeeeee');}); });

Pas 6: consells i trucs

Consells i trucs
Consells i trucs
  • Depuració:

    • Activeu el registre al nivell del controlador per obtenir més depuració i crear registres.

      • Estableix el nivell de registre a "detallat"
      • Estableix logOutput al nom del directori ('logs')

controlador = webdriverio.remote (loglevel: 'detallat', logOutput: 'registres', {desitjatCapacitats: {browserName: 'firefox'}});

  • Utilitzeu console.log (), debug (), getText () per depurar.

    • console.log (): s'utilitza per mostrar informació per determinar l'estat.
    • debug (): utilitzeu una pausa del navegador / script fins que premeu Enter a la línia d'ordres.
    • getText (): utilitzeu-lo per verificar que interactueu amb l'element correcte.

      Especialment útil amb expressions xpath

// Feu clic a l'element 3 de la llista

it ('hauria de fer clic a l'element 3 de la llista', function () {// use getText () per verificar si xpath és correcte per al controlador de retorn de l'element.getText ("// ul [@ id = 'mylist'] / li [3] / div / div / a "). Then (function (link) {// use console.log () to output information console.log ('Link found:' + link); (link).should.equal ("Element 3");}) // utilitzeu debug () per aturar l'acció per veure què passa al navegador.debug ().click ("// ul [@ id = 'mylist'] / li [3] /div/div/a").then (function () {console.log ('Enllaç fet clic');}) // espera que aparegui el formulari de cerca de google.waitForVisible ("# tsf", 20000).then (function (e) {console.log ('resultats de la cerca trobats');});});

  • Utilitzeu la variable d'entorn per canviar dinàmicament el navegador:

    • Utilitzeu la variable d'entorn SELENIUM_BROWSER per invocar un navegador diferent sense modificar l'script de prova cada vegada.
    • Cal suportar un lleuger canvi de codificació.

Canvis de codi:

// carregueu el controlador per al navegador

controlador = webdriverio.remote ({desitjatCapacitats: {browserName: process.env. SELENIUM_BROWSER || 'chrome'}});

Navegadors compatibles:

  • Internet Explorer - IE 8+ (només per a Windows)

    SELENIUM_BROWSER = és a dir, moca

  • Firefox 10+ (Windows / Max / Linux)

    SELENIUM_BROWSER = moka de Firefox

  • Chrome 12+ (Windows / Max / Linux)

    SELENIUM_BROWSER = moka cromada

  • 12pera 12+

    SELENIUM_BROWSER = opera mocha

  • Safari

    SELENIUM_BROWSER = safata mocha

Proves:

  • Per a Windows, utilitzeu git bash shell:

    • SELENIUM_BROWSER = moka cromada
    • $ SELENIUM_BROWSER = Chrome moca DynamicBrowser.js
  • Per a Mac o Linux, obriu el terminal:

    • SELENIUM_BROWSER = moka cromada
    • $ SELENIUM_BROWSER = croma moca DynamicBrowser.js
  • Proves responsives:

    • Determineu els punts d'interrupció basats en el projecte o el marc (és a dir, bootstrap).
    • Definiu les variables d'entorn per a cada punt d'interrupció:

      • DESKTOP - 1200 px
      • TAULETA: 992 px
      • M MOBBIL: 768 px
    • Desenvolupeu una ordre reutilitzable per llegir la variable d'entorn i definir la mida del navegador.

      Vegeu l'exemple següent

    • Truqueu a l'ordre reutilitzable al vostre script de prova.

// codi reutilitzable - biblioteca // fragment de codi if (bp == "DESKTOP") {obj.width = 1200; obj.height = 600; obj.name = bp; } else if (bp == "TABLET") {obj.width = 992; obj.height = 600; obj.name = bp; } else if (bp == "MILEBIL") {obj.width = 768; obj.height = 400; obj.name = bp; }

// Prova de guió

before (function (done) {winsize = common.getWindowSizeParams ();… driver.addCommand ('setWindowSize', common.setWindowSize.bind (driver));} // defineix la mida de la finestra it ('hauria de definir la mida de la finestra', function (fet) {// només importa l'amplada driver.setWindowSize (winsize.width, winsize.height, function () {}). call (fet);});

  • Ordres reutilitzables (ordres personalitzades):

    • El controlador web IO es pot ampliar fàcilment.
    • M'agrada posar totes les ordres reutilitzables en una biblioteca. (potser aquesta és la vella escola, però funciona!)

common / commonLib.js

// verifyLastNameCheckError ()

// // Descripció: // Verifica el missatge d'error de validació del formulari de cognom // // Entrada: // número - índex d'error (1-5) // Sortida: // cap // var verifyLastNameCheckError = function () { var idx = arguments [0], devolució de trucada = arguments [arguments.length - 1]; aquest.getText ("// ul [@ class = 'alert alert-danger'] / li [" + idx + "]", funció (err, e) {console.log ('Error trobat:' + e); (e).should.be.equal ("Introduïu el cognom");}).call (devolució de trucada); }; // exporta la funció module.exports.verifyLastNameCheckError = verificaLastNameCheckError;

Aquests són els canvis específics necessaris per cridar a una funció reutilitzable

Consulteu formFieldValidation.js per obtenir un exemple de treball complet

// requereixen l'ordre reutilitzable - CommonLib

common = require ('./ Common / CommonLib'); … // lliga les ordres driver.addCommand ('verifyFirstNameError', common.verifyFirstNameCheckError.bind (controlador)); driver.addCommand ('verifyLastNameError', common.verifyLastNameCheckError.bind (controlador)); it ('ha de contenir 2 errors: nom / cognom', function () {// trucar al controlador de funció reutilitzable.verifyFirstNameError (1);.verifyLastNameError (2);});

  • Estructura del fitxer / directori del projecte:

    • Aquí teniu l'estructura típica del projecte:

      • "Projecte": directori principal del projecte

        • README.md: llegeix-me per a un projecte global
        • "Comú": directori per a funcions globals comuns a tots els projectes

          • common-lib.js: biblioteca de funcions globals
          • README.md: readme per a funcions globals
        • "Producte1": directori del producte 1

          • test-script1.js
          • test-script2.js
          • "Comú": directori per a funcions locals al projecte 1

            • prod1-lib.js: biblioteca de funcions locals per al projecte 1
            • README.md: readme per a funcions locals per al projecte 1
        • "Producte2": directori del producte 2test-script1.jstest-script2.js

          • "Comú": directori per a funcions locals al projecte 2

            • prod2-lib.js: biblioteca de funcions locals per al projecte 2
            • README.md: llegeix-me perquè les funcions locals es projectin 2
  • Divideix els scripts de prova en diversos fitxers:

    • Aquí teniu una mostra de l’ús de diversos fitxers:

      • Sanity Check: script bàsic de prova per verificar que tot funciona
      • Element estàtic i validació de text: verifiqueu tots els elements i el text
      • Validació d'errors de formulari / pàgina: validació d'errors
      • Resultats de la cerca: proveu contingut dinàmic
  • Devolucions de trucada VS. Promeses:

    • La versió 3 de Web Driver IO admet devolucions de trucades i promeses.

      Les promeses són el mètode preferit, ja que redueix el codi de gestió d'errors. Vegeu a continuació el mateix exemple escrit amb devolucions de trucada i promeses.

Devolucions de trucada

// Configureu / verifiqueu el nom / cognom mitjançant la devolució de trucada

it ('hauria d'establir / verificar el nom / cognom mitjançant les devolucions de trucada', funció (fet) {driver.setValue ("# fname", "Tony", function (e) {driver.getValue ("# fname", function (err, e) {(e).should.be.equal ("Tony"); console.log ("Nom:" + e); driver.setValue ("# lname", "Keith", funció (e) { driver.getValue ("# lname", function (err, e) {(e).should.be.equal ("Keith"); console.log ("Last Name:" + e); done ();});});});});});

Promeses

// Configureu / verifiqueu el nom / cognom amb Promeses

it ('hauria d'establir / verificar el nom / cognom mitjançant Promeses', function () {return driver.setValue ("# fname", "Tony").getValue ("# fname"). then (function (e) {(e).should.be.equal ("Tony"); console.log ("Nom:" + e);}).setValue ("# lname", "Keith").getValue ("# lname"). then (function (e) {(e).should.be.equal ("Keith"); console.log ("Cognom:" + e);});});

Pas 7: Més recursos

Aquí teniu alguns recursos addicionals per a la vostra referència:

  • Grups de discussió (Gitter)

    • Web Driver IO Discussion Group
    • Grup de debat Mocha
  • Altres projectes interessants

    • Supertest: afirmacions
    • Chai - afirmacions

Pas 8: Conclusió

Vaig dedicar un temps a investigar les tecnologies que heu d’utilitzar per al meu projecte. Originalment vaig començar amb Selenium Web Driver, però vaig passar a utilitzar Web Driver IO. El controlador web IO semblava ser més fàcil d'utilitzar i molt més fàcil d'estendre (almenys la documentació per ampliar - les ordres reutilitzables era millor).

Quan vaig començar a mirar les tecnologies, era difícil trobar bons exemples que fossin relatius a qualsevol cosa que intentés fer. Aquesta és la raó per la qual volia compartir aquesta informació i coneixements amb vosaltres.

Les tecnologies funcionaven molt millor del que esperava, però hi havia una corba d'aprenentatge. Un cop vaig entendre com funcionaven tots els components junts, vaig poder escriure scripts de prova complicats en molt poc temps. Els scripts més difícils eren components basats en JavaScript, com ara un selector de dates i selectors modals.

Mai no m'he etiquetat com a desenvolupador de JavaScript ni volia ser expert en JavaScript, però l'ús d'aquestes tecnologies m'ha motivat definitivament a millorar les meves habilitats en JS.

Espero que aquest article sigui útil i els exemples siguin clars i informatius.

Feu-me saber si teniu cap pregunta o comentari.

Gràcies, Tony Keith

Recomanat: