- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 8.6k
[Java] Add visibility check to selectByVisibleText in Select class #15912
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
[Java] Add visibility check to selectByVisibleText in Select class #15912
Conversation
| Thank you, @SantiagoCecena for this code suggestion. The support packages contain example code that many users find helpful, but they do not necessarily represent We actively encourage people to add the wrapper and helper code that makes sense for them to their own frameworks. | 
| PR Reviewer Guide 🔍(Review updated until commit b4475b0)Here are some key observations to aid the review process: 
 | 
| PR Code Suggestions ✨Latest suggestions up to b4475b0 
 Previous suggestions✅ Suggestions up to commit b4475b0
 | |||||||||||||||||||||
| @SantiagoCecena please fix the formatting and update your branch (missing space after  | 
| Also, please sign the CLA: #15912 (comment) | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@SantiagoCecena, there are test failures related to this change. Could you please check them?
| @diemol but the test failures are in Ruby, right? I worked in a feature in Java, so I don't understand why is this happening 🤔 | 
| The ruby failures are isolated. The Java failures are here: https://github.com/SeleniumHQ/selenium/actions/runs/15824432595/job/44601350705?pr=15912 | 
This change updates the selectByVisibleText method to prevent selecting <option> elements that are hidden via CSS properties: "display: none", "visibility: hidden", and "opacity: 0" or "0.0". It uses the existing hasCssPropertyAndVisible method to ensure that only visible options can be selected, making this method consistent with selectByContainsVisibleText, which already has this behavior. Fixes SeleniumHQ#15265
Refactored the logic in selectByVisibleText to skip invisible options instead of failing fast. The method now continues evaluating other options with matching visible text, ensuring consistent behavior when multiple matching elements exist but some are hidden via CSS. This change improves robustness and aligns with cross-language expectations for Select component behavior. Relates to SeleniumHQ#15265
5c524b5    to
    0a48d48      
    Compare
  
    | This PR (#16220) was merged. I am closing this one. | 
User description
🔗 Related Issues
Fixes #15265
💥 What does this PR do?
This PR updates the
selectByVisibleTextmethod in the JavaSelectclass to prevent selecting<option>elements that are hidden via CSS.Specifically, the method now checks for CSS properties:
display: nonevisibility: hiddenopacity: 0or0.0An existing private method,
hasCssPropertyAndVisible, is used to verify visibility.🔧 Implementation Notes
The fix was done by calling
assertSelectIsVisible()at the beginning of the method, following the same pattern already used inselectByContainsVisibleText.No new logic or dependencies were introduced, and behavior is now consistent across both selection methods.
💡 Additional Considerations
The change was manually tested in a local environment using WebDriver, since I currently cannot run Bazel locally due to company machine restrictions.
If needed, I'm happy to follow up with a Bazel-compatible test or collaborate with a maintainer to integrate one.
🔄 Types of changes
PR Type
Bug fix
Description
• Add visibility check to
selectByVisibleTextmethod in Java Select class• Prevent selection of hidden options with CSS properties like
display: none• Make behavior consistent with
selectByContainsVisibleTextmethodChanges walkthrough 📝
Select.java
Add visibility validation to selectByVisibleText methodjava/src/org/openqa/selenium/support/ui/Select.java
• Added
assertSelectIsVisible()call at method start• Added
visibility check for each option using
hasCssPropertyAndVisible()•
Throw
NoSuchElementExceptionfor invisible options with descriptivemessage