如何使用Selenium在react-dnd-treeview库上进行拖放测试

时间:2018-05-11 15:02:37

标签: java selenium selenium-webdriver drag-and-drop

我正在尝试在React应用上测试一个简单的拖放行为。

我正在使用react-dnd-treeview库和their example website来测试我的测试用例。

当我在调试中运行测试时,我没有收到任何错误,Selenium能够获得正确的元素,但没有任何事情发生,我无法创建或可视化任何类型的操作,即使在尝试之后这么多不同的答案in this similar question,但都是徒劳的。

以下是我正在使用的代码:

package tests;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.interactions.Actions;

import java.io.File;

public class DAndDJava {

    public static void main(String[] args) {

        File file = new File("C:/misc/chromedriver.exe");
        System.setProperty("webdriver.chrome.driver" , file.getAbsolutePath());

        WebDriver driver = new ChromeDriver();
        driver.manage().window().maximize();
        driver.get("http://teleport.github.io/react-dnd-treeview/example/dist/index.html");

        WebElement dragPoint = driver.findElement(By.xpath ("//*[@id=\"root\"]/div/div/div[3]/div[2]/div[2]/div/div/div[3]/div[2]/div/div[1]/div[3]/div[1]/div"));
        WebElement dropPoint = driver.findElement(By.xpath ("//*[@id=\"root\"]/div/div/div[3]/div[2]/div[2]/div/div/div[3]/div[2]/div/div[1]/div[3]/div[1]"));

        Actions builder = new Actions(driver);

        Action dragAndDrop = builder.clickAndHold(dragPoint)
                                    .moveToElement(dropPoint)
                                    .release(dropPoint)
                                    .build();

        dragAndDrop.perform();

        driver.quit();
    }

}

2 个答案:

答案 0 :(得分:0)

您可以尝试使用以下代码:

Action dragAndDrop = builder.clickAndHold(dragPoint)
                            .moveToElement(dropPoint)
                            .moveByOffset(0,10)   
                            .release()
                            .build()
                            .perform() ;

答案 1 :(得分:-1)

此处描述了解决方案

首先光标移动应该在元素边界内,以便将元素的状态更改为dragged,然后才能将其拖动到预期位置:

action.clickAndHold(elementToDrag)
    .moveByOffset(0, -5)
    .pause(100)
    .moveByOffset(0, -300)
    .release()
    .perform();