码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 二、Robot Framework 对数据库的操作


    Robot Framework 对数据库的操作

    • 2.1 DatabaseLibrary 库的使用
        • 1. 安装 DatabaseLibrary 库
        • 2. 测试套件中导入 DatabaseLibrary 库
        • 3. 安装 pure-PythonMySQL client library
      • 2.1.1 如何连接数据库
      • 2.1.2 如何断开数据库
      • 2.1.3 如何对数据库的表进行查询
      • 2.1.4 如何插入和删除数据
      • 2.1.5 如何执行数据库脚本文件
      • 2.1.6 DatabaseLibrary 库的其他操作关键字
    • 2.2 MongoDBLibrary 库的使用
        • 1. 安装 MongoDBLibrary 库
        • 2. 测试套件中导入 MongoDBLibrary 库
      • 2.2.1 MongoDB 数据库的连接和断开
        • 连接
        • 断开
      • 2.2.2 Get Mongodb Databases 和 Get Mongodb Collections
      • 2.2.3 Save Mongodb Records
      • 2.2.4 Retrieve All Mongodb Records
      • 2.2.5 Update Many Mongodb Records
      • 2.2.6 Remove Mongodb Records
      • 2.2.7 MongoDBLibrary 库的其他关键字

    2.1 DatabaseLibrary 库的使用

    Robot Framework 提供了 DatabaseLibrary 库来操作数据库

    • GitHub 上的 DatabaseLibrary 库

    1. 安装 DatabaseLibrary 库

    pip3 install -U robotframework-databaselibrary
    
    • 1

    请添加图片描述

    2. 测试套件中导入 DatabaseLibrary 库

    请添加图片描述

    3. 安装 pure-PythonMySQL client library

    可从 GitHub 下载安装或通过 pip:

    pip3 install PyMySQL
    
    • 1

    请添加图片描述

    2.1.1 如何连接数据库

    1. 通过 DatabaseLibrary 库中的 Connect To Database 关键字来连接一个 MySQL 数据库
      请添加图片描述
    2. 还可以通过 Connect To Database Using Custom Params 关键字来连接 MySQL 数据库
      请添加图片描述

    2.1.2 如何断开数据库

    可以通过关键字 Disconnect From Database 断开数据库连接,我们在操作数据库时一定不要忘记在操作完成后断开数据库的连接
    请添加图片描述

    2.1.3 如何对数据库的表进行查询

    通过 Query 关键字可以对数据库中的表进行查询
    请添加图片描述

    2.1.4 如何插入和删除数据

    可以通过 Execute Sql String 关键字来执行数据库的插入操作和删除操作

    1. 插入:执行 INSERT INTO ( ,,...) VALUES ('','',...)
      请添加图片描述
    2. 删除:执行 DELETE FROM WHERE =
      请添加图片描述

    2.1.5 如何执行数据库脚本文件

    在做自动化测试时,我们经常需要构造数据或者对库中的数据进行初始化,但是如果我们每次都是将要执行的数据库脚本按条写在用例中,那么将非常不好维护,因此我们需要直接执行数据库脚本文件

    在 DatabaseLibrary 库中,可以通过 Execute Sql Script 关键字来执行数据库脚本文件

    script.sql

    INSERT INTO city(Name,Population) VALUES ('Suzhou','1274.83 w');
    INSERT INTO city(Name,Population) VALUES ('Wuxi','747.95 w');
    
    • 1
    • 2

    请添加图片描述

    2.1.6 DatabaseLibrary 库的其他操作关键字

    请添加图片描述

    2.2 MongoDBLibrary 库的使用

    MongoDB 是非常常用的一个非关系型数据库,Robot Framework 提供了对 MongoDB 数据库测试操作的支持

    • GitHub 上的 MongoDBLibrary 库

    1. 安装 MongoDBLibrary 库

    pip install -U Robotframework-MongoDB-Library
    
    • 1

    请添加图片描述

    2. 测试套件中导入 MongoDBLibrary 库

    请添加图片描述

    2.2.1 MongoDB 数据库的连接和断开

    连接

    在 MongoDBLibrary 中通过 Connect To MongoDB 关键字来连接到 MongoDB 数据库

    • 该关键字接收 [ dbHost=localhost | dbPort=27017 | dbMaxPoolSize=10 |dbNetworkTimeout=None | dbDocClass= | dbTZAware=False ] 六个参数
      • dbHost :MongoDB 数据库的 IP 地址
      • dbPort:MongoDB 数据库的端口号,不输入时默认为27017
      • dbMaxPoolSize:数据库连接的最大线程池大小,不输入时默认大小为10

    请添加图片描述

    断开

    在 MongoDBLibrary 中通过 Disconnect From Mongodb 关键字来断开已经建立的 MongoDB 数据库连接
    请添加图片描述

    2.2.2 Get Mongodb Databases 和 Get Mongodb Collections

    在 MongoDBLibrary 中通过 Get Mongodb Databases 关键字来获取当前 MongoDB 下所有在用的数据库

    • 调用该关键字时可能会遇到问题 “‘Database’ object is not callable”

    请添加图片描述
    通过 Get Mongodb Collections 关键字可以获取到指定 MongoDB 数据库下的所有 Collection,该关键字接收[ dbName ]一个参数
    请添加图片描述

    2.2.3 Save Mongodb Records

    Save MongoDB Records 关键字用来向指定的 Collection 中保存插入的记录,接收[ dbName| dbCollName | recordJSON ]三个参数
    请添加图片描述

    2.2.4 Retrieve All Mongodb Records

    Retrieve All Mongodb Records 关键字用来获取指定 Collection 下的所有数据记录,接收[ dbName | dbCollName | returnDocuments=False ]三个参数
    请添加图片描述

    2.2.5 Update Many Mongodb Records

    Update Many Mongodb Records 关键字用来更新 Collection 中的数据记录,接收[dbName | dbCollName | queryJSON | updateJSON | upsert=False ]五个参数
    请添加图片描述

    2.2.6 Remove Mongodb Records

    Remove Mongodb Records 关键字用来删除指定 Collection 中的数据记录,接收 [dbName | dbCollName | recordJSON ] 三个参数
    请添加图片描述

    2.2.7 MongoDBLibrary 库的其他关键字

    请添加图片描述

  • 相关阅读:
    OB Cloud助力泡泡玛特打造新一代分布式抽盒机系统
    KeyShot for 3dMax插件教程
    Promise的基本用法
    华为机试真题 C++ 实现【水仙花数】
    springboot学习笔记
    2022年最新江苏交安安全员模拟真题及答案
    MySQL_06:多表查询
    20221205今天的世界发生了什么
    跨境电商面临“寒冬”考验,如何转型升级入局新赛道(Starday)
    Java设计模式:Callback
  • 原文地址:https://blog.csdn.net/Sally_xy/article/details/127838284
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号