-
Notifications
You must be signed in to change notification settings - Fork 116
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
Somewhat Off Topic - But - How To Set Value of OJ Combobox? #73
Comments
JET v4.1.0 is very old and it contains security vulnerabilities in multiple libraries that are distributed with JET (jQuery and Knockout to name two). I strongly recommend updating if at all possible. Updating the value programmatically for oj-combobox is pretty simple in that you just update the observable that you have bound to the "value" property, or you can use setProperty on the component as well. I'm making an assumption with the above comment, and that is that you are using the custom element syntax <oj-combobox ...> and not the really old jQueryUI syntax which used a Knockout custom binding called ojComponent. As for test automation, we recommend the use of Selenium Web Driver. We are working on providing a set of Web Elements for the JET components that will make this a lot easier, but they won't be available until later this year unfortunately. |
@peppertech Thanks so much for responding. I am not the one who created the page. I am the one trying to automate third party input to it :). I don't know what they used on the backend side of things ( or ojComponent) - I only have access to the front-end Javascript that the browser can see when the page is rendered. I am using Selenium Web Driver, and that's what I am trying to automate - setting a value on the combobox. I do see that they are including
Also it seems that the backing observable for the combobox is created thusly:
I also see the following which looks to setup some type of event handler:
Thanks so much. |
@peppertech Do you think you could take a second look? I really appreciate it. |
Hi Michael, sorry for the delay. I've asked one of the test engineers to pop in and give some advice. I'm sure he'll be more knowledgeable than I am on how to use Selenium. and here is a JET Cookbook demo using that same old jQuery syntax for setting up the component itself in the HTML and then defining the "val" variable as a Knockout observableArray. https://www.oracle.com/webfolder/technetwork/jet-320/jetCookbook.html?component=combobox&demo=single To update the value, you would set update that observableArray
|
@peppertech Thanks for your feedback. For some reason Again, this is how they setup the combobox - I am not able to change the page itself - only trying to automate it's entry. Is there a way to set the value by going through jQuery as
Seems like the The reason I think the |
For the Knockout observable issue, I would try initializing it with an empty string, or just leave it empty (it will default to undefined) and see if that works. I've never seen initializing with null, being and issue before, but the version of Knockout you are working against may very well have a bug in it. It's a bit old and insecure. |
Well, doing a search of the Knockout repository issues, it appears that they did implement a breaking change in Knockout 3.0.0 where you can no longer initialize an observable or observableArray with null or undefined. The version of KO shipped with JET v4.1.0 was 3.4.0. Sooooo, I would initialize with an empty parens or array respectively if you don't know what value you want into there. Empty string will work for observable as well of course. |
I'm not sure on the DOM structure of the combobox for that version of JET, but have you tried calling sendKeys to the element and then tabbing out? That would normally trigger a "change" event on the element, which should cause the observable value to update. Something like |
@itlgit That works in the sense that it enters the text in the combobox, but it does not trigger the following event listener: console.log({caller:"optionChange"});
$("#om_shipFromOverride").ojCombobox({
optionChange: function() {self.lookupShipFromRemarks();}
}); and thus the script does not think it is actually filled in and won't let the form be submitted. |
Trying to understand from your sample, which element is id="om_shipFromOverride"? From your sample above, the outer-most "root" element is id="oj-combobox-choice-om_shipFromOverride" and the <input> element is id="oj-combobox-input-om_shipFromOverride" Since typing the value into the input doesn't seem to trigger optionChange event, I wonder if clicking on the outer element to show the list, then sending it the arrow keys would do it? Or is that what you already tried? |
@itlgit That's a good question. I don't see that in the HTML anywhere, but that's how they reference the combobox. Here are all appearances of that string in their scripts: var validationMessages = [];
if (inspirage.isShipFromOverrideRequired) {
if (! self.shipFromOverride()) {
var message = "Ship From Override is required";
validationMessages.push({message:message, selector:"#om_shipFromOverride"});
} // set combo box here om_shipFromOverride
$("#orderBaseManager #om_shipFromOverride").ojCombobox({"options":locations}); if (false) {
$("#om_shipFromOverrideDiv").focusout(function() {
self.lookupShipFromRemarks();
});
}
if (true) {
console.log({caller:"optionChange"});
$("#om_shipFromOverride").ojCombobox({
optionChange: function() {self.lookupShipFromRemarks();}
});
} Indeed, trying to click on the outer element and then sending arrow keys was the first thing I tried. I realize we may be at an impasse because of how this page was coded - it's quite annoying. Appreciate all your assistance. |
Does |
@itlgit It does, good idea.
Is that full enough? Or do you need more DOM? Thank you so much. |
Sorry for the late reply. Can you share what the live DOM looks like after the component has been created? The original HTML |
@itlgit No problem. Thanks for your help. It seems that the real DOM structure is only created when I interact with the input box (such as typing a character). It does not seem to do it just on page load which may be a problem for automating in this case. But after some interaction here is the result: I took a screenshot because copy/paste is selecting the old DOM structure. |
Ok, so #om_shipFromOverride is the original node on which the jQuery component was created, but it's no longer relevant (it's display:none) because, presumably, the component root is now #ojChoiceId_om_shipFromoverride, and the new, effective <input> element is #oj-combobox-input-om_shipFromOverride. So you've tried send the "value" property via JS, calling sendKeys to send the keystrokes to the input--neither have triggered the optionChange event. Does the combobox have a expand/drop-down arrow that shows a list of options when clicked? If so, you could try targeting that with your test, click it, then click the appropriate item from the list that displays. |
That's one of the things I tried. It does not seem possible to click on the arrow dropdown box, which happens to be:
I don't mean from Selenium, either. Trying to do it just from the developer tools console also doesn't work:
I made sure that the selector is infact selecting the drop down arrow: No matter what I try this continues to stump me. |
Does Selenium give you any error when you try to click it, or it just does nothing? I'm assuming actually clicking it with your mouse works and shows the list... |
Selenium and the Javascript console both do nothing. Actually clicking it with my mouse does work :). |
Sorry if this is off-topic.
I am attempting to automate input on a website that uses Oracle JET (version 4.1.0).
I am using Selenium to take user-like actions such as entering text in input fields, etc.
All is working well except for trying to set the value of an ojcombobox.
It is defined in the HTML thusly:
It is constructed dynamically from a SQL result:
I have tried a bunch of things, such as:
Which sets the value visually, but doesn't seem to actually trigger observables so the script on the page still believes it is not set.
I also tried sending the keys: "TAB, TAB, TAB, TAB... etc. ARROW_DOWN ARROW_DOWN ENTER" but this doesn't seem to do anything.
I am able to execute arbitrary Javascript using Selenium - so I was wondering if there is a way to programmatically make a selection for the combobox? Browsing the documentation I only saw a method for setting the initial value when it is instantiated.
Assistance would be greatly appreciated.
The text was updated successfully, but these errors were encountered: