测试平台系列(55) 引入AceEditor(代码编辑器)

简介: 引入AceEditor(代码编辑器)

回顾


我们上一节已经写好了左侧数据表目录,今天继续完成sql编辑器的部分。

调研组件


  • monaco
    因为我们的项目用的是React,市面上很多编辑器都是js编写,react提供了一层方便的封装。
    比如我们在HTTP调试页面用的JSON编辑器,是以monaco为原型封装成的React组件

13.jpg

这个就是monaco

monaco呢,是微软开源的,大家熟悉的VsCode其实内部核心也是monaco。

优点是美观,专业,缺点是使用比较复杂

  • AceEditor
    用过yapi的人都知道,里面填写JSON_SCHEMA的时候用到了JSON编辑器,会校验你的JSON格式。里头的编辑器就是AceEditor
    我觉得它的优点就是功能比较强大,包括代码补全,UI响应都做的很棒,唯一的缺点可能就是主题很少,不太好看。
  • CodeMirror
    这是我最开始调研过的一款插件,包括大名鼎鼎的leetcode都是用的它。如果用好了自然非常牛逼,但我确实玩不太转,觉得里面的API太生硬了。
    React对应的实现: react-codemirror2
    唯一缺点就是使用困难,遇到问题不好解决

最终选型


由于AceEditor我在公司实现了一套,为了避免重复造轮子,花更多的时间去搞一套新的。我决定直接搬运过来。

当然如果以后有时间,我会向leetcode学习,做一个更好用的编辑器。

封装编辑器组件


14.jpg

简单看看就行

接受value, 语言,改变value的事件以及高度和theme。这样我们就可以对编辑器的主题,内容等进行完美控制

还是看看下最终页面成果吧~

15.jpg

image

页面分为3块,左侧是上一节编写好的部分,右侧上半部分是编辑器,下半部分是返回结果

16.jpg

选中db后的效果

17.jpg

自动补全

18.jpg

切换主题

19.jpg

执行后的结果

渐渐地成型了一点~

后端bug修复


先给大家道个歉,自己上一节写的代码没有经过很严谨的测试,导致出了一些问题:

  • 问题1: 多个fat环境

20.jpg

这个问题我现在是修复了

可以看到,出现了2个fat数据。

仔细找一下原因,发现是这里出了岔子:

21.jpg

image

这里我们添加好第一个fat数据后,idx=0对不,所以env_index里面的数据是这样的:


env_idx = {"fat": 0}

那么当第二个fat来了,会取到idx=0,判断if not idx,这里not idx自动隐式转换为True了,导致又append了一次result。

所以这时候我们需要换个判断方式if idx is None,这个判断代表字典里面没有这个key。

22.jpg

这样就ok了


  • 问题2: 天真的以为MetaData可以复用

23.jpg

get_tables这个方法

还记得get_tables里面这个metadata变量吗?之前是通过方法传递进来的参数,这样只需要实例化MetaData()一次。

但是坑就坑在,后续生成的数据,也会带上之前获得的表信息,所以我们还是不能复用这个对象。

改造online_sql方法


前面我们已经实现过在线执行sql的方法了,但是会发现有一些问题。

  • datetime不是我们想要的
    所以我们需要自行处理,拿到我们标准的datetime。

24.jpg

编写2个新的方法,方法json_serialize是针对datetime数据进行序列化

拿到字段里面的keys(),也就是列名,用于前端展示。

  • 对于update这种没有返回结果的方法没有兼容

25.jpg

如果sql没有返回值,那一定是delete/insert/update之类的语句

我们返回更新的行数就好,不管是增删还是

添加全局loading,使得体验更好。

26.jpg

加载数据表的过程会比较缓慢

后端未来优化


由于数据表不会一直修改,我们可以把他们的数据放到redis之中。这样我们效率会提高很多,加载速度也不会像现在这么慢。

最后,pg的支持还不是很完善,目前来说处于待测状态,有感兴趣的小伙伴可以提供下pg的连接或者自测一下。

数据库的配置需要管理员,如果你不是可以联系我,我给你添加。


今天的内容就港(肝)到这里了,数据库这块总算告一段落了大家`周末happy`


相关文章
|
28天前
|
关系型数据库 MySQL 测试技术
【分享】AgileTC测试用例管理平台使用分享
AgileTC 是一个脑图样式测试用例管理平台,支持用例设计、执行与团队协作,帮助测试人员高效管理测试流程。
172 116
【分享】AgileTC测试用例管理平台使用分享
|
26天前
|
人工智能 数据可视化 测试技术
AI测试平台自动遍历:低代码也能玩转全链路测试
AI测试平台的自动遍历功能,通过低代码配置实现Web和App的自动化测试。用户只需提供入口链接或安装包及简单配置,即可自动完成页面结构识别、操作验证,并生成可视化报告,大幅提升测试效率,特别适用于高频迭代项目。
|
1月前
|
人工智能 测试技术 调度
写用例写到怀疑人生?AI 智能测试平台帮你一键生成!
霍格沃兹测试开发学社推出AI智能测试用例生成功能,结合需求文档一键生成高质量测试用例,大幅提升效率,减少重复劳动。支持自定义提示词、多文档分析与批量管理,助力测试人员高效完成测试设计,释放更多时间投入核心分析工作。平台已开放内测,欢迎体验!
|
1月前
|
人工智能 测试技术 项目管理
测试不再碎片化:AI智能体平台「项目资料套件」功能上线!
在实际项目中,需求文档分散、整理费时、测试遗漏等问题常困扰测试工作。霍格沃兹推出AI智能体测试平台全新功能——项目资料套件,可将多个关联文档打包管理,并一键生成测试用例,提升测试完整性与效率。支持套件创建、文档关联、编辑删除及用例生成,适用于复杂项目、版本迭代等场景,助力实现智能化测试协作,让测试更高效、更专业。
|
2月前
|
存储 人工智能 算法
AI测试平台实战:深入解析自动化评分和多模型对比评测
在AI技术迅猛发展的今天,测试工程师面临着如何高效评估大模型性能的全新挑战。本文将深入探讨AI测试平台中自动化评分与多模型对比评测的关键技术与实践方法,为测试工程师提供可落地的解决方案。
|
4月前
|
存储 测试技术 虚拟化
VMmark 4.0.3 - 虚拟化平台基准测试
VMmark 4.0.3 - 虚拟化平台基准测试
95 0
VMmark 4.0.3 - 虚拟化平台基准测试
|
28天前
|
人工智能 自然语言处理 测试技术
AI测试平台的用例管理实践:写得清晰,管得高效,执行更智能
在测试过程中,用例分散、步骤模糊、回归测试效率低等问题常困扰团队。霍格沃兹测试开发学社推出的AI测试平台,打通“用例编写—集中管理—智能执行”全流程,提升测试效率与覆盖率。平台支持标准化用例编写、统一管理操作及智能执行,助力测试团队高效协作,释放更多精力优化测试策略。目前平台已开放内测,欢迎试用体验!
|
2月前
|
存储 人工智能 文字识别
从零开始打造AI测试平台:文档解析与知识库构建详解
AI时代构建高效测试平台面临新挑战。本文聚焦AI问答系统知识库建设,重点解析文档解析关键环节,为测试工程师提供实用技术指导和测试方法论
|
2月前
|
人工智能 安全 数据可视化
安全测试平台的选型标准与搭建思路
随着企业安全需求升级,传统漏洞扫描和渗透测试已无法满足要求。构建安全测试平台(STP)成为趋势,实现漏洞扫描、权限评估、接口测试等工作的平台化运营。本文从选型标准、平台架构、模块功能等六个方面,系统讲解如何搭建企业级安全测试平台,提升安全能力。
|
5月前
|
安全 前端开发 Linux
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台
167 3
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台