Robot Framework 无法识别某些 class 关键字
Robot Framework not recognizing some class keywords
我正在创建一个包含三个不同 classes 的 RobotFramework 库。
我可以使用第一个 class 关键字,但是我无法使用剩下的两个 classes 关键字。
根据 RF 文档,我尝试按以下方式使用导入 LibraryName.className
我还设置 python 路径到我的个人图书馆文件夹。
然而,当 运行 测试时,只有第一个 class 关键字被识别。
我试图将第一个 class 的名称更改为与我的 lib 文件不同的名称,并分别导入每个 class,但这对三个 class 的关键字不起作用。
这是我的库代码:
from robotpageobjects import Page, robot_alias
from robot.utils import asserts
class HomePage(Page):
""" Models WeekendDesk home page at:
HOST:weekendesk.fr/"""
name="Home"
# This is Then Keyword for Weekendesk Home Page.
# This page is found at baseurl"
uri = ""
# inheritable dictionary mapping human-readable names
# to Selenium2Library locators. You can then pass in the
# keys to Selenium2Library actions instead of the locator
# strings.
selectors = {
"destination": "id=concatField",
"search button": "id=searchButton",
"arrival date": "id=spArrival",
"departure date": "id=spDeparture",
}
# Use robot_alias and the "__name__" token to customize
# where to insert the optional page object name
# when calling this keyword. Without the "__name__"
# token this method would map to either "Type In Search Box",
# or "Type In Search Box WDHomePage". Using "__name__" we can call
# "Type in Home Search Box foo".
@robot_alias("type_in__name__search_box")
def type_in_search_box(self, txt):
self.input_text("destination", txt)
# We always return something from a page object,
# even if it's the same page object instance we are
# currently on.
return self
@robot_alias("type_in__name__arrival_box")
def type_in_arrival_box(self, txt):
self.input_text("arrival date", txt)
# We always return something from a page object,
# even if it's the same page object instance we are
# currently on.
return self
@robot_alias("type_in__name__departure_box")
def type_in_departure_box(self, txt):
self.input_text("departure date", txt)
# We always return something from a page object,
# even if it's the same page object instance we are
# currently on.
return self
@robot_alias("click__name__search_button")
def click_search_button(self):
self.click_link("search button")
return SerpPage()
@robot_alias("search_weekends_for")
def search_for(self, concatField,spArrival,spDeparture):
self.type_in_search_box(concatField)
self.type_in_arrival_box(spArrival)
self.type_in_departure_box(spDeparture)
return self.click_search_button()
class SerpPage(Page):
"""Models a Serp search result page. For example:
http://www.weekendesk.fr/sejour/DTE6_070815RGN1_iPLC2_3iNGH1_5VRS1_9 /weekend-en-PACA """
# The URI for the SERP page does not have a template to follow
uri = ""
Name= "Serp"
# This is a "selector template". We are parameterizing the
# nth result in this xpath. We call this from click_result, below.
selectors = {
"nth result link": "div.searchResult:nth-child(1) > div:nth-child(1) > h2:nth-child(1) > a:nth-child(1)"
}
@robot_alias("click_result_on__name__")
def click_result(self, i):
# For selector templates, we need to resolve the selector to the
# locator first, before finding or acting on the element.
locator = self.resolve_selector("nth result link", n=int(i))
self.click_link(locator)
return ProductPage()
class ProductPage(Page):
uri = ""
Name="Product"
@robot_alias("__name__body_should_contain")
def body_should_contain(self, str, ignore_case=True):
ref_str = str.lower() if ignore_case else str
ref_str = ref_str.encode("utf-8")
body_txt = self.get_text("css=body").encode("utf-8").lower()
asserts.assert_true(ref_str in body_txt, "body text does not contain %s" %ref_str)
return self
我的库文件名是HomePage.py
谢谢
你要求做的应该是可能的,但是,如果没有看到你的机器人测试套件,你实际上并不清楚你在做什么。例如,如果你的库文件在 PYTHONPATH 上,你可以单独导入 类。例如,如果这是你的库文件,我将我的命名为 LibTest.py
:
from robot.api import logger
class LibTest:
def libtest_1(self):
logger.warn("In LibTest")
class OtherTest:
def othertest_1(self):
logger.warn("In OtherTest")
class OneMoreTest:
def onemoretest_1(self):
logger.warn("In OneMoreTest")
然后在您的测试套件中,您可以单独加载 类:
*** Settings ***
Library LibTest.LibTest
Library LibTest.OtherTest
Library LibTest.OneMoreTest
*** Test Cases ***
sometest
Log Test Start
libtest_1
othertest_1
onemoretest_1
此示例适用于我的环境:Python 2.7.6 和 Robot Framework 2.8.7。这是我输出的控制台:
20150831 12:48:49.449 : INFO : Test Start
20150831 12:48:49.450 : WARN : In LibTest
20150831 12:48:49.450 : WARN : In OtherTest
20150831 12:48:49.451 : WARN : In OneMoreTest
不过,我认为 Robot 确实在鼓励您将您的库 类 保存在单独的文件中 - 因为它更容易处理,即您不需要将它们放在一起在 PYTHONPATH 上。
我正在创建一个包含三个不同 classes 的 RobotFramework 库。 我可以使用第一个 class 关键字,但是我无法使用剩下的两个 classes 关键字。 根据 RF 文档,我尝试按以下方式使用导入 LibraryName.className 我还设置 python 路径到我的个人图书馆文件夹。 然而,当 运行 测试时,只有第一个 class 关键字被识别。 我试图将第一个 class 的名称更改为与我的 lib 文件不同的名称,并分别导入每个 class,但这对三个 class 的关键字不起作用。
这是我的库代码:
from robotpageobjects import Page, robot_alias
from robot.utils import asserts
class HomePage(Page):
""" Models WeekendDesk home page at:
HOST:weekendesk.fr/"""
name="Home"
# This is Then Keyword for Weekendesk Home Page.
# This page is found at baseurl"
uri = ""
# inheritable dictionary mapping human-readable names
# to Selenium2Library locators. You can then pass in the
# keys to Selenium2Library actions instead of the locator
# strings.
selectors = {
"destination": "id=concatField",
"search button": "id=searchButton",
"arrival date": "id=spArrival",
"departure date": "id=spDeparture",
}
# Use robot_alias and the "__name__" token to customize
# where to insert the optional page object name
# when calling this keyword. Without the "__name__"
# token this method would map to either "Type In Search Box",
# or "Type In Search Box WDHomePage". Using "__name__" we can call
# "Type in Home Search Box foo".
@robot_alias("type_in__name__search_box")
def type_in_search_box(self, txt):
self.input_text("destination", txt)
# We always return something from a page object,
# even if it's the same page object instance we are
# currently on.
return self
@robot_alias("type_in__name__arrival_box")
def type_in_arrival_box(self, txt):
self.input_text("arrival date", txt)
# We always return something from a page object,
# even if it's the same page object instance we are
# currently on.
return self
@robot_alias("type_in__name__departure_box")
def type_in_departure_box(self, txt):
self.input_text("departure date", txt)
# We always return something from a page object,
# even if it's the same page object instance we are
# currently on.
return self
@robot_alias("click__name__search_button")
def click_search_button(self):
self.click_link("search button")
return SerpPage()
@robot_alias("search_weekends_for")
def search_for(self, concatField,spArrival,spDeparture):
self.type_in_search_box(concatField)
self.type_in_arrival_box(spArrival)
self.type_in_departure_box(spDeparture)
return self.click_search_button()
class SerpPage(Page):
"""Models a Serp search result page. For example:
http://www.weekendesk.fr/sejour/DTE6_070815RGN1_iPLC2_3iNGH1_5VRS1_9 /weekend-en-PACA """
# The URI for the SERP page does not have a template to follow
uri = ""
Name= "Serp"
# This is a "selector template". We are parameterizing the
# nth result in this xpath. We call this from click_result, below.
selectors = {
"nth result link": "div.searchResult:nth-child(1) > div:nth-child(1) > h2:nth-child(1) > a:nth-child(1)"
}
@robot_alias("click_result_on__name__")
def click_result(self, i):
# For selector templates, we need to resolve the selector to the
# locator first, before finding or acting on the element.
locator = self.resolve_selector("nth result link", n=int(i))
self.click_link(locator)
return ProductPage()
class ProductPage(Page):
uri = ""
Name="Product"
@robot_alias("__name__body_should_contain")
def body_should_contain(self, str, ignore_case=True):
ref_str = str.lower() if ignore_case else str
ref_str = ref_str.encode("utf-8")
body_txt = self.get_text("css=body").encode("utf-8").lower()
asserts.assert_true(ref_str in body_txt, "body text does not contain %s" %ref_str)
return self
我的库文件名是HomePage.py
谢谢
你要求做的应该是可能的,但是,如果没有看到你的机器人测试套件,你实际上并不清楚你在做什么。例如,如果你的库文件在 PYTHONPATH 上,你可以单独导入 类。例如,如果这是你的库文件,我将我的命名为 LibTest.py
:
from robot.api import logger
class LibTest:
def libtest_1(self):
logger.warn("In LibTest")
class OtherTest:
def othertest_1(self):
logger.warn("In OtherTest")
class OneMoreTest:
def onemoretest_1(self):
logger.warn("In OneMoreTest")
然后在您的测试套件中,您可以单独加载 类:
*** Settings ***
Library LibTest.LibTest
Library LibTest.OtherTest
Library LibTest.OneMoreTest
*** Test Cases ***
sometest
Log Test Start
libtest_1
othertest_1
onemoretest_1
此示例适用于我的环境:Python 2.7.6 和 Robot Framework 2.8.7。这是我输出的控制台:
20150831 12:48:49.449 : INFO : Test Start
20150831 12:48:49.450 : WARN : In LibTest
20150831 12:48:49.450 : WARN : In OtherTest
20150831 12:48:49.451 : WARN : In OneMoreTest
不过,我认为 Robot 确实在鼓励您将您的库 类 保存在单独的文件中 - 因为它更容易处理,即您不需要将它们放在一起在 PYTHONPATH 上。