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"

不清楚您是在字面上使用字符串hostnameuname 等,还是只是出于问题目的的样板。您需要传递实际的主机名和实际的用户名和密码。

您可能不需要其他值的引号,在这种情况下,它看起来像这样:

*** Variables ***
$DBHost_ConnectionString  DRIVER=SQL Server;SERVER=hostname;UID=uname;PWD=******;DATABASE=dbname

【讨论】:

以上是关于RobotFramework 使用自定义参数连接到数据库的问题的主要内容,如果未能解决你的问题,请参考以下文章

使用 RobotFramework 连接到 H2 数据库文件

将参数化 BigQuery 自定义查询连接到数据洞察

无法通过 appium-RobotFramework 连接到 Android 模拟器

无法使用 pyodbc/pymssql 和 Robot Framework 连接到 SQL\Express

怎么样导入RobotFramework 自定义关键字

怎么样导入RobotFramework 自定义关键字