找回密码
 立即注册
首页 业界区 安全 12K+ Star!新一代的开源持续测试工具!

12K+ Star!新一代的开源持续测试工具!

猷浮 5 小时前
大家好,我是 Java陈序员。
在企业软件研发的持续交付流程中,测试环节往往是影响效率的关键瓶颈,用例管理混乱、接口调试复杂、团队协作不畅、与 DevOps 流程脱节等问题都能影响软件交付。
今天,给大家介绍一款开源持续测试工具,让测试工作变得简单高效!
关注微信公众号:【Java陈序员】,获取开源项目分享、AI副业分享、超200本经典计算机电子书籍等。
项目介绍

MeterSphere —— 新一代的开源持续测试工具,让软件测试工作更简单、更高效,不再成为持续交付的瓶颈。
功能特色

  • 一体化测试管理:从测试用例管理,到测试计划执行、缺陷管理、测试报告生成,具有远超 TestLink 等传统测试管理工具的使用体验
  • 强大的接口测试能力:集 Postman 的易用与 JMeter 的灵活于一体,接口调试、接口定义、接口 Mock、场景自动化、接口报告,你想要的都有
  • 适配团队协作:采用“系统-组织-项目”分层的设计理念实现多层级权限管控,帮助用户摆脱单机测试工具的束缚,方便快捷地开展团队协作
  • 灵活扩展与集成:提供各种类别的插件,用户可以按需取用,快速实现 MeterSphere 测试能力的扩展以及与 DevOps 流水线的集成
技术栈

  • 后端:SpringBoot + MySQL + Kafka + MinIO + Redis
  • 前端:Vue.js
快速上手

MeterSphere 支持在线/离线安装、1Panel 安装、Docker 安装、K8S 部署等多种方式,可使用 Dokcer 完成快速部署。
1、拉取镜像
  1. docker pull metersphere/metersphere-ce-allinone
复制代码
2、创建挂载目录
  1. mkdir -p /data/software/metersphere
复制代码
3、运行容器
  1. docker run -d -p 8081:8081 \
  2.     --name=metersphere \
  3.     -v /data/software/metersphere:/opt/metersphere/data \
  4.     metersphere/metersphere-ce-allinone
复制代码
4、容器运行成功后,浏览器访问
  1. http://{ip/域名}:8081
复制代码
默认管理员用户名密码:admin/metersphere.
功能体验


  • 工作台
1.png


  • 项目管理
2.png

3.png


  • 测试计划
4.png

5.png


  • 测试用例
6.png

7.png

8.png


  • 接口测试
9.png


  • 缺陷管理
10.png


  • 系统设置
11.png

本地开发

环境准备

1、MeterSphere 后端使用了 Java 语言的 Spring Boot 框架,并使用 Maven 作为项目管理工具,项目依赖如下:

  • JDK 21
  • MySQL8
  • Redis
  • Kafka
  • Minio
  • Node.js
2、克隆或下载项目源码,并切换到 v3.x 分支
  1. git clone https://github.com/metersphere/metersphere.git
复制代码
3、项目结构
  1. .
  2. ├── Jenkinsfile                                     # 构建镜像使用的 jenkinsfile
  3. ├── Dockerfile                                      # 构建镜像使用的 Dockerfile
  4. ├── LICENSE
  5. ├── OWNERS
  6. ├── README.md                                       # 项目中文介绍
  7. ├── README-EN.md                                    # 项目英文介绍
  8. ├── SECURITY.md                                     # 安全说明
  9. ├── CODE_OF_CONDUCT.md                              #
  10. ├── CONTRIBUTING.md
  11. ├── build.md                                        # 构建过程
  12. ├── backend                                         # 后端项目主目录
  13. │   ├── app                                   
  14. │   ├── framework
  15. │   ├── app
  16. │   ├── pom.xml                               # 后端 maven 项目使用的 pom 文件
  17. │   └── .gitignore                                 
  18. ├── frontend                                        # 前端项目主目录
  19. │   ├── .husky
  20. │   ├── config                                # 项目构建配置
  21. │   ├── public
  22. │   ├── src                                   # 前端代码目录
  23. │   ├── types
  24. │   ├── .env.development                      # 开发环境变量声明
  25. │   ├── .env.production                       # 生产环境变量声明
  26. │   ├── .eslintignore
  27. │   ├── .eslintrc.js
  28. │   ├── .eslintrc-auto-import.json
  29. │   ├── .gitignore
  30. │   ├── .prettierignore
  31. │   ├── .prettierrc.js
  32. │   ├── .stylelintrc.js
  33. │   ├── babel.config.js
  34. │   ├── commitlint.config.js                   # commitlint 配置,校验 commit 信息
  35. │   ├── components.d.ts                        # 组件注册 TS 声明
  36. │   ├── Dockerfile                             # 构建前端应用使用的 Dockerfile
  37. │   ├── index.html                             # 单页面html模板
  38. │   ├── nginx.conf                             # Nginx 配置文件
  39. │   ├── package.json                           # 前端项目中的元数据文件
  40. │   ├── pom.xml                                # 前端 maven 项目使用的 pom 文件
  41. │   ├── postcss.config.js
  42. │   ├── README.md
  43. │   ├── tailwind.config.js
  44. │   ├── tsconfig.json
  45. │   ├── vitest.config.ts
  46. │   ├── .editorconfig
  47. │   ├── .gitignore
  48. │   ├── babel.config.js                        # babel配置,支持JSX
  49. │   ├── package.json
  50. │   ├── vue.config.js                              
  51. │   └── 代码规范.MD                                   
  52. ├── .gitignore
  53. ├── mvnw
  54. ├── mvnw.cmd
  55. └── pom.xml                                           # 整体 maven 项目使用的 pom 文件
复制代码
后端服务

1、将整个项目以 Maven 工程的形式导入到 IDEA
2、在 MySQL8 中创建数据库
  1. CREATE DATABASE metersphere /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci *//*!80016 DEFAULT ENCRYPTION='N'*/;
复制代码
3、MeterSphere 会默认加载配置文件 /opt/metersphere/conf/metersphere.properties, 参考下列配置创建对应目录及配置文件
  1. # 数据库配置
  2. spring.datasource.url=jdbc:mysql://localhost:3306/metersphere?autoReconnect=false&useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8&zeroDateTimeBehavior=convertToNull&useSSL=false
  3. spring.datasource.username=root
  4. spring.datasource.password=root
  5. # kafka 配置,result-hub 服务需要使用 kafka 进行测试结果的收集和处理
  6. kafka.bootstrap-servers=localhost:9092
  7. # minio 配置
  8. minio.endpoint=http://localhost:9000
  9. minio.access-key=admin
  10. minio.secret-key=admin@minio
复制代码
4、MeterSphere 会默认加载 Redis 配置文件 /opt/metersphere/conf/redisson.yml, 参考下列配置创建对应目录及配置文件
  1. # Redis 配置
  2. singleServerConfig:
  3.   address: "redis://localhost:6379"
  4.   password: Password123@redis
  5.   database: 1
复制代码
5、运行主启动类 io.metersphere.Application 启动服务
前端服务

1、进入前端工程项目
  1. cd front/
复制代码
2、安装依赖
  1. pnpm install
  2. # 推荐使用 pnpm 安装依赖,如未安装 pnpm 可使用如下命令进行安装
  3. npm install pnpm -g
复制代码
3、打开配置文件 .env.development, 参考如下配置修改后端服务地址
  1. VITE_API_BASE_URL= 'front'
  2. VITE_DEV_DOMAIN='http://localhost:8081/'
复制代码
4、启动服务
  1. pnpm run dev
复制代码
5、浏览器访问
  1. http://localhost:5173
复制代码
默认管理员用户名密码:admin/metersphere.
可以说,无论是小型团队的测试需求,还是大型企业的复杂测试场景,MeterSphere 都能出色地完成工作,助力企业研发团队实现更高效的持续交付~
  1. 项目地址:https://github.com/metersphere/metersphere
复制代码
最后

推荐的开源项目已经收录到 GitHub 项目,欢迎 Star:
  1. https://github.com/chenyl8848/great-open-source-project
复制代码
或者访问网站,进行在线浏览:
  1. https://chencoding.top:8090/#/
复制代码
12.png

我创建了一个开源项目交流群,方便大家在群里交流、讨论开源项目
但是任何人在群里打任何广告,都会被 T 掉
如果你对这个交流群感兴趣或者在使用开源项目中遇到问题,可以通过如下方式进群
关注微信公众号:【Java陈序员】,回复【开源项目交流群】进群,或者通过公众号下方的菜单添加个人微信,并备注【开源项目交流群】,通过后拉你进群
大家的点赞、收藏和评论都是对作者的支持,如文章对你有帮助还请点赞转发支持下,谢谢!

来源:豆瓜网用户自行投稿发布,如果侵权,请联系站长删除

相关推荐

您需要登录后才可以回帖 登录 | 立即注册