Files
2022-01-20 20:30:18 +01:00

3.2 KiB

id, title, challengeType, dashedName
id title challengeType dashedName
587d824f367417b2b2512c5c ヘッドレスブラウザーを使用してアクションをシミュレートする 2 simulate-actions-using-a-headless-browser

--description--

注意点として、このプロジェクトは Replit の始動プロジェクト、または GitHub からクローンされたプロジェクトに基づいて構築されています。

次のチャレンジでは、ヘッドレスブラウザーを使用してページと人間のやり取りをシミュレートします。

ヘッドレスブラウザーは、GUI を持たないウェブブラウザーです。 通常のブラウザーと同じように、HTML、CSS、および JavaScript をレンダーして解釈することができます。 特にウェブページのテストに役立ちます。

以降のチャレンジでは、Zombie.js を使用します。これは、追加のバイナリをインストールしなくても動作する軽量のヘッドレスブラウザーです。 この機能により、Replit のような限られた環境で使用できます。 ただし、他にも多くの高機能なヘッドレスブラウザーがあります。

Mocha では、実際のテストが実行される前にコードを実行できます。 これは、以降のテストで使用するデータベースへのエントリの追加などの操作を行うのに便利です。

ヘッドレスブラウザーでテストを行う前に、テストを行うページにアクセスしてください。

suiteSetup フックは、テストスイートの始めに一度だけ実行されます。

他にも、各テストの前、各テストの後、またはテストスイートの終わりにコードを実行できるいくつかのフックタイプがあります。 詳細については、Mocha のドキュメントを参照してください。

--instructions--

tests/2_functional-tests.js の中の Browser 宣言の直後で、変数の site プロパティにプロジェクトの URL を追加してください。

Browser.site = 'https://boilerplate-mochachai.your-username.repl.co'; // Your URL here

次に、'Functional Tests with Zombie.js' スイートのルートレベルで、次のコードを使用して Browser オブジェクトの新しいインスタンスを生成してください。

const browser = new Browser();

そして、次のコードを使用して、suiteSetupフックで browser/ ルートに移動させてください。

suiteSetup(function(done) {
  return browser.visit('/', done);
});

--hints--

すべてのテストに合格する必要があります。

(getUserInput) =>
  $.get(getUserInput('url') + '/_api/get-tests?type=functional&n=4').then(
    (data) => {
      assert.equal(data.state, 'passed');
    },
    (xhr) => {
      throw new Error(xhr.responseText);
    }
  );

--solutions--

/**
  Backend challenges don't need solutions, 
  because they would need to be tested against a full working project. 
  Please check our contributing guidelines to learn more.
*/