1. ホーム
  2. javascript

[解決済み] protractorjs e2e テストでドロップダウンのオプションを選択する方法

2022-08-14 14:36:21

質問

protractorを使って、angular e2eのテストでドロップダウンからオプションを選ぼうとしています。

以下は、selectオプションのコードスニペットです。

<select id="locregion" class="create_select ng-pristine ng-invalid ng-invalid-required" required="" ng-disabled="organization.id !== undefined" ng-options="o.id as o.name for o in organizations" ng-model="organization.parent_id">
    <option value="?" selected="selected"></option>
    <option value="0">Ranjans Mobile Testing</option>
    <option value="1">BeaverBox Testing</option>
    <option value="2">BadgerBox</option>
    <option value="3">CritterCase</option>
    <option value="4">BoxLox</option>
    <option value="5">BooBoBum</option>
</select>

試してみました。

ptor.findElement(protractor.By.css('select option:1')).click();

これでは、以下のようなエラーになります。

無効な、または不正な文字列が指定されました ビルド情報: バージョン: '2.35.0', リビジョン: 'c916b9d', 時間: '2013-08-12 15:42:01' システム情報: os.name: 'Mac OS X', os.arch: x86_64'、os.version: '10.9'、java.version: '1.6.0_65' となります。 ドライバー情報: driver.version: unknown

も試してみました。

ptor.findElement(protractor.By.xpath('/html/body/div[2]/div/div[4]/div/div/div/div[3]/ng-include/div/div[2]/div/div/organization-form/form/div[2]/select/option[3]')).click();

これでは、以下のようなエラーになります。

ElementNotVisibleError: 要素は現在表示されていないので、対話できない可能性があります。 コマンドの持続時間またはタイムアウト: 9 ミリ秒 ビルド情報: バージョン: '2.35.0', リビジョン: 'c916b9d', 時刻: '2013-08-12 15:42:01'. システム情報: os.name: 'Mac OS X', os.arch: x86_64', os.version: '10.9', java.version: '1.6.0_65'. セッション ID: bdeb8088-d8ad-0f49-aad9-82201c45c63f ドライバ情報: org.openqa.selenium.firefox.FirefoxDriver 機能 [{platform=MAC, acceptSslCerts=true, javascriptEnabled=true, browserName=firefox, rotatable=false, locationContextEnabled=true, version=24.0, cssSelectorsEnabled=true, databaseEnabled=true, handlesAlerts=true, browserConnectionEnabled=true, nativeEvents=false, webStorageEnabled=true, applicationCacheEnabled=false, takesScreenshot=true} ]について説明します。

誰かこの問題で私を助けてください、または私がここで間違っているかもしれないことに光を投げてください。

どのように解決するには?

私も同じような問題があり、最終的にドロップダウンの値を選択するヘルパー関数を書きました。

私は最終的にオプション番号で選択しても問題ないと判断し、要素とoptionNumberを受け取り、そのoptionNumberを選択するメソッドを書きました。 optionNumberがNULLの場合は何も選択されません(ドロップダウンは未選択のまま)。

var selectDropdownbyNum = function ( element, optionNum ) {
  if (optionNum){
    var options = element.all(by.tagName('option'))   
      .then(function(options){
        options[optionNum].click();
      });
  }
};

もっと詳しく知りたい方はブログ記事を書きました。ドロップダウンで選択されたオプションのテキストを検証することもカバーしています。 http://technpol.wordpress.com/2013/12/01/protractor-and-dropdowns-validation/