Rapporteur - Objets

Ce chapitre traite en détail des objets dans Protractor.

Que sont les objets de page?

L'objet de page est un modèle de conception qui est devenu populaire pour écrire des tests e2e afin d'améliorer la maintenance des tests et de réduire la duplication de code. Elle peut être définie comme une classe orientée objet servant d'interface à une page de votre AUT (application en test). Mais, avant de plonger profondément dans les objets de page, nous devons comprendre les défis liés aux tests d'interface utilisateur automatisés et les moyens de les gérer.

Les défis des tests d'interface utilisateur automatisés

Voici quelques défis courants liés aux tests d'interface utilisateur automatisés -

Modifications de l'interface utilisateur

Les problèmes très courants lors de l'utilisation des tests d'interface utilisateur sont les modifications apportées à l'interface utilisateur. Par exemple, il arrive la plupart du temps que les boutons ou les zones de texte, etc., soient généralement modifiés et créent des problèmes pour les tests de l'interface utilisateur.

Manque de prise en charge DSL (Domain Specific Language)

Un autre problème avec les tests d'interface utilisateur est le manque de prise en charge DSL. Avec ce problème, il devient très difficile de comprendre ce qui est testé.

Beaucoup de répétition / duplication de code

Le prochain problème courant dans les tests d'interface utilisateur est qu'il y a beaucoup de répétition ou de duplication de code. Il peut être compris à l'aide des lignes de code suivantes -

element(by.model(‘event.name’)).sendKeys(‘An Event’);
element(by.model(‘event.name’)).sendKeys(‘Module 3’);
element(by.model(‘event.name’));

Entretien difficile

En raison des défis ci-dessus, cela devient un casse-tête pour la maintenance. C'est parce que nous devons trouver toutes les instances, les remplacer par le nouveau nom, le sélecteur et tout autre code. Nous devons également passer beaucoup de temps pour maintenir les tests en ligne avec la refactorisation.

Tests cassés

Un autre défi dans les tests d'interface utilisateur est la survenue de nombreux échecs dans les tests.

Façons de gérer les défis

Nous avons vu certains défis courants des tests d'interface utilisateur. Voici quelques-unes des façons de relever ces défis:

Mise à jour manuelle des références

La toute première option pour gérer les défis ci-dessus est de mettre à jour les références manuellement. Le problème avec cette option est que nous devons faire la modification manuelle du code ainsi que nos tests. Cela peut être fait lorsque vous avez un ou deux fichiers de tests, mais que faire si vous avez des centaines de fichiers de tests dans un projet?

Utilisation des objets de page

Une autre option pour gérer les défis ci-dessus consiste à utiliser des objets de page. Un objet de page est essentiellement un JavaScript simple qui encapsule les propriétés d'un modèle angulaire. Par exemple, le fichier de spécification suivant est écrit sans et avec des objets de page pour comprendre la différence -

Without Page Objects

describe('angularjs homepage', function() {
   it('should greet the named user', function() {
      browser.get('http://www.angularjs.org');
      element(by.model('yourName')).sendKeys('Julie');
      var greeting = element(by.binding('yourName'));
      expect(greeting.getText()).toEqual('Hello Julie!');
   });
});

With Page Objects

Pour écrire le code avec des objets de page, la première chose que nous devons faire est de créer un objet de page. Par conséquent, un objet de page pour l'exemple ci-dessus pourrait ressembler à ceci -

var AngularHomepage = function() {
   var nameInput = element(by.model('yourName'));
   var greeting = element(by.binding('yourName'));

   this.get = function() {
      browser.get('http://www.angularjs.org');
   };

   this.setName = function(name) {
      nameInput.sendKeys(name);
   };
   
   this.getGreetingText = function() {
      return greeting.getText();
   };
};
module.exports = new AngularHomepage();

Utilisation d'objets de page pour organiser les tests

Nous avons vu l'utilisation d'objets de page dans l'exemple ci-dessus pour gérer les défis des tests d'interface utilisateur. Ensuite, nous allons discuter de la manière dont nous pouvons les utiliser pour organiser les tests. Pour cela, nous devons modifier le script de test sans modifier la fonctionnalité du script de test.

Exemple

Pour comprendre ce concept, nous prenons le fichier de configuration ci-dessus avec des objets de page. Nous devons modifier le script de test comme suit -

var angularHomepage = require('./AngularHomepage');
describe('angularjs homepage', function() {
   it('should greet the named user', function() {
      angularHomepage.get();

      angularHomepage.setName('Julie');
   
      expect(angularHomepage.getGreetingText()).toEqual
      ('Hello Julie!');
   });
});

Ici, notez que le chemin d'accès à l'objet de page sera relatif à votre spécification.

Sur la même note, nous pouvons également séparer notre suite de tests en plusieurs suites de tests. Le fichier de configuration peut alors être modifié comme suit

exports.config = {
   // The address of a running selenium server.
   seleniumAddress: 'http://localhost:4444/wd/hub',

   // Capabilities to be passed to the webdriver instance.
   capabilities: {
      'browserName': 'chrome'
   },
   // Spec patterns are relative to the location of the spec file. They may
   // include glob patterns.
   suites: {
      homepage: 'tests/e2e/homepage/**/*Spec.js',
      search: ['tests/e2e/contact_search/**/*Spec.js',
         'tests/e2e/venue_search/**/*Spec.js']
   },

   // Options to be passed to Jasmine-node.
   jasmineNodeOpts: {
      showColors: true, // Use colors in the command line report.
   }
};

Désormais, nous pouvons facilement basculer entre l'exécution de l'une ou l'autre suite de tests. La commande suivante exécutera uniquement la section de la page d'accueil du test -

protractor protractor.conf.js --suite homepage

De même, nous pouvons exécuter des suites spécifiques de tests avec la commande comme suit -

protractor protractor.conf.js --suite homepage,search