2

I am having issues pressing a hidden radio button on my page using protractor. Below you will find a single test where the flow should work as following.

  1. Page is navigated too, and make sure that the radio button exists. (Two ways to verify existence below, both work)

  2. Attempt to click the button in a variety of different ways. All of the commented out ways, as well as the real one below do not error out the test, but they do also not "Click" the radio button. I am able to confirm this because of the 3 expects at the bottom that look to see if the form that shows up when the button is clicked actually shows up, and those are turning false every single time.

Any help with this would be greatly appreciated, Below I've also put the sample html that this code is looking at. Any help would be great, not sure if it is even possible. Thank you for any help in advance

       it('Should press one of the radio buttons and have the form pop up', function() {

    // Make sure that the value equals bank is found (This passing its test)
    expect(element.all(by.model('bankConnection.bank')).get(0).getAttribute('ng-value')).toEqual('bank');

    // Another way to make sure that the element is found (This is passing the test)
    // expect(element.all(by.css('[ng-value="bank"]')).get(0).getAttribute('ng-value')).toEqual('bank');

    // browser.driver.executeScript("return arguments[0].click();", element.all(by.css('[ng-value="bank"]')).get(0).getAttribute('ng-value').getWebElement());
    //   browser.driver.executeScript("return arguments[0].click();", element.all(by.model('bankConnection.bank')).get(0).getAttribute('ng-value').getWebElement());

    // #1 Way THIS WAY WORKS BUT DOESNT PRESS ANYTHING
    //  var input = element.all(by.model('bankConnection.bank')).get(0);

    // browser.driver.executeScript('angular.element(arguments[0]).triggerHandler("touchstart");', input.getWebElement());

    // #2 Way THIS WAY WORKS BUT DOESNT PRESS ANYTHING
    var input = element.all(by.model('bankConnection.bank')).get(0).getAttribute('ng-value');

    browser.driver.executeScript('angular.element(arguments[0]).triggerHandler("touchstart");', input.getWebElement());

    // To verify button was pressed. 2 seconds
    browser.driver.sleep(2000);

    // Make sure that the form pops up (IT IS CURRENTLY NOT SHOWING UP)
    expect(element(by.model('bankConnect.username')).isPresent()).toBe(true);
    expect(element(by.model('bankConnect.password')).isPresent()).toBe(true);

    // Once click is figured out this should flow through properly BOA CLICK
    expect(bank_page.idText).toEqual('Online ID');

    });

Radio Button Element

<div class="col" ng-repeat="bank in firstBanks">
  <div style="font-size: 2em; ">
   <label class="bank_radio">
     <input type="radio" ng-model="bankConnection.bank" ng-value="bank" class="ng-valid ng-dirty" value="[object Object]">
     <img ng-src="img/banks/bofa.png" src="img/banks/bofa.png">
   </label>
  </div>
 </div>

Form that pops up element

<div class="list card" style="margin-bottom: 0;margin-top:0;" ng-show="bankConnection.bank != null ">
 <div class-="list">

 <label class="item item-input">
  <span class="input-label ng-binding">Online ID</span>
   <input type="text" ng-model="bankConnection.username" class="ng-pristine ng-valid">
 </label>
 <label class="item item-input">
 <span class="input-label ng-binding">Password</span>
  <input type="password" ng-model="bankConnection.password" class="ng-pristine ng-valid" autocomplete="off" style="cursor: auto; background-image: url(); background-attachment: scroll; background-position: 100% 50%; background-repeat: no-repeat;">
</label>

 </div>
</div>
parchambeau
  • 1,141
  • 9
  • 34
  • 56
  • What if you declare `input` as just: `var input = element.all(by.model('bankConnection.bank')).get(0);`? – alecxe Jan 28 '15 at 11:02
  • If I declare my input as that I get the same issue. I tried passing that "input.getWebElement()" on all of the different ways above of "clicking" but have had no luck. The click is still not being registered, and the form is not popping up. I know that this is working correctly because If I manually click the buttons I do see the forms pop up, I just cannot seem to get it automated with protractor. – parchambeau Jan 28 '15 at 17:41
  • I suggest you look here: http://stackoverflow.com/questions/18406674/a-way-of-clicking-on-hidden-elements-in-protractor-end-to-end-tests – Randy Rakestraw Jan 28 '15 at 17:42
  • Do you think that I should try to grab ahold of the ng-src image tags and then try to issue the click commands that way? Because the "Buttons" do have an image as the area to click. Also thank you for the link I will take a look – parchambeau Jan 28 '15 at 17:48
  • So after looking at the link you sent I came up with a non deprecated version of the answer that he provided but it is still not issuing the click. var hiddenElement = element(by.css('[ng-src="img/banks/bofa.png"]')); browser.driver.executeScript("arguments[0].click()", hiddenElement.getWebElement()).then(function() { expect(element(by.model('bankConnect.username')).isPresent()).toBe(true); }); – parchambeau Jan 28 '15 at 18:22
  • I was able to find an answer to my problem. It seems like I have to issue a command for the mouse to hover over the area of the button, and then issue a click. This post pushed me in the right direction. http://stackoverflow.com/questions/22265040/how-to-click-on-hidden-element-in-protractor – parchambeau Jan 28 '15 at 18:53

1 Answers1

1

Here is what was able to fix my problem in the end. Courtesy of: How to click on hidden element in protractor?

I added this block to my code to hover over the area of the image, and then issue a click command.

// Move mouse over the button
browser.driver.actions().mouseMove(element(by.css('[ng-src="img/banks/bofa.png"]'))).perform();

    element.all(by.css('[ng-src="img/banks/bofa.png"]')).then(function (elm) {

        elm[0].click();
    });

Thank you for the help!

Community
  • 1
  • 1
parchambeau
  • 1,141
  • 9
  • 34
  • 56