Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added Java Example to Selenium Manager #1966

Open
wants to merge 11 commits into
base: trunk
Choose a base branch
from

Conversation

shbenzer
Copy link
Contributor

@shbenzer shbenzer commented Sep 24, 2024

User description

Added Java example to Selenium Manager

Description

Created usage.java with selenium manager examples
added examples to all translations

Motivation and Context

increase site comprehensiveness

Types of changes

  • Change to the site (I have double-checked the Netlify deployment, and my changes look good)
  • Code example added (and I also added the example to all translated languages)
  • Improved translation
  • Added new translation (and I also added a notice to each document missing translation)

Checklist

  • I have read the contributing document.
  • I have used hugo to render the site/docs locally and I am sure it works.

PR Type

enhancement, documentation


Description

  • Added a new Java example file demonstrating Selenium usage with and without a manager.
  • Updated documentation in multiple languages (English, Japanese, Portuguese, Chinese) to include new Java examples.
  • Enhanced site comprehensiveness by providing practical code examples.

Changes walkthrough 📝

Relevant files
Enhancement
usage.java
Add Java Selenium usage examples with test methods             

examples/java/src/test/java/dev/selenium/selenium_manager/usage.java

  • Added a new Java class usage with Selenium examples.
  • Included two test methods demonstrating Selenium setup with and
    without a manager.
  • +24/-0   
    Documentation
    selenium_manager.en.md
    Update English documentation with Java examples                   

    website_and_docs/content/documentation/selenium_manager.en.md

  • Updated Java tab with new Selenium Manager examples.
  • Added code block references for Java examples.
  • +5/-2     
    selenium_manager.ja.md
    Update Japanese documentation with Java examples                 

    website_and_docs/content/documentation/selenium_manager.ja.md

  • Updated Java tab with new Selenium Manager examples.
  • Added code block references for Java examples.
  • +5/-2     
    selenium_manager.pt-br.md
    Update Portuguese documentation with Java examples             

    website_and_docs/content/documentation/selenium_manager.pt-br.md

  • Updated Java tab with new Selenium Manager examples.
  • Added code block references for Java examples.
  • +5/-2     
    selenium_manager.zh-cn.md
    Update Chinese documentation with Java examples                   

    website_and_docs/content/documentation/selenium_manager.zh-cn.md

  • Updated Java tab with new Selenium Manager examples.
  • Added code block references for Java examples.
  • +5/-2     

    💡 PR-Agent usage: Comment /help "your question" on any pull request to receive relevant information

    Copy link

    netlify bot commented Sep 24, 2024

    👷 Deploy request for selenium-dev pending review.

    Visit the deploys page to approve it

    Name Link
    🔨 Latest commit e251d0b

    @qodo-merge-pro qodo-merge-pro bot added documentation Improvements or additions to documentation enhancement New feature or request Review effort [1-5]: 2 labels Sep 24, 2024
    Copy link
    Contributor

    PR Reviewer Guide 🔍

    ⏱️ Estimated effort to review: 2 🔵🔵⚪⚪⚪
    🧪 PR contains tests
    🔒 No security concerns identified
    ⚡ Key issues to review

    Hardcoded Path
    The path to the chromedriver is hardcoded, which may cause issues on different systems or when the driver is updated.

    Missing Assertions
    The test methods do not include any assertions to verify the expected behavior.

    Copy link
    Contributor

    PR Code Suggestions ✨

    CategorySuggestion                                                                                                                                    Score
    Best practice
    Use try-with-resources to automatically close the WebDriver

    Consider using a try-with-resources statement to ensure that the WebDriver is always
    closed, even if an exception occurs during the test execution.

    examples/java/src/test/java/dev/selenium/selenium_manager/usage.java [10-15]

     @Test
     public void testSetupWithoutManager() {
         System.setProperty("webdriver.chrome.driver", "/path/to/chromedriver");
    -    WebDriver driver = new ChromeDriver();
    -    driver.get("https://www.selenium.dev/documentation/selenium_manager/");
    -    driver.quit();
    +    try (WebDriver driver = new ChromeDriver()) {
    +        driver.get("https://www.selenium.dev/documentation/selenium_manager/");
    +    }
     }
     
    • Apply this suggestion
    Suggestion importance[1-10]: 9

    Why: This suggestion is a best practice that ensures the WebDriver is closed properly, even if an exception occurs, which enhances the reliability of the test.

    9
    Maintainability
    Use a system property for the ChromeDriver path to improve flexibility

    Instead of hardcoding the path to the ChromeDriver, consider using a system property
    or environment variable to make the code more flexible and portable across different
    environments.

    examples/java/src/test/java/dev/selenium/selenium_manager/usage.java [11]

    -System.setProperty("webdriver.chrome.driver", "/path/to/chromedriver");
    +String chromeDriverPath = System.getProperty("webdriver.chrome.driver.path", "/path/to/chromedriver");
    +System.setProperty("webdriver.chrome.driver", chromeDriverPath);
     
    • Apply this suggestion
    Suggestion importance[1-10]: 8

    Why: This change improves the maintainability and portability of the code by allowing the ChromeDriver path to be configured externally, which is beneficial for different environments.

    8
    Extract common code into a separate method to reduce duplication

    Consider extracting the common code between the two test methods into a separate
    method to reduce duplication and improve maintainability.

    examples/java/src/test/java/dev/selenium/selenium_manager/usage.java [10-22]

    +private void performTest(WebDriver driver) {
    +    driver.get("https://www.selenium.dev/documentation/selenium_manager/");
    +    // Add assertions here
    +}
    +
     @Test
     public void testSetupWithoutManager() {
         System.setProperty("webdriver.chrome.driver", "/path/to/chromedriver");
    -    WebDriver driver = new ChromeDriver();
    -    driver.get("https://www.selenium.dev/documentation/selenium_manager/");
    -    driver.quit();
    +    try (WebDriver driver = new ChromeDriver()) {
    +        performTest(driver);
    +    }
     }
     
     @Test
     public void testSetupWithManager() {
    -    WebDriver driver = new ChromeDriver();
    -    driver.get("https://www.selenium.dev/documentation/selenium_manager/");
    -    driver.quit();
    +    try (WebDriver driver = new ChromeDriver()) {
    +        performTest(driver);
    +    }
     }
     
    • Apply this suggestion
    Suggestion importance[1-10]: 7

    Why: This suggestion improves maintainability by reducing code duplication, making the codebase easier to manage and understand.

    7
    Enhancement
    Add assertions to verify the correct page has been loaded

    Consider adding assertions to verify that the correct page has been loaded, as this
    would make the tests more meaningful and robust.

    examples/java/src/test/java/dev/selenium/selenium_manager/usage.java [18-22]

     @Test
     public void testSetupWithManager() {
         WebDriver driver = new ChromeDriver();
         driver.get("https://www.selenium.dev/documentation/selenium_manager/");
    +    assert driver.getTitle().contains("Selenium Manager");
         driver.quit();
     }
     
    • Apply this suggestion
    Suggestion importance[1-10]: 7

    Why: Adding assertions makes the tests more meaningful and robust by verifying that the intended page is loaded, though it is a minor enhancement.

    7

    💡 Need additional feedback ? start a PR chat

    @shbenzer shbenzer changed the title Added Java Example Added Java Example to Selenium Manager Sep 24, 2024
    Copy link

    @A1exKH A1exKH left a comment

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    LGTM.

    @VietND96 VietND96 added the java Pull requests that update Java code label Nov 1, 2024
    Copy link
    Member

    @harsha509 harsha509 left a comment

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    Thank you @shbenzer !

    @shbenzer
    Copy link
    Contributor Author

    shbenzer commented Jan 3, 2025

    @harsha509 changed

    Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
    Labels
    documentation Improvements or additions to documentation enhancement New feature or request java Pull requests that update Java code Review effort [1-5]: 2
    Projects
    None yet
    Development

    Successfully merging this pull request may close these issues.

    4 participants