# MeterSphere 一站式开源持续测试平台

[![Codacy Badge](https://api.codacy.com/project/badge/Grade/176186d132df448b955f8bdd5e6ef9c0)](https://app.codacy.com/gh/metersphere/metersphere?utm_source=github.com&utm_medium=referral&utm_content=metersphere/metersphere&utm_campaign=Badge_Grade_Dashboard)
[![GitHub release (latest SemVer)](https://img.shields.io/github/v/release/metersphere/metersphere)](https://github.com/metersphere/metersphere/releases/latest)
[![GitHub All Releases](https://img.shields.io/github/downloads/metersphere/metersphere/total)](https://github.com/metersphere/metersphere/releases)
[![TesterHome](https://img.shields.io/badge/TTF-TesterHome-2955C5.svg)](https://testerhome.com/github_statistics)

> [English](README-EN.md) | 中文

| Developer Wanted                                                                                             |
| ------------------------------------------------------------------------------------------------------------ |
| 我们正在寻找开发者,欢迎加入我们共同打造更好用、更强大的 MeterSphere。联系我们: [metersphere@fit2cloud.com](mailto:metersphere@fit2cloud.com) |

MeterSphere 是一站式开源持续测试平台,涵盖测试跟踪、接口测试、性能测试、团队协作等功能,兼容JMeter 等开源标准,有效助力开发和测试团队充分利用云弹性进行高度可扩展的自动化测试,加速高质量软件的交付。

-   测试跟踪: 远超 TestLink 的使用体验,覆盖从编写用例到生成测试报告的完整流程;
-   接口测试: 集 Postman 的易用与 JMeter 的灵活于一体,接口管理、多协议支持、场景自动化,你想要的全都有;
-   性能测试: 兼容 JMeter,支持 Kubernetes 和云环境,轻松支持高并发、分布式的性能测试;
-   团队协作: 用户管理、租户管理、权限管理、资源管理,无论团队规模如何,总有适合的落地方式。

![产品定位](https://metersphere.oss-cn-hangzhou.aliyuncs.com/img/ct-devops.png)

> 如需进一步了解 MeterSphere 开源项目,推荐阅读 [MeterSphere 的初心和使命](https://mp.weixin.qq.com/s/DpCt3BNgBTlV3sJ5qtPmZw)

## 在线体验

-   环境地址:<https://demo.metersphere.com/>
-   用户名:demo
-   密码:P@ssw0rd123..

| :warning: 注意                 |
| :--------------------------- |
| 该环境仅作体验目的使用,我们会定时清理、重置数据!    |
| 请勿修改体验环境用户的密码!               |
| 请勿在环境中添加业务生产环境地址、用户名密码等敏感信息! |

## 快速开始

仅需两步快速安装 MeterSphere:

1.  准备一台不小于 8 G内存的 64位 Linux 主机;
2.  以 root 用户执行如下命令一键安装 MeterSphere。

```sh
curl -sSL https://github.com/metersphere/metersphere/releases/latest/download/quick_start.sh | sh
```

文档和演示视频:

-   [完整文档](https://metersphere.io/docs/)
-   [演示视频](http://video.fit2cloud.com/%E3%80%90%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91%E3%80%91202006%20MeterSphere%20v1.0%20%E5%8A%9F%E8%83%BD%E6%BC%94%E7%A4%BA.mp4)

## MeterSphere 企业版

[申请企业版使用](https://jinshuju.net/f/CzzAOe)

> 注: 企业版支持离线安装,申请通过后会提供高速下载链接

## 相关工具

-   [Jenkins 插件](https://github.com/metersphere/jenkins-plugin)
-   [浏览器插件](https://github.com/metersphere/chrome-extensions)

## 版本说明

MeterSphere 版本号命名规则为:v大版本.功能版本.Bug修复版本。比如:

```text
v1.0.1 是 v1.0.0 之后的Bug修复版本;
v1.1.0 是 v1.0.0 之后的功能版本。
```

像其它优秀开源项目一样,MeterSphere 将每月发布一个功能版本。

## 产品优势

-   开源:基于开源、兼容开源;按月发布新版本、日均下载安装超过100次、被大量客户验证;
-   一站式:一个产品全面涵盖测试跟踪、接口测试、性能测试等功能并形成联动:其中用例管理是底座需求、接口自动化测试是高频需求、性能测试是专家服务为主工具为辅;一个产品全满足从测试计划、测试执行到测试报告分析的全生命周期需求;
-   持续测试:能将测试融入持续交付和 DevOps 体系;无缝对接 Bug 管理工具和持续集成工具等;支持团队协作和资产沉淀。

## 功能列表

<table>
    <tbody>
        <tr>
            <td rowspan="17">测试跟踪</td>
            <td>项目管理</td>
            <td>多项目支持,测试用例、测试计划与项目关联</td>
        </tr>
        <tr>
            <td rowspan="4">测试用例管理</td>
            <td>在线编辑用例</td>
        </tr>
        <tr>
            <td>以树状形式展示项目的模块及其用例</td>
        </tr>
        <tr>
            <td>自定义用例属性</td>
        </tr>
        <tr>
            <td>快速导入用例到系统</td>
        </tr>
                <tr>
            <td rowspan="4">测试用例评审</td>
            <td>基于已有用例发起评审</td>
        </tr>
        <tr>
            <td>在线更新评审结果</td>
        </tr>
        <tr>
            <td>支持多人在线添加评审评论</td>
        </tr>
        <tr>
            <td>灵活的评审人分配形式</td>
        </tr>
        <tr>
            <td rowspan="8">测试计划跟踪</td>
            <td>基于已有用例发起测试计划</td>
        </tr>
        <tr>
            <td>在线更新用例执行结果</td>
        </tr>
        <tr>
            <td>灵活的用例分配方式</td>
        </tr>
        <tr>
            <td>在线生成测试报告,支持自定义测试报告模板</td>
        </tr>
        <tr>
            <td>与平台中的接口测试、性能测试功能结合,自动更新关联用例的结果</td>
        </tr>
        <tr>
            <td>记录测试用例关联的缺陷</td>
        </tr>
        <tr>
            <td>缺陷记录支持关联到 Jira/TAPD 平台</td>
        </tr>
        <tr>
            <td>测试报告支持分享、导出</td>
        </tr>
        <tr>
            <td rowspan="19">接口测试</td>
            <td rowspan="12">测试脚本</td>
            <td>在线编辑接口测试内容</td>
        </tr>
        <tr>
            <td>支持参数化测试</td>
        </tr>
        <tr>
            <td>灵活多样的断言支持</td>
        </tr>
        <tr>
            <td>支持多接口的场景化测试</td>
        </tr>
        <tr>
            <td>测试场景复用</td>
        </tr>
        <tr>
            <td>测试场景支持引用已有环境信息</td>
        </tr>
        <tr>
            <td>测试环境信息管理</td>
        </tr>
        <tr>
            <td>通过浏览器插件快速录制测试脚本</td>
        </tr>
        <tr>
            <td>支持前后置 BeanShell/Python 脚本</td>
        </tr>
        <tr>
            <td>上传并引用自定义 Jar 包</td>
        </tr>
        <tr>
            <td>多协议支持,支持 HTTP、Dubbo、SQL、TCP 类型请求</td>
        </tr>
        <tr>
            <td>支持等待时间、条件判断等逻辑控制功能</td>
        </tr>
        <tr>
            <td rowspan="4">测试执行</td>
            <td>内置定时任务支持</td>
        </tr>
        <tr>
            <td>通过 Jenkins 插件触发测试执行</td>
        </tr>
        <tr>
            <td>多个接口测试一键合并执行</td>
        </tr>
        <tr>
            <td>一键创建性能测试</td>
        </tr>
        <tr>
            <td rowspan="3">测试报告</td>
            <td>测试执行后自动生成动态实时测试报告</td>
        </tr>
        <tr>
            <td>测试报告导出</td>
        </tr>
        <tr>
            <td>通过邮件、IM 工具等通知执行结果</td>
        </tr>
        <tr>
            <td rowspan="12">性能测试</td>
            <td rowspan="6">测试脚本</td>
            <td>完全兼容&nbsp;JMeter&nbsp;脚本</td>
        </tr>
        <tr>
            <td>在线调整压力参数</td>
        </tr>
        <tr>
            <td>分布式压力测试</td>
        </tr>
        <tr>
            <td>支持参数化测试</td>
        </tr>
        <tr>
            <td>通过浏览器插件快速录制测试脚本</td>
        </tr>
        <tr>
            <td>多协议支持</td>
        </tr>
        <tr>
            <td rowspan="2">测试执行</td>
            <td>内置定时任务支持</td>
        </tr>
        <tr>
            <td>通过 Jenkins 插件触发测试执行</td>
        </tr>
        <tr>
            <td rowspan="4">测试报告</td>
            <td>测试执行后自动生成测试报告</td>
        </tr>
        <tr>
            <td>丰富的测试报告展现形式</td>
        </tr>
        <tr>
            <td>测试报告导出</td>
        </tr>
        <tr>
            <td>查看测试日志详情</td>
        </tr>
        <tr>
            <td rowspan="9">系统管理</td>
            <td rowspan="3">用户租户管理</td>
            <td>支持多级租户体系</td>
        </tr>
        <tr>
            <td>支持多种租户角色</td>
        </tr>
        <tr>
            <td>LDAP 认证对接</td>
        </tr>
        <tr>
            <td>测试资源管理</td>
            <td>性能测试资源池管理</td>
        </tr>
        <tr>
            <td rowspan="2">消息通知配置</td>
            <td>IM 工具通知(如企业微信、钉钉)</td>
        </tr>
        <tr>
            <td>邮件通知配置</td>
        </tr>
        <tr>
            <td rowspan="3">集成与扩展</td>
            <td>完善的&nbsp;API&nbsp;列表</td>
        </tr>
        <tr>
            <td>支持对接&nbsp;Jenkins&nbsp;等持续集成工具</td>
        </tr>
        <tr>
            <td>支持对接 Jira/TAPD 等缺陷管理工具</td>
        </tr>
    </tbody>
</table>

详细的版本规划请参考 [版本路线图](https://github.com/metersphere/metersphere/blob/master/ROADMAP.md)

## 技术栈

-   后端: [Spring Boot](https://www.tutorialspoint.com/spring_boot/spring_boot_introduction.htm)
-   前端: [Vue.js](https://vuejs.org/)
-   中间件: [MySQL](https://www.mysql.com/), [Kafka](https://kafka.apache.org/)
-   基础设施: [Docker](https://www.docker.com/), [Kubernetes](https://kubernetes.io/)
-   测试引擎: [JMeter](https://jmeter.apache.org/)

## 致谢

-   [BlazeMeter](https://www.blazemeter.com/):感谢 BlazeMeter 提供的设计思路
-   [JMeter](https://jmeter.apache.org/):MeterSphere 使用了 JMeter 作为测试引擎
-   [Element](https://element.eleme.cn/#/):感谢 Element 提供的优秀组件库

## 加入 MeterSphere 团队

我们正在招聘 MeterSphere 技术布道师,一起打造开源明星项目,请发简历到 metersphere@fit2cloud.com

点击查看 [岗位详情](https://www.zhipin.com/job_detail/b151c4b3d594688733Ny3dy1GFI~.html)

## 微信群

![wechat-group](https://metersphere.oss-cn-hangzhou.aliyuncs.com/img/wechat-group.png)

## License & Copyright

Copyright (c) 2014-2020 飞致云 FIT2CLOUD, All rights reserved.

Licensed under The GNU General Public License version 2 (GPLv2)  (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

<https://www.gnu.org/licenses/gpl-2.0.html>

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.