web-dev-qa-db-de.com

Wie bewegen Sie die Maus mit Protractor/Selen an einen beliebigen Punkt?

Ist es möglich, die Maus zu beliebigen Koordinaten auf dem Bildschirm/relativ zu einem Element in den Protractor-Tests zu bewegen? Ich sehe, dass Leute die Verwendung von Robot für Java-Benutzer empfehlen, aber ich kann das natürlich nicht in JavaScript verwenden.

18
Andy

Ich habe es für mich selbst herausgefunden ... Ich habe nur tief durch die Protractor- und Selenium-Dokumentation gegraben. Hier ist ein Beispielcode:

  it('should pan plots when you click and drag', function() {
    var plot0 = element(by.css('.plot > canvas'));
    browser.actions()
      .mouseMove(plot0, {x: 100, y: 100}) // 100px from left, 100 px from top of plot0
      .mouseDown()
      .mouseMove({x: 400, y: 0}) // 400px to the right of current location
      .perform();
  });
32
Andy

Ich habe auch eine Lösung gefunden, um eine Swipe-Aktion zu simulieren.

var card = element(by.css('#card'));

browser.actions()
  .mouseMove(card, {x: 100, y: 100})
  .mouseDown()
  .mouseMove({x: 0, y: -400})
  .perform();

browser.sleep(500);

browser.actions()
  .mouseUp()
  .perform();
4
PurpleOrange
var graphDimensions = {// see [1]
  Width: 0,
  Height: 0
};
company_page.company_Chart_Graph().getAttribute('width')
  .then(function(width) {
    graphDimensions.Width = parseInt(width);
  });

company_page.company_Chart_Graph().getAttribute('height').then(function(height) {
  graphDimensions.Height = parseInt(height);

  console.log('W' + graphDimensions.Width);
  console.log('H' + graphDimensions.Height);

  var plot0 = company_page.company_Chart_Graph();
  browser.actions()
    .mouseMove(plot0, {
      x: 0,
      y: 0
    })
    .mouseDown()
    .mouseMove(plot0, {
      x: graphDimensions.Width,
      y: graphDimensions.Height
    })
    .mouseUp()
    .perform();

  browser.driver.sleep(23000);
  company_page.company_ReportDownload().click();
  browser.driver.sleep(23000);
});

[1]: http://testingalert.com/

0
kkashyap1707