Puppeteer ile Web Bluetooth'u test et

François Beaufort
François Beaufort

Web Bluetooth, Chrome 56'dan beri desteklenmektedir ve geliştiricilerin doğrudan kullanıcıların Bluetooth cihazlarıyla iletişim kuran web uygulamaları yazmasına olanak tanır. Espruino web düzenleyicisinin uyumlu Bluetooth cihazlara kod yükleyebilmesi bu tür bir örnektir. Bu uygulamaları artık Puppeteer ile test edebilirsiniz.

Bu blog yayınında, Bluetooth özellikli bir web uygulamasını çalıştırmak ve test etmek için Puppeteer'ın nasıl kullanılacağı açıklanmaktadır. Bunun en önemli kısmı, Puppeteer'ın Chrome'un Bluetooth cihaz seçicisini çalıştırma özelliğidir.

Chrome'da Web Bluetooth'u kullanma hakkında bilginiz yoksa aşağıdaki videoda Espruino web düzenleyicisindeki Bluetooth istemi gösterilmektedir:

Kullanıcı, Espruino web düzenleyicisinde bir Puck.js Bluetooth cihazı seçer.

Bu blog yayınını takip etmek için Bluetooth özellikli bir web uygulamasına, bu uygulamayla iletişim kurabilecek bir Bluetooth cihaza ve Puppeteer v21.4.0 veya sonraki bir sürümüne ihtiyacınız vardır.

Tarayıcıyı başlatma

Çoğu Puppeteer komut dosyasında olduğu gibi, Puppeteer.launch() ile tarayıcıyı başlatarak başlayın. Bluetooth özelliklerine erişmek için birkaç ek bağımsız değişken sağlamanız gerekir:

import puppeteer from 'puppeteer';

const browser = await puppeteer.launch({
  headless: false,
  args: ["--enable-features=WebBluetooth"],
});

İlk sayfayı açarken genellikle gizli tarayıcıyı kullanmanız önerilir. Bu, komut dosyanızla çalıştırılan testler arasında izin sızıntısını önlemeye yardımcı olur (Puppeteer tarafından önlenemeyecek bazı işletim sistemi düzeyinde paylaşılan durumlar olsa da). Aşağıdaki kod bunu göstermektedir:

const browserContext = await browser.createIncognitoBrowserContext();
const page = await browserContext.newPage();

Ardından, Page.goto() ile test ettiğiniz web uygulamasının URL'sine gidebilirsiniz.

Bluetooth cihaz istemini açma

Web uygulamasının sayfasını Puppeteer ile açtıktan sonra, verileri okumak için Bluetooth cihazına bağlanabilirsiniz. Bu sonraki adımda, web uygulamanızda navigator.bluetooth.requestDevice() çağrısı da dahil olmak üzere bazı JavaScript'lerin çalıştığı bir düğmeniz olduğu varsayılır.

Page.locator().click() düğmesine basmak için Page.locator().click() düğmesini, Bluetooth cihaz seçicinin göründüğünü algılamak için Page.waitForDevicePrompt() düğmesini kullanın. Düğmeyi tıklamadan önce waitForDevicePrompt()'yi çağırmanız gerekir. Aksi takdirde istem zaten açılmış olur ve istemi algılayamaz.

Bu Puppeteer yöntemlerinin ikisi de promise döndürdüğü için Promise.all(), bunları birlikte doğru sırada çağırmanın uygun bir yoludur:

const [devicePrompt] = await Promise.all([
  page.waitForDevicePrompt(),
  page.locator("#start-test-button").click(),
]);

waitForDevicePrompt() tarafından döndürülen promise, bağlanmak istediğiniz Bluetooth cihazını seçmek için kullanacağınız bir DeviceRequestPrompt nesnesine çözünür.

Cihaz seç

Doğru Bluetooth cihazını bulup bağlanmak için DeviceRequestPrompt.waitForDevice() ve DeviceRequestPrompt.select() düğmelerini kullanın.

DeviceRequestPrompt.waitForDevice(), Chrome her Bluetooth cihazı bulduğunda sağlanan geri çağırma işlevini cihazla ilgili bazı temel bilgilerle çağırır. Geri çağırma ilk kez doğru değerini döndürdüğünde waitForDevice(), eşleşen DeviceRequestPromptDevice değerine çözümlenir. Bluetooth cihazını seçip bağlanmak için ilgili cihazı DeviceRequestPrompt.select()'e iletin.

const bluetoothDevice = await devicePrompt.waitForDevice(
  (d) => d.name == wantedDeviceName,
);
await devicePrompt.select(bluetoothDevice);

DeviceRequestPrompt.select() çözüldükten sonra Chrome cihaza bağlanır ve web sayfası cihaza erişebilir.

Cihazda okuma

Bu noktada web uygulamanız, seçilen Bluetooth cihazına bağlanır ve bu cihazdan bilgi okuyabilir. Bu, şöyle görünebilir:

const serviceId = "6e400001-b5a3-f393-e0a9-e50e24dcca9e";

const device = await navigator.bluetooth.requestDevice({
  filters: [{ services: [serviceId] }],
});
const gattServer = await device.gatt.connect();
const service = await gattServer.getPrimaryService(serviceId);
const characteristic = await service.getCharacteristic(
  "0b30afd0-193e-11eb-adc1-0242ac120002",
);
const dataView = await characteristic.readValue();

Bu API çağrısı sırasının daha ayrıntılı bir adım adım açıklamalı kılavuzu için JavaScript üzerinden Bluetooth cihazlarla iletişim kurma başlıklı makaleyi inceleyin.

Bu noktada, Bluetooth cihaz seçici menüsünden cihaz seçme işlemini kullanıcının yerine yaparak Bluetooth özellikli bir web uygulamasının kullanımını otomatikleştirmek için Puppeteer'ı nasıl kullanacağınızı biliyorsunuz. Bu genel olarak yararlı olsa da bu tür bir web uygulaması için uçtan uca test yazmak için doğrudan kullanılabilir.

Test oluşturma

Kodu bu aşamaya kadar getirip tam bir test yazmak için gereken son adım, web uygulamasından Puppeteer komut dosyanıza bilgi aktarmaktır. Bu işlemden sonra, doğru verilerin okunup raporlandığını doğrulamak için bir test kitaplığı (ör. TAP veya mocha) kullanmak oldukça kolaydır.

Bunu yapmanın en kolay yollarından biri DOM'a veri yazmaktır. JavaScript'te bunu ek kitaplıklar olmadan yapmanın birçok yolu vardır. Hayali web uygulamanıza dönecek olursak, Bluetooth cihazdan veri okurken bir durum göstergesinin rengini değiştirebilir veya bir alandaki gerçek verileri yazdırabilir. Örneğin:

const dataDisplayElement = document.querySelector('#data-display');
dataDisplayElement.innerText = dataView.getUint8();

Puppeteer'da Page.$eval(), bu verileri sayfanın DOM'undan bir test komut dosyasına aktarmanıza olanak tanır. $eval(), bir öğeyi bulmak için document.querySelector() ile aynı mantığı kullanır ve ardından sağlanan geri çağırma işlevini bağımsız değişken olarak bu öğeyle birlikte çalıştırır. Bu değişkeni oluşturduktan sonra, verilerin beklediğimiz veriler olup olmadığını test etmek için beyan kitaplığınızı kullanın.

const dataText = await page.$eval('#data-display', (el) => el.innerText);
equal(17, dataText);

Ek kaynaklar

Puppeteer ile Bluetooth özellikli web uygulamaları için test yazmayla ilgili daha karmaşık örnekler görmek isterseniz şu depoya göz atın: https://github.com/WebBluetoothCG/manual-tests/. Web Bluetooth Topluluk Grubu, tümünün tarayıcıdan veya yerel olarak çalıştırılabileceği bu test paketini yönetir. "Salt Okunur Özellik" testi, bu blog yayınında kullanılan örneğe en çok benzeyen testtir.

Tasdik

Bu projeyi başlattığı ve bu yayınla ilgili değerli geri bildirimler sağladığı için Vincent Scheib'e teşekkür ederiz.