import pytest import allure import logging from utils.mysql_database_connection_utils import MysqlDBUtil class TestChaxun(): def mysql_connect(self): self.conn = MysqlDBUtil(host,port,user,password,db,charset) # def teardown_class(self): # self.conn.sql_close def test_chaxun(self): data=self.conn.query("SELECT * from stu WHERE name = '张三' ") print(data)
时间: 2024-04-28 11:21:07 浏览: 159
你对代码进行了修改,现在在 mysql_connect 方法中使用了 MysqlDBUtil 类的实例化对象来连接 MySQL 数据库,并传递了必要的参数(host,port,user,password,db,charset)。这样可以确保数据库连接成功,并可以执行 query 方法来查询数据。
这个实现在大多数情况下可以工作,但是你需要确保传递的参数是正确的,并且数据库已经正确地配置,才能使测试代码成功运行。另外,你可能需要在代码中添加一些错误处理代码,以便在出现错误时能够捕获并记录错误信息,从而更好地调试和修复问题。
相关问题
import pytest import allure import logging from utils.mysql_database_connection_utils import MysqlDBUtil class TestChaxun(): def mysql_connect(self): self.conn = MysqlDBUtil # def teardown_class(self): # self.conn.sql_close def test_chaxun(self): data=self.conn.query("SELECT * from stu WHERE name = '张三' ") print(data)
根据你的代码,我猜测你正在使用 pytest 和 allure 进行测试,并且你的测试代码中包含一个 TestChaxun 类,其中有一个名为 test_chaxun 的方法。这个方法中调用了一个叫做 mysql_connect 的方法,来连接 MySQL 数据库,并使用 MysqlDBUtil 类来进行数据库操作。在 test_chaxun 中,你使用了 query 方法来执行一个 SQL 查询,返回了符合条件的所有记录,并将结果打印出来。
不过,你的代码中有一个问题,就是在 mysql_connect 方法中,你没有实例化 MysqlDBUtil 类,而是直接将类名作为参数传递给了 conn 变量。你需要将这个变量赋值为 MysqlDBUtil 的实例,才能正确地连接数据库并进行操作。
import pymysql class MysqlDBUtil(): # 字典输出 def __init__(self, host, user, password, database, charset): # host = "localhost" # 指定访问的服务器,本地服务器指定“localhost”,远程服务器指定服务器ip地址 # port = 3306 # 指定端口号,范围在0-65535 # user = "root" # 用户名 # password = "123456" # 密码 # database = "sys" # 数据库的名字 # charset = "utf8" # 数据库的编码方式 # 建立连接 self.connect = pymysql.Connect(host=host, port=3306, user=user, passwd=password, db=database, charset=charset) # 数据库的查询 def query(self , sql): cursor = None res = None try: cursor = self.connect.cursor() cursor.execute(sql) res = cursor.fetchall() except Exception as e: print(str(e)) finally: cursor.close() return res # 数据库的增删改 def uid(self , sql): cursor = None try: cursor = self.connect.cursor() cursor.execute(sql) self.connect.commit() except Exception as e: print(str(e)) self.connect.rollback() finally: cursor.close() #数据库的关闭 def sql_close(self): self.connect.close() import pytest import allure import logging from utils.mysql_database_connection_utils import MysqlDBUtil import utils.mysql_database_connection_utils class TestChaxun(): def mysql_connect(self): self.conn = MysqlDBUtil("localhost", "root", "123456", "sys", "utf8") def teardown_class(self): self.conn.sql_close() def test1(self): data = self.conn.query("SELECT * from stu WHERE name = '张三' ") print(data)
这段代码中的问题可能是在TestChaxun类中的mysql_connect方法中,没有使用self关键字来定义conn属性。应该将mysql_connect方法中的 "self.conn" 更改为 "self.db",因为在类的初始化方法中已经定义了 "self.connect"。修改后的代码如下:
```
class TestChaxun():
def mysql_connect(self):
self.db = MysqlDBUtil("localhost", "root", "123456", "sys", "utf8")
def teardown_class(self):
self.db.sql_close()
def test1(self):
data = self.db.query("SELECT * from stu WHERE name = '张三' ")
print(data)
```
另外,你需要确保在运行测试之前已经安装了pytest和allure模块,并且将utils.mysql_database_connection_utils模块添加到PYTHONPATH中,以便测试代码能够正确地导入MysqlDBUtil类。
阅读全文