QTP / UFT 'Style/*' Notation (Web-based objects)
You can now use the new “Style/*” notation to access the values of CSS properties for Web-based objects. You can then use these property values to identify such objects by adding the notation to the object's description properties using programmatic descriptions/descriptive Programming.
These below examples are using properties like style/background-color, style/background-position, style/font-family and border-style.
Example: 1 - using the "style/background-color" property
Write the below code in a Notepad and save it as an .html file.
On opening the above Notepad with browser (I used IE 10), you will see the below two buttons.
data:image/s3,"s3://crabby-images/18d07/18d0786f589d9d280824dd75cea107eff04e635d" alt=""
Write the below code in QTP (UFT/QTP 12.0) and run the code:
Example: 2 - using the "style/background-color" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/69ed2/69ed231e6623f562c952b35191eb3ff61ad24b52" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below two buttons.
data:image/s3,"s3://crabby-images/d30df/d30df7f509e02c2e572733a115dfb0ca080cea00" alt=""
Write the below code in QTP and run the code:
Example: 3 - using the "style/background-position" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/68ca8/68ca8102cf31091f4d51486c9921e00e5797f449" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below two images and a text area. You have to make sure that the (Tulips) image is in the same location as the file.
data:image/s3,"s3://crabby-images/66ad0/66ad0686bd8f88d2a0c560015190fddbad86dfba" alt=""
Part a:
Write the below code in QTP and run it:
Browser("name:=QTP-Test").Page("title:=QTP-Test").image("html tag:=img", "style/background-position:= 2px 1px").Click
Above line will click the top image and the value "Top image with border" will be shown in text area.
Part b:
Write the below code in QTP and run it:
Browser("name:=QTP-Test").Page("title:=QTP-Test").image("html tag:=img", "style/background-position:= -91px 1px").Click
Above line will click the bottom image and the value "Bottom image without border" will be shown in text area.
Example: 4 - using the "style/font-family" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/df61d/df61d9805380effdd75976f6e6e3b44ba50004d5" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below text field and a button.
data:image/s3,"s3://crabby-images/127f2/127f218adc155df13607d3cc347a9fe4e6ee70ce" alt=""
Write the below code in QTP and run it:
Example: 5 - using the "border-style" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/f49f5/f49f5eb175d2f95f6491243f61f8d830732d4e89" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below text field and a button with dotted border.
data:image/s3,"s3://crabby-images/d61ed/d61ed65c55ff22b16b3871cae27be4b6e6c587ea" alt=""
Write the below code in QTP and run it:
You can now use the new “Style/*” notation to access the values of CSS properties for Web-based objects. You can then use these property values to identify such objects by adding the notation to the object's description properties using programmatic descriptions/descriptive Programming.
These below examples are using properties like style/background-color, style/background-position, style/font-family and border-style.
Example: 1 - using the "style/background-color" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/e4155/e4155d47282bf410fd187bb5859bf8927fef0793" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below two buttons.
Write the below code in QTP (UFT/QTP 12.0) and run the code:
Set oDesc = Description.Create() oDesc("micclass").Value = "Webbutton" oDesc("style/background-color").Value = "rgb\(0, 255, 0\)" Set var_buttons = Browser("name:=QTP-Test").Page("title:=QTP-Test").ChildObjects(oDesc) no_of_buttons = var_buttons.Count msgbox no_of_buttonsWhen you run the above code, a message box will open and show the count of green buttons - 2 in our case.
Example: 2 - using the "style/background-color" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/69ed2/69ed231e6623f562c952b35191eb3ff61ad24b52" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below two buttons.
Write the below code in QTP and run the code:
Set oDesc = Description.Create() oDesc("micclass").Value = "Webbutton" oDesc("style/background-color").Value = "rgb\(0, 255, 0\)" Set var_buttons = Browser("name:=QTP-Test").Page("title:=QTP-Test").ChildObjects(oDesc) no_of_buttons = var_buttons.Count msgbox no_of_buttons For i = 0 To no_of_buttons-1 If var_buttons(i).GetROProperty("value") = "Green_2" Then var_buttons(i).click End If NextSimilar to above example, it first shows the count of green buttons and then clicks the Green_2 button. As in above example, we are using the "style/background-color" property in above code.
Example: 3 - using the "style/background-position" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/68ca8/68ca8102cf31091f4d51486c9921e00e5797f449" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below two images and a text area. You have to make sure that the (Tulips) image is in the same location as the file.
Part a:
Write the below code in QTP and run it:
Browser("name:=QTP-Test").Page("title:=QTP-Test").image("html tag:=img", "style/background-position:= 2px 1px").Click
Above line will click the top image and the value "Top image with border" will be shown in text area.
Part b:
Write the below code in QTP and run it:
Browser("name:=QTP-Test").Page("title:=QTP-Test").image("html tag:=img", "style/background-position:= -91px 1px").Click
Above line will click the bottom image and the value "Bottom image without border" will be shown in text area.
Example: 4 - using the "style/font-family" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/df61d/df61d9805380effdd75976f6e6e3b44ba50004d5" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below text field and a button.
Write the below code in QTP and run it:
Set oDesc = Description.Create() oDesc("micclass").Value = "WebButton" oDesc("style/font-family").Value = "Times New Roman" Browser("name:=QTP").Page("title:=QTP").WebButton(oDesc).ClickThe above code will click the button and show the alert box with the message Red on it.
Example: 5 - using the "border-style" property
Write the below code in a Notepad and save it as an .html file.
data:image/s3,"s3://crabby-images/f49f5/f49f5eb175d2f95f6491243f61f8d830732d4e89" alt=""
On opening the above Notepad with browser (I used IE 10), you will see the below text field and a button with dotted border.
Write the below code in QTP and run it:
Set oDesc = Description.Create() oDesc("micclass").Value = "WebButton" oDesc("border-style").Value = "dotted" Browser("name:=QTP").Page("title:=QTP").WebButton(oDesc).ClickAbove code will click on the button and show the alert box with message as Red. Similar to above you can try with other properties like border-width etc. also.