Busur derajat - Benda

Bab ini membahas secara detail tentang objek-objek di Busur derajat.

Apa itu Objek Halaman?

Objek halaman adalah pola desain yang telah menjadi populer untuk menulis tes e2e untuk meningkatkan pemeliharaan tes dan mengurangi duplikasi kode. Ini dapat didefinisikan sebagai kelas berorientasi objek yang berfungsi sebagai antarmuka ke halaman AUT Anda (aplikasi yang sedang diuji). Namun, sebelum mendalami objek halaman, kita harus memahami tantangan dengan pengujian UI otomatis dan cara menanganinya.

Tantangan dengan pengujian UI otomatis

Berikut adalah beberapa tantangan umum dengan pengujian UI otomatis -

Perubahan UI

Masalah yang paling umum saat bekerja dengan pengujian UI adalah perubahan yang terjadi di UI. Misalnya, ini sering terjadi ketika tombol atau kotak teks, dll. Biasanya berubah dan menimbulkan masalah untuk pengujian UI.

Kurangnya dukungan DSL (Domain Specific Language)

Masalah lain dengan pengujian UI adalah kurangnya dukungan DSL. Dengan masalah ini, menjadi sangat sulit untuk memahami apa yang sedang diuji.

Banyak pengulangan / duplikasi Kode

Masalah umum berikutnya dalam pengujian UI adalah banyaknya pengulangan atau duplikasi kode. Ini dapat dipahami dengan bantuan baris kode berikut -

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

Perawatan yang sulit

Karena tantangan di atas, perawatannya jadi pusing. Itu karena kita harus mencari semua instance, ganti dengan nama baru, selector & kode lain. Kami juga perlu menghabiskan banyak waktu untuk menjaga agar pengujian sejalan dengan pemfaktoran ulang.

Tes rusak

Tantangan lain dalam pengujian UI adalah terjadinya banyak kegagalan dalam pengujian.

Cara Menangani Tantangan

Kami telah melihat beberapa tantangan umum dalam pengujian UI. Beberapa cara untuk menangani tantangan tersebut adalah sebagai berikut -

Memperbarui Referensi Secara Manual

Opsi pertama untuk menangani tantangan di atas adalah memperbarui referensi secara manual. Masalah dengan opsi ini adalah kita harus melakukan perubahan manual pada kode serta pengujian kita. Ini dapat dilakukan ketika Anda memiliki satu atau dua file tes tetapi bagaimana jika Anda memiliki ratusan file tes dalam sebuah proyek?

Menggunakan Objek Halaman

Pilihan lain untuk menangani tantangan di atas adalah menggunakan objek halaman. Objek halaman pada dasarnya adalah JavaScript biasa yang merangkum properti template Angular. Misalnya, file spesifikasi berikut ditulis tanpa dan dengan objek halaman untuk memahami perbedaannya -

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

Untuk menulis kode dengan Objek Halaman, hal pertama yang perlu kita lakukan adalah membuat Objek Halaman. Karenanya, Objek Halaman untuk contoh di atas bisa terlihat seperti ini -

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();

Menggunakan Objek Halaman untuk Mengatur Tes

Kami telah melihat penggunaan objek halaman pada contoh di atas untuk menangani tantangan pengujian UI. Selanjutnya, kita akan membahas bagaimana kita dapat menggunakannya untuk mengatur tes. Untuk ini kita perlu memodifikasi skrip uji tanpa mengubah fungsionalitas skrip uji.

Contoh

Untuk memahami konsep ini kita mengambil file konfigurasi di atas dengan objek halaman. Kita perlu memodifikasi skrip pengujian sebagai berikut -

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!');
   });
});

Di sini, perhatikan bahwa jalur ke objek halaman akan sesuai dengan spesifikasi Anda.

Pada catatan yang sama, kami juga dapat memisahkan rangkaian pengujian kami ke dalam berbagai rangkaian pengujian. File konfigurasi kemudian dapat diubah sebagai berikut

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.
   }
};

Sekarang, kita dapat dengan mudah beralih antara menjalankan satu atau rangkaian pengujian lainnya. Perintah berikut hanya akan menjalankan bagian beranda pengujian -

protractor protractor.conf.js --suite homepage

Demikian pula, kita dapat menjalankan rangkaian pengujian tertentu dengan perintah sebagai berikut -

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