【项目】智能BI洞察引擎 测试报告

目录

  • 一、项目背景
    • BI介绍
    • 问题分析
    • 项目背景
  • 二、项目功能
  • 三、功能测试
    • 1、登录测试
      • 测试用例
      • 测试结果
    • 2、注册测试
      • 测试用例
      • 测试结果
      • 出现的bug
    • 3、上传文件测试
      • 测试用例
      • 测试结果
    • 4、AI生成图表测试
      • 测试用例
      • 测试结果
    • 5、分析数据页面测试(异步)
      • 测试用例
      • 测试结果
    • 6、图表列表页面测试
      • 测试用例
      • 测试结果
  • 四、自动化测试
    • 整体架构模式
    • 登录注册页面
    • AI生产图表页面测试
    • 图表列表页面测试
      • 自动化测试遇到的问题
        • 元素定位不到:
        • 编写自动化测试代码看不到效果
        • StaleElementReferenceException

项目地址:
项目代码:Gitee

一、项目背景

BI介绍

BI: Business Intelligence
即商业智能:数据可视化、报表可视化系统
主流BI平台:
FineBI、PowerBI

https://chartcube.alipay.com/

在这里插入图片描述

问题分析

  1. 需要人工上传数据
  2. 需要人工拖选分析要用到的数据行和列(数据分析师)
  3. 需要人工选择图表类型(数据分析师)
  4. 生成图表并保持配置

项目背景

区别于传统的 BI,用户(数据分析者)只需要导入最最最原始的数据集,输入想要进行分析的目标(比如帮我分析一下网站的增长趋势),就能利用 AI 自动生成一个符合要求的图表以及结论,实现数据分析的降本增效

二、项目功能

  1. 用户的登录和注册 --用户输入账号密码登录注册
  2. 智能分析:
    – 用户上传excel文件,分析目标(图表类型)
    – 对接AI能力 – 对接讯飞星火大模型分析数据
    –自动生成图表和分析结论
  3. 图表管理功能 – 点击图表管理,用户可以看到自己需要生成的数据分析结果和数据分析状态
  4. 异步化图表生成 – 对图表生成的优化
    在这里插入图片描述

三、功能测试

软件环境:win11 Google Chrome 131.0.6778.205 mysql 5.7

测试用例总览
在这里插入图片描述

1、登录测试

测试用例

在这里插入图片描述

测试结果

  1. 页面显示在这里插入图片描述

  2. 正常登录 (显示登录成功)在这里插入图片描述

  3. 异常登录
    在这里插入图片描述
    在这里插入图片描述

2、注册测试

测试用例

在这里插入图片描述

测试结果

点击注册:
显示该页面不存在
在这里插入图片描述

404 一般是路径问题
后端注册接口为:/api/user/register
后端注册接口没问题
在这里插入图片描述

出现的bug

bug:openapi自动生成了 前后端交互部分,但是前端没有是实现这个注册页面
在这里插入图片描述

3、上传文件测试

测试用例

在这里插入图片描述

测试结果

  1. 正常上传
    在这里插入图片描述
    在这里插入图片描述
  2. 异常上传
    在这里插入图片描述
    yml文件也可以上传成功,这里前端未校验文件格式
    点击提交(后端校验文件格式),显示分析失败
    在这里插入图片描述

4、AI生成图表测试

测试用例

在这里插入图片描述

测试结果

在这里插入图片描述
分析结论和可视化图表展示正常
在这里插入图片描述
鼠标光标定位显示正常

5、分析数据页面测试(异步)

测试用例

在这里插入图片描述

测试结果

在这里插入图片描述

6、图表列表页面测试

测试用例

在这里插入图片描述

测试结果

  • 无数据时显示
    在这里插入图片描述

  • 历史图表显示情况

  • 在测试时输入新的数据出现bug

异常情况:
在这里插入图片描述
解决:观察数据库,AI生成的echarts的json配置不正确,导致前端界面显示正常,预设的 promote 需要重新调整
调整后:

String predefinedInformation = “你是一个数据分析师和前端开发专家,接下来我会按照以下固定格式给你提供内容:\n” +
“分析需求:\n” +
“{数据分析的需求或者目标}\n” +
“原始数据:\n” +
“{csv格式的原始数据,用,作为分隔符}\n” +
“请根据这两部分内容,严格按照以下指定格式生成内容(此外不要输出任何多余的开头、结尾、注释)同时不要使用这个符号 ‘】’\n” +
“‘【【【【【’\n” +
“{前端 Echarts V5 的 option 配置对象 JSON 代码, 不要生成任何多余的内容,比如注释和代码块标记}\n” +
“‘【【【【【’\n” +
“{明确的数据分析结论、越详细越好,不要生成多余的注释} \n”
+ “下面是一个具体的例子的模板:”
+ “‘【【【【【’\n”
+ “JSON格式代码”
+ “‘【【【【【’\n” +
“结论:”;

将后端错误数据逻辑删除,显示正常
在这里插入图片描述

  • 搜索功能
    存在情况在这里插入图片描述
    不存在情况
    在这里插入图片描述

四、自动化测试

整体架构模式

在这里插入图片描述

登录注册页面

测试点
在这里插入图片描述

自动化代码


package tests;

import common.Utils;
import org.openqa.selenium.By;


import java.io.IOException;

public class LoginPage extends Utils {
    public static String url = "http://localhost:8000/user/login";
    public LoginPage() {
        super(url);
    }


    // 检查登录功能 -- 登录成功
    public void loginSuc() throws InterruptedException, IOException {

//        String title = driver.getTitle();
//        // 断言
//        assert title.equals("");

        // 清空输入框里的数据


        driver.findElement(By.cssSelector("#root > div > div > div > div.ant-pro-form-login-top.css-dev-only-do-not-override-1wwf28x.css-dev-only-do-not-override-1wwf28x > div.ant-pro-form-login-desc.css-dev-only-do-not-override-1wwf28x > a"));


        // 先清除输入框
        driver.findElement(By.cssSelector("#userAccount")).clear();
        driver.findElement(By.cssSelector("#userPassword")).clear();

        Thread.sleep(2000);
        driver.navigate().refresh();

        // 账号密码正确
        driver.findElement(By.cssSelector("#userAccount")).sendKeys("admin");
        driver.findElement(By.cssSelector("#userPassword")).sendKeys("admin123");
        driver.findElement(By.cssSelector("#root > div > div > div > div.ant-pro-form-login-main.css-dev-only-do-not-override-1wwf28x > form > button")).click();


//        driver.navigate().back();

        Thread.sleep(2000);
    }

    // 检查登录功能 -- 登录失败
    public void loginFail() throws IOException, InterruptedException {


        // 检查元素
        driver.findElement(By.cssSelector("#root > div > div > div > div.ant-pro-form-login-top.css-dev-only-do-not-override-1wwf28x.css-dev-only-do-not-override-1wwf28x > div.ant-pro-form-login-desc.css-dev-only-do-not-override-1wwf28x > a"));


        // 先清除输入框
        driver.findElement(By.cssSelector("#userAccount")).clear();
        driver.findElement(By.cssSelector("#userPassword")).clear();

        // 密码错误情况
        driver.findElement(By.cssSelector("#userAccount")).sendKeys("admwqwin");
        driver.findElement(By.cssSelector("#userPassword")).sendKeys("admin123");
        driver.findElement(By.cssSelector("#root > div > div > div > div.ant-pro-form-login-main.css-dev-only-do-not-override-1wwf28x > form > button")).click();
        // 检查是否登录成功
        Utils.getScreenshot("loginFail");


    }

}

登成功失败页面

AI生产图表页面测试

测试点:
在这里插入图片描述

上传文件代码

      // 定位上传文件按钮
        WebElement fileInput = driver.findElement(By.cssSelector("input[type='file']"));
        String filePath = "D:\\dev-BI\\bi-backend\\backend\\bi-backend\\src\\main\\resources\\测试数据.xlsx";
        fileInput.sendKeys(filePath);

自动化代码

package tests;

import common.Utils;
import org.openqa.selenium.By;
import org.openqa.selenium.WebElement;

import java.io.IOException;
import java.util.concurrent.TimeUnit;

public class BiCreatePage extends Utils {
    public static String url = "http://localhost:8000/add_chart";
    public BiCreatePage() {
        super(url);
    }
    public void biCreate() throws InterruptedException, IOException {
        // 隐式等待 
        driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);

        // 检查元素
        driver.findElement(By.cssSelector("#root > div > div.ant-layout.css-dev-only-do-not-override-1wwf28x > div > main > div.add-chart > div > div:nth-child(2) > div:nth-child(3) > div.ant-card-body > div:nth-child(1)"));
        System.out.println("succeed!!!");
        driver.findElement(By.cssSelector("#addChart_goal")).sendKeys("分析一下专业情况");
        driver.findElement(By.cssSelector("#addChart_name")).sendKeys("专业分析图");

        driver.findElement(By.cssSelector("#addChart > div:nth-child(3) > div > div.ant-col.ant-col-16.ant-form-item-control.css-dev-only-do-not-override-1wwf28x > div > div > div > div > span > span.ant-select-selection-search"));

        // 定位图表类型下拉框
        WebElement chartTypeDropdown = driver.findElement(By.cssSelector(".ant-select"));
        chartTypeDropdown.click();
        // 定位折线图选项并点击
        WebElement lineChartOption = driver.findElement(By.cssSelector(".ant-select"));
        lineChartOption.click();
        // 定位上传文件按钮
        WebElement fileInput = driver.findElement(By.cssSelector("input[type='file']"));
        String filePath = "D:\\dev-BI\\bi-backend\\backend\\bi-backend\\src\\main\\resources\\测试数据.xlsx";
        fileInput.sendKeys(filePath);
        System.out.println("---------------------wfe----------------");

        WebElement submitButton = driver.findElement(By.cssSelector(".ant-btn-primary"));
        submitButton.click();
    }
}

AI生成图表自动化测试

图表列表页面测试

在这里插入图片描述

图表管理自动化测试

自动化测试遇到的问题

元素定位不到:
  • js渲染需要时间,自动化已经开始下一步了,通过添加等待的方式
  • ant design pro 框架有特殊的cssSelector 比如 .ant-btn-primary、.ant-select,通过这种方式定位元素。
  • 要定位的元素为动态元素,每次打开对应的元素名不一样
编写自动化测试代码看不到效果
  • 通过添加等待,来观察效果
StaleElementReferenceException
  • 页面刷新或导航后,原来的 WebElement 对象变得无效。
  • 元素所在的 iframe 或者 shadow DOM 发生了变化。
  • 动态加载的内容导致元素被重新渲染。
  • StaleElementReferenceException 可能是由于页面刷新或元素被重新渲染后,之前的 WebElement 对象变得无效。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/946264.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

年会头投票小游戏

原型预览 源码 https://github.com/open-frame/vote 原型源文件 https://download.csdn.net/download/qq_42618566/90206788

活动预告 |【Part1】Microsoft Azure 在线技术公开课:基础知识

课程介绍 参加“Azure 在线技术公开课:基础知识”活动,培养有助于创造新的技术可能性的技能并探索基础云概念。参加我们举办的本次免费培训活动,扩充自身的云模型和云服务类型知识。你还可以查看以计算、网络和存储为核心的 Azure 服务。 活…

springboot499基于javaweb的城乡居民基本医疗信息管理系统(论文+源码)_kaic

摘 要 信息数据从传统到当代,是一直在变革当中,突如其来的互联网让传统的信息管理看到了革命性的曙光,因为传统信息管理从时效性,还是安全性,还是可操作性等各个方面来讲,遇到了互联网时代才发现能补上自古…

Java高级

1.反射 每个类都有一个唯一的类对象,该对象是 java.lang.Class 类型。【是 Java 类的元数据(metadata)对象,包含了该类的结构信息和其他相关数据】 获取类对象 1.什么是类对象 public class Daughter extends Parent{ …

HarmonyOS NEXT 实战之元服务:静态案例效果---我的热门应用服务

背景: 前几篇学习了元服务,后面几期就让我们开发简单的元服务吧,里面丰富的内容大家自己加,本期案例 仅供参考 先上本期效果图 ,里面图片自行替换 效果图1完整代码案例如下: Index import { authentica…

libvirt学习

文章目录 libvirt 简介节点、Hypervisor和域libvirt 安装和配置libvirt的XML配置文件libvirt APIMain libvirt APIsError handlingSpecial specific APIs 建立到Hypervisor的连接libvirt API使用编译libvirt工具virshvirt-clonevirt-dfvirt-imagevirt-installvirt-topvirt-what…

“进制转换”公式大集合

咱们都知道十进制是“逢10进1 ”,同理,N进制就是 “逢N进1”。进制其实就这么简单。它的麻烦之处在于各种进制之间的转换。 一、十进制整数转N进制 1.十进制转二进制 除2取余法:连续除以2,直到商为0,逆序…

线程-3-线程控制

线程资源共享 线程间绝大部分资源都是共享的(堆栈共享区) 线程间堆空间是共享的 谁拿着堆空间的入口地址,谁就能访问 共享区也是共享的(cout,printf库都在共享区) 线程间有权限访问/修改其他线程栈数据&…

1、ELK的架构和安装

ELK简介 elk:elasticsearch logstash kibana,统一日志收集系统。 elasticsearch:分布式的全文索引引擎的非关系数据库,json格式,在elk中存储所有的日志信息,架构有主和从,最少需要2台。 …

MetaRename for Mac,适用于 Mac 的文件批量重命名工具

在处理大量文件时,为每个文件手动重命名既耗时又容易出错。对于摄影师、设计师、开发人员等需要频繁处理和整理文件的专业人士来说,找到一款能够简化这一过程的工具是至关重要的。MetaRename for Mac 就是这样一款旨在提高工作效率的应用程序&#xff0c…

方正畅享全媒体新闻采编系统 imageProxy.do 任意文件读取漏洞复现

0x01 产品简介 方正畅享全媒体新闻生产系统是以内容资产为核心的智能化融合媒体业务平台,融合了报、网、端、微、自媒体分发平台等全渠道内容。该平台由协调指挥调度、数据资源聚合、融合生产、全渠道发布、智能传播分析、融合考核等多个平台组成,贯穿新闻生产策、采、编、发…

【Unity3d】C#浮点数丢失精度问题

一、float、double浮点数丢失精度问题 Unity3D研究院之被坑了的浮点数的精度(一百零三) | 雨松MOMO程序研究院 https://segmentfault.com/a/1190000041768195?sortnewest 浮点数丢失精度问题是由于大部分浮点数在IEEE754规范下就是无法准确以二进制…

Flink CDC 自定义函数处理 SQLServer XML类型数据 映射 doris json字段方案

Flink CDC 自定义函数处理 SQLServer XML类型数据方案 1. 背景 因业务使用SQLServer数据库,CDC同步到doris 数仓。对于SQLServer xml类型,doris没有相应的字段对应, 可以使用json来存储xml数据。需要进行一步转换。从 flink 自定义函数入手…

详解云桌面3种主流架构

本文简要介绍下云桌面(云电脑)的3种主流架构:VDI、IDV和VOI,概念、原理和区别,欢迎阅读。 云桌面作为桌面办公和云计算融合发展的产物,在一定程度上替代了传统的办公形式。目前阿里云、华为云、移动云、电…

按照人们阅读Excel习惯来格式化BigDecimal

1、环境/问题描述 使用springboot发送邮件(附件)的方式将月度报表发送给领导查阅,数据是准确的,领导基本满意。 就是对一些数字的格式化提出了改进建议,比如不要让大数字自动转为科学计数法、浮点数小数点后都是0就不要带出来,根…

深入解析:谱分解、SVD与PCA在算法中的应用与实现

特征值分解(EVD)、奇异值分解(SVD)和主成分分析(PCA)是矩阵分解技术的三种重要形式,它们在人工智能中扮演了关键角色。随着数据维度的快速增长和信息复杂度的提升,这些技术为处理高维…

连接Milvus

连接到Milvus 验证Milvus服务器正在侦听哪个本地端口。将容器名称替换为您自己的名称。 docker port milvus-standalone 19530/tcp docker port milvus-standalone 2379/tcp docker port milvus-standalone 192.168.1.242:9091/api/v1/health 使用浏览器访问连接地址htt…

记录一个我在idea启动时的报错

这几天我的idea突然就不能用了我就想着下一个新的,但是却一直报错报错内容如下 这个是我在网上截的pycharm的。 我在网上查了很多方法都不能用,今天重写安装发现我点了关联.java 和.pom和创建环境变量 这几个只需要创建一个快捷方式就行。我重新安装之…

使用maven-mvnd替换maven大大提升编译打包速度

先上结论!!! 多模块清理并打包提升:约3.5倍 多模块不清理打包提升:约5.5倍 单模块提升:约2倍 从计算结果来看,多模块提升的效率更高。在使用mvnd package打包多模块式,可在控制台…

【从零开始入门unity游戏开发之——C#篇43】C#补充知识——值类型和引用类型汇总补充、变量的生命周期与性能优化、值类型和引用类型组合使用

文章目录 一、值类型和引用类型汇总补充1、值类型和引用类型汇总2、值类型和引用类型的区别3、简单的判断值类型和引用类型 二、变量的生命周期与性能优化1、**栈和堆的区别**2、**变量生命周期**3、**垃圾回收(GC)机制**4、**代码示例与优化**4.1. 临时…