RobotFramework 使用自定义参数连接到数据库的问题
Posted
技术标签:
【中文标题】RobotFramework 使用自定义参数连接到数据库的问题【英文标题】:Issue with RobotFramework Connect To Database Using Custom Params 【发布时间】:2021-04-17 13:28:39 【问题描述】:低于错误 OperationalError: ('08001', '[08001] [Microsoft][ODBC SQL Server Driver][DBNETLIB]SQL Server 不存在或拒绝访问。(17) (SQLDriverConnect); [08001] [Microsoft][ODBC SQL Server Driver ][DBNETLIB]ConnectionOpen (Connect()). (53)'
*** Settings ***
Documentation Simple example using DBLibrary.
Library SeleniumLibrary
Library DatabaseLibrary
*** Variables ***
$DBHost_ConnectionString 'DRIVER=SQL Server;SERVER="hostname";UID="uname";PWD="******";DATABASE="dbname"'
*** Test Cases ***
Connect Database
Connect To Database Using Custom Params pyodbc $DBHost_ConnectionString
我在互联网上尝试了所有解决方案,例如将端口添加到连接字符串,在服务器名称之前附加 tcp,等等, 遵循dbapi源码中提到的实现 https://github.com/franz-see/Robotframework-Database-Library/blob/master/src/DatabaseLibrary/connection_manager.py
elif dbapiModuleName in ["pyodbc", "pypyodbc"]:
dbPort = dbPort or 1433
logger.info('Connecting using : %s.connect(DRIVER=SQL Server;SERVER=%s,%s;DATABASE=%s;UID=%s;PWD=%s)' % (dbapiModuleName, dbHost, dbPort, dbName, dbUsername, dbPassword))
self._dbconnection = db_api_2.connect('DRIVER=SQL Server;SERVER=%s,%s;DATABASE=%s;UID=%s;PWD=%s' % (dbHost, dbPort, dbName, dbUsername, dbPassword))
任何帮助都应该感激。
【问题讨论】:
【参考方案1】:作为猜测,您不应该用单引号将连接字符串括起来,因为它们会成为连接字符串的一部分。 Robot 不是 python,robot 不是 shell,所以通常不需要引用字符串。
*** Variables ***
$DBHost_ConnectionString DRIVER=SQL Server;SERVER="hostname";UID="uname";PWD="******";DATABASE="dbname"
不清楚您是在字面上使用字符串hostname
和uname
等,还是只是出于问题目的的样板。您需要传递实际的主机名和实际的用户名和密码。
您可能不需要其他值的引号,在这种情况下,它看起来像这样:
*** Variables ***
$DBHost_ConnectionString DRIVER=SQL Server;SERVER=hostname;UID=uname;PWD=******;DATABASE=dbname
【讨论】:
以上是关于RobotFramework 使用自定义参数连接到数据库的问题的主要内容,如果未能解决你的问题,请参考以下文章
使用 RobotFramework 连接到 H2 数据库文件
无法通过 appium-RobotFramework 连接到 Android 模拟器