From f3465338aa95eb69f2f435fc22dfa78aeae0e863 Mon Sep 17 00:00:00 2001 From: btangmu Date: Tue, 12 Dec 2023 17:16:56 -0500 Subject: [PATCH] CLDR-17248 Measure vote timing; update cldr-apps-webdriver -Update selenium-grid-start.sh to work with current Selenium -Update instructional comments in SurveyDriver.java -Update rowId to start with row_ as in current Survey Tool -Update maven.yml and pom.xml with newer versions, logging --- scripts/selenium-grid-start.sh | 4 +- .../cldr/surveydriver/SurveyDriver.java | 38 ++++++++----------- 2 files changed, 17 insertions(+), 25 deletions(-) diff --git a/scripts/selenium-grid-start.sh b/scripts/selenium-grid-start.sh index 36b7829..412e6f1 100644 --- a/scripts/selenium-grid-start.sh +++ b/scripts/selenium-grid-start.sh @@ -1,8 +1,8 @@ #!/bin/bash -HUB_URL=http://localhost:4444/grid/register java -jar selenium-server-standalone-3.141.59.jar -role hub & +HUB_URL=http://localhost:4444/grid/register java -jar selenium-server-4.16.1.jar standalone & for ((PORT = 5555; PORT <= 5564; PORT++)) do - HUB_URL=http://localhost:4444/grid/register java -jar selenium-server-standalone-3.141.59.jar -role node -port $PORT & + HUB_URL=http://localhost:4444/grid/register java -jar selenium-server-4.16.1.jar standalone --port $PORT & done diff --git a/src/test/java/org/unicode/cldr/surveydriver/SurveyDriver.java b/src/test/java/org/unicode/cldr/surveydriver/SurveyDriver.java index 66b5c1e..f129770 100644 --- a/src/test/java/org/unicode/cldr/surveydriver/SurveyDriver.java +++ b/src/test/java/org/unicode/cldr/surveydriver/SurveyDriver.java @@ -31,42 +31,34 @@ /** * Perform automated testing of the CLDR Survey Tool using Selenium WebDriver. - * Reference: https://unicode.org/cldr/trac/ticket/11488 - * "Implement new Survey Tool automated test framework and infrastructure" * - * This test has been used with the cldr-apps-webdriver project running in Eclipse. At the same time, - * cldr-apps can be running either on localhost (in the same Eclipse as cldr-apps-webdriver) or on SmokeTest. + * This test has been used with the cldr-apps-webdriver project running in IntelliJ. At the same time, + * cldr-apps can be running either on localhost or on SmokeTest. * * This code requires installing an implementation of WebDriver, such as chromedriver for Chrome. * On macOS, chromedriver can be installed from Terminal with brew as follows: - * brew tap homebrew/cask * brew install chromedriver - * -- or download chromedriver from https://chromedriver.storage.googleapis.com - * (Testing with geckodriver for Firefox has been unsuccessful.) + * Then, right-click chromedriver, choose Open, and authorize to avoid the macOS error, + * "“chromedriver” cannot be opened because the developer cannot be verified". + * Press Ctrl+C to stop this instance of chromedriver. * - * A tutorial for setting up a project using Selenium in Eclipse: - * https://www.guru99.com/selenium-tutorial.html + * (Testing with geckodriver for Firefox was unsuccessful, but has not been tried recently.) * - * The Selenium jar files must be added to the Eclipse project. Download from - * https://www.seleniumhq.org/download/ and unzip to get a folder like selenium-java-3.141.59. - * In Eclipse, right-click on "cldr-apps-webdriver" and select Properties. Click on "Java Build Path". - * Click on the Libraries tab. Click on "Add External JARs". Navigate to the selenium folder and - * add all the jar files outside the "lib" folder. Click on "Add External JARs" again and add all - * the jar files inside "lib". + * Go to https://www.selenium.dev/downloads/ and scroll down to "Selenium Server (Grid)" and + * follow the link to download a file like selenium-server-4.16.1.jar and save it in the parent + * directory of cldr-apps-webdriver. * - * For Gson, CLDR already includes cldr/tools/java/libs/gson.jar. Take advantage of that - * and add it to Eclipse as follows: Right-click on "cldr-apps-webdriver" and select Properties. - * Click on "Java Build Path". Click on the Libraries tab. Click on "Add External JARs". - * Navigate to cldr/tools/java/libs and select gson.jar. - * - * Setting up may require adding a specific set of test users to the db, consistent - * with getNodeLoginQuery: + * Add a specific set of simulated test users to the db, consistent with the method getNodeLoginQuery below: * * mysql cldrdb < cldr-apps-webdriver/scripts/cldr-add-webdrivers.sql * - * and starting selenium grid: + * Start selenium grid: * * sh cldr-apps-webdriver/scripts/selenium-grid-start.sh & + * + * Open this file (SurveyDriver.java) in IntelliJ, right-click cldr-apps-webdriver in the Project + * panel, and choose "Debug All Tests". You can do this repeatedly to start multiple browsers with + * simulated vetters vetting at the same time. */ public class SurveyDriver {