Rapporteur - Rapporteur et serveur de sélénium

Comme indiqué précédemment, Protractor est un cadre de test open source de bout en bout pour les applications Angular et AngularJS. C'est le programme Node.js. D'autre part, Selenium est un cadre d'automatisation de navigateur qui comprend le serveur Selenium, les API WebDriver et les pilotes de navigateur WebDriver.

Rapporteur avec sélénium

Si nous parlons de la conjonction de Protractor et Selenium, Protractor peut travailler avec le serveur Selenium pour fournir une infrastructure de test automatisée. L'infrastructure peut simuler l'interaction de l'utilisateur avec une application angulaire qui s'exécute dans un navigateur ou sur un appareil mobile. La conjonction de Protractor et Selenium peut être divisée en trois partitions à savoir test, serveur et navigateur, comme indiqué dans le diagramme suivant -

Processus Selenium WebDriver

Comme nous l'avons vu dans le diagramme ci-dessus, un test utilisant Selenium WebDriver implique les trois processus suivants -

  • Les scripts de test
  • Le serveur
  • Le navigateur

Dans cette section, parlons de la communication entre ces trois processus.

Communication entre les scripts de test et le serveur

La communication entre les deux premiers processus - les scripts de test et le serveur dépend du fonctionnement de Selenium Server. En d'autres termes, nous pouvons dire que la façon dont le serveur Selenium fonctionne donnera une forme au processus de communication entre les scripts de test et le serveur.

Le serveur Selenium peut fonctionner localement sur notre machine en tant que serveur Selenium autonome (selenium-server-standalone.jar) ou il peut fonctionner à distance via un service (Sauce Labs). Dans le cas d'un serveur Selenium autonome, il y aurait une communication http entre Node.js et le serveur Selenium.

Communication entre le serveur et le navigateur

Comme nous savons que le serveur est responsable de la transmission des commandes au navigateur après les avoir interprétées à partir des scripts de test. C'est pourquoi le serveur et le navigateur nécessitent également un moyen de communication et ici la communication se fait à l'aide deJSON WebDriver Wire Protocol. Le navigateur étendu avec le pilote de navigateur utilisé pour interpréter les commandes.

Le concept ci-dessus sur les processus Selenium WebDriver et leur communication peut être compris à l'aide du diagramme suivant -

Tout en travaillant avec Protractor, le tout premier processus, c'est-à-dire le script de test, est exécuté à l'aide de Node.js, mais avant d'effectuer une action sur le navigateur, il enverra une commande supplémentaire pour s'assurer que l'application testée est stabilisée.

Configuration du serveur Selenium

Selenium Server agit comme un serveur proxy entre notre script de test et le pilote du navigateur. Il transmet essentiellement la commande de notre script de test au WebDriver et renvoie les réponses du WebDriver à notre script de test. Les options suivantes pour configurer le serveur Selenium sont incluses dansconf.js fichier de script de test -

Serveur Selenium autonome

Si nous voulons exécuter le serveur sur notre machine locale, nous devons installer un serveur sélénium autonome. La condition préalable à l'installation d'un serveur sélénium autonome est JDK (Java Development Kit). Nous devons avoir JDK installé sur notre machine locale. Nous pouvons le vérifier en exécutant la commande suivante à partir de la ligne de commande -

java -version

Maintenant, nous avons la possibilité d'installer et de démarrer Selenium Server manuellement ou à partir d'un script de test.

Installation et démarrage du serveur Selenium manuellement

Pour installer et démarrer manuellement le serveur Selenium, nous devons utiliser l'outil de ligne de commande WebDriver-Manager fourni avec Protractor. Les étapes d'installation et de démarrage du serveur Selenium sont les suivantes:

Step 1- La première étape consiste à installer le serveur Selenium et ChromeDriver. Cela peut être fait à l'aide de l'exécution de la commande suivante -

webdriver-manager update

Step 2- Ensuite, nous devons démarrer le serveur. Cela peut être fait à l'aide de l'exécution de la commande suivante -

webdriver-manager start

Step 3- Enfin, nous devons définir seleniumAddress dans le fichier de configuration à l'adresse du serveur en cours d'exécution. L'adresse par défaut seraithttp://localhost:4444/wd/hub.

Démarrage du serveur Selenium à partir d'un script de test

Pour démarrer le serveur Selenium à partir d'un script de test, nous devons définir les options suivantes dans notre fichier de configuration -

  • Location of jar file - Nous devons définir l'emplacement du fichier jar pour le serveur Selenium autonome dans le fichier de configuration en définissant seleniumServerJar.

  • Specifying the port- Nous devons également spécifier le port à utiliser pour démarrer le serveur Selenium autonome. Il peut être spécifié dans le fichier de configuration en définissant seleniumPort. Le port par défaut est 4444.

  • Array of command line options- Nous devons également définir le tableau des options de ligne de commande à transmettre au serveur. Il peut être spécifié dans le fichier de configuration en définissant seleniumArgs. Si vous avez besoin de la liste complète du tableau de commandes, démarrez le serveur avec le-help drapeau.

Utilisation du serveur Selenium distant

Une autre option pour exécuter notre test consiste à utiliser le serveur Selenium à distance. La condition préalable pour utiliser le serveur à distance est que nous devons avoir un compte avec un service qui héberge le serveur. Tout en travaillant avec Protractor, nous avons le support intégré pour les services suivants hébergeant le serveur -

TestObject

Pour utiliser TestObject comme serveur Selenium distant, nous devons définir le testobjectUser, le nom d'utilisateur de notre compte TestObject et testobjectKey, la clé API de notre compte TestObject.

BrowserStack

Pour utiliser BrowserStack comme serveur Selenium distant, nous devons définir le BrowserStackUser, le nom d'utilisateur de notre compte BrowserStack et browsererstackKey, la clé API de notre compte BrowserStack.

Laboratoires de sauce

Pour utiliser Sauce Labs comme serveur Selenium distant, nous devons définir la sauceUser, le nom d'utilisateur de notre compte Sauce Labs et SauceKey, la clé API de notre compte Sauce Labs.

Kobiton

Pour utiliser Kobiton comme serveur Selenium distant, nous devons définir le kobitonUser, le nom d'utilisateur de notre compte Kobiton et kobitonKey, la clé API de notre compte Kobiton.

Connexion directe au pilote de navigateur sans utiliser Selenium Server

Une autre option pour exécuter notre test consiste à se connecter directement au pilote du navigateur sans utiliser le serveur Selenium. Protractor peut tester directement, sans utiliser Selenium Server, contre Chrome et Firefox en définissant directConnect: true dans le fichier de configuration.

Configuration du navigateur

Avant de configurer et de configurer le navigateur, nous devons savoir quels navigateurs sont pris en charge par Protractor. Voici la liste des navigateurs pris en charge par Protractor -

  • ChromeDriver
  • FirefoxDriver
  • SafariDriver
  • IEDriver
  • Appium-iOS/Safari
  • Appium-Android/Chrome
  • Selendroid
  • PhantomJS

Pour définir et configurer le navigateur, nous devons nous déplacer vers le fichier de configuration de Protractor car la configuration du navigateur est effectuée dans l'objet de capacités du fichier de configuration.

Configurer Chrome

Pour configurer le navigateur Chrome, nous devons définir l'objet de capacités comme suit

capabilities: {
   'browserName': 'chrome'
}

Nous pouvons également ajouter des options spécifiques à Chrome qui sont imbriquées dans chromeOptions et sa liste complète peut être consultée à l'adresse https://sites.google.com/a/chromium.org/chromedriver/capabilities.

Par exemple, si vous souhaitez ajouter un compteur FPS en haut à droite, vous pouvez le faire comme suit dans le fichier de configuration -

capabilities: {
   'browserName': 'chrome',
   'chromeOptions': {
      'args': ['show-fps-counter=true']
   }
},

Configurer Firefox

Pour configurer le navigateur Firefox, nous devons définir l'objet de capacités comme suit -

capabilities: {
   'browserName': 'firefox'
}

Nous pouvons également ajouter des options spécifiques à Firefox qui sont imbriquées dans l'objet moz: firefoxOptions et sa liste complète peut être consultée sur https://github.com/mozilla/geckodriver#firefox-capabilities.

Par exemple, si vous souhaitez exécuter votre test sur Firefox en mode sans échec, cela peut être fait comme suit dans le fichier de configuration -

capabilities: {
   'browserName': 'firefox',
   'moz:firefoxOptions': {
     'args': ['—safe-mode']
   }
},

Configurer un autre navigateur

Pour configurer tout autre navigateur que Chrome ou Firefox, nous devons installer un binaire distinct de https://docs.seleniumhq.org/download/.

Configurer PhantonJS

En fait, PhantomJS n'est plus pris en charge en raison de ses problèmes de plantage. Au lieu de cela, il est recommandé d'utiliser Chrome sans tête ou Firefox sans tête. Ils peuvent être configurés comme suit -

Pour configurer Chrome sans tête, nous devons démarrer Chrome avec l'indicateur "headless" comme suit -

capabilities: {
   'browserName': 'chrome',
   'chromeOptions': {
      'args': [“--headless”, “--disable-gpu”, “--window-size=800,600”]
   }
},

Pour configurer Firefox sans tête, nous devons démarrer Firefox avec le –headless drapeau comme suit -

capabilities: {
   'browserName': 'firefox',
   'moz:firefoxOptions': {
      'args': [“--headless”]
   }
},

Configuration de plusieurs navigateurs pour les tests

Nous pouvons également tester contre plusieurs navigateurs. Pour cela, nous devons utiliser l'option de configuration multiCapabilities comme suit -

multiCapabilities: [{
   'browserName': 'chrome'
},{
   'browserName': 'firefox'
}]

Quel cadre?

Deux frameworks de test BDD (Behavior driven development), Jasmine et Mocha, sont pris en charge par Protractor. Les deux frameworks sont basés sur JavaScript et Node.js. La syntaxe, le rapport et l'échafaudage, nécessaires à l'écriture et à la gestion des tests, sont fournis par ces frameworks.

Ensuite, nous voyons comment nous pouvons installer divers frameworks -

Cadre de jasmin

Il s'agit du cadre de test par défaut pour Protractor. Lorsque vous installez Protractor, vous obtiendrez la version Jasmine 2.x avec. Nous n'avons pas besoin de l'installer séparément.

Cadre Mocha

Mocha est un autre framework de test JavaScript fonctionnant essentiellement sur Node.js. Pour utiliser Mocha comme cadre de test, nous devons utiliser l'interface BDD (Behavior driven development) et les assertions Chai avec Chai As Promised. L'installation peut être effectuée à l'aide des commandes suivantes -

npm install -g mocha
npm install chai
npm install chai-as-promised

Comme vous pouvez le voir, l'option -g est utilisée lors de l'installation de mocha, c'est parce que nous avons installé Protractor globalement en utilisant l'option -g. Après l'avoir installé, nous devons exiger et configurer Chai dans nos fichiers de test. Cela peut être fait comme suit -

var chai = require('chai');
var chaiAsPromised = require('chai-as-promised');
chai.use(chaiAsPromised);
var expect = chai.expect;

Après cela, nous pouvons utiliser Chai comme promis en tant que tel -

expect(myElement.getText()).to.eventually.equal('some text');

Maintenant, nous devons définir la propriété du framework sur mocha du fichier de configuration en ajoutant le framework: 'mocha'. Les options comme 'reporter' et 'slow' pour mocha peuvent être ajoutées dans le fichier de configuration comme suit -

mochaOpts: {
   reporter: "spec", slow: 3000
}

Cadre de concombre

Pour utiliser Cucumber comme cadre de test, nous devons l'intégrer à Protractor avec l'option de cadre custom. L'installation peut être effectuée à l'aide des commandes suivantes

npm install -g cucumber
npm install --save-dev protractor-cucumber-framework

Comme vous pouvez le voir, l'option -g est utilisée lors de l'installation de Cucumber, c'est parce que nous avons installé Protractor globalement c'est-à-dire avec l'option -g. Ensuite, nous devons définir la propriété du framework surcustom du fichier de configuration en ajoutant framework: 'custom' et frameworkPath: 'Protractor-cucumber-framework' au fichier de configuration nommé cucumberConf.js.

L'exemple de code ci-dessous est un fichier cucumberConf.js de base qui peut être utilisé pour exécuter des fichiers de fonctionnalités de concombre avec Protractor -

exports.config = {
   seleniumAddress: 'http://localhost:4444/wd/hub',

   baseUrl: 'https://angularjs.org/',

   capabilities: {
      browserName:'Firefox'
   },

   framework: 'custom',

   frameworkPath: require.resolve('protractor-cucumber-framework'),

   specs: [
      './cucumber/*.feature'
   ],

   // cucumber command line options
   cucumberOpts: {
      require: ['./cucumber/*.js'],
      tags: [],
      strict: true,
      format: ["pretty"],
      'dry-run': false,
      compiler: []
   },
   onPrepare: function () {
      browser.manage().window().maximize();
   }
};