本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/28209
并行策略配置
JUnit
提供了两种实现(动态和固定)和一个自定义选项。junit.jupiter.execution.parallel.config.strategy
的值设为并行策略配置参数中的一种即可。- 如果没有进行策略的相关配置,并行化策略默认为
dynamic
并行策略配置参数
- 并发策略的配置参数有3种:
dynamic
、fixed
、custom
- 前两种
dynamic
和fixed
是JUnit
平台提供的 开箱即用 的实现。 custom
策略是通过自定义的模式来配置并行的线程池数量。
dynamic
- 动态策略;默认选项
junit.jupiter.execution.parallel.config.strategy = dynamic
- 所需的并行数 根据 ++处理器/内核的数量++ 乘以 ++使用指定的因子参数++(默认为 1)确定线程数。
- 并发线程数为
可用处理器/核的数量 * 系数
- 系数设置
dynamic
对应的系数配置项为:junit.jupiter.execution.parallel.config.dynamic.factor
- 系数默认值为1
fixed
- 固定策略
junit.jupiter.execution.parallel.config.strategy = fixed
- 所需的并行数 固定策略依赖于预定义的线程数
- 并发线程数为 设置的
junit.jupiter.execution.parallel.config.fixed.parallelism
的value
值
测试类并行,测试方法并行
junit.jupiter.execution.parallel.mode.default = concurrent
junit.jupiter.execution.parallel.mode.classes.default=concurrent
固定策略
junit.jupiter.execution.parallel.config.strategy = fixed
junit.jupiter.execution.parallel.config.fixed.parallelism=2
custom
- 自定义策略
- 通过实现 ParallelExecutionConfigurationStrategy 接口来配置并行的线程池数量。
junit.jupiter.execution.parallel.config.strategy = custom
- 所需的并行数
- 使用
ParallelExecutionConfigurationStrategy
接口实现。
- 使用
custom
- 自定义策略
- 通过实现 ParallelExecutionConfigurationStrategy 接口来配置并行的线程池数量。
junit.jupiter.execution.parallel.config.strategy = custom
- 所需的并行数
- 使用
ParallelExecutionConfigurationStrategy
接口实现。
- 使用
package com.junit5;
import org.junit.platform.commons.JUnitException;
import org.junit.platform.engine.ConfigurationParameters;
import org.junit.platform.engine.support.hierarchical.ParallelExecutionConfiguration;
import org.junit.platform.engine.support.hierarchical.ParallelExecutionConfigurationStrategy;
public class MyCustomStratgy implements ParallelExecutionConfigurationStrategy {
@Override
public ParallelExecutionConfiguration createConfiguration(ConfigurationParameters configurationParameters) {
int count = configurationParameters.get("custom.parallelism", Integer::valueOf)
.orElseThrow(() -> {
return new JUnitException(String.format("Configuration parameter '%s' must be set", "fixed.parallelism"));
});
return new ParallelExecutionConfiguration() {
@Override
public int getParallelism() {
return count;
}
@Override
public int getMinimumRunnable() {
return count;
}
@Override
public int getMaxPoolSize() {
return count;
}
@Override
public int getCorePoolSize() {
return count;
}
@Override
public int getKeepAliveSeconds() {
return count;
}
};
}
}
测试类并行,测试方法并行
junit.jupiter.execution.parallel.mode.default = concurrent
junit.jupiter.execution.parallel.mode.classes.default=concurrent
自定义策略
junit.jupiter.execution.parallel.config.strategy = custom
junit.jupiter.execution.parallel.config.custom.class = com.junit5.MyCustomStratgy
junit.jupiter.execution.parallel.config.custom.parallelism = 3
推荐学习
【霍格沃兹测试开发】7天软件测试快速入门带你从零基础/转行/小白/就业/测试用例设计实战
【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (上集)
【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (下集)
【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(上集)
【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(下集)
【霍格沃兹测试开发】精品课合集/ 自动化测试/ 性能测试/ 精准测试/ 测试左移/ 测试右移/ 人工智能测试
【霍格沃兹测试开发】腾讯/ 百度/ 阿里/ 字节测试专家技术沙龙分享合集/ 精准化测试/ 流量回放/Diff
【霍格沃兹测试开发】Pytest 用例结构/ 编写规范 / 免费分享
【霍格沃兹测试开发】JMeter 实时性能监控平台/ 数据分析展示系统Grafana/Docker 安装
【霍格沃兹测试开发】接口自动化测试的场景有哪些?为什么要做接口自动化测试?如何一键生成测试报告?
【霍格沃兹测试开发】面试技巧指导/ 测试开发能力评级/1V1 模拟面试实战/ 冲刺年薪百万!
【霍格沃兹测试开发】腾讯软件测试能力评级标准/ 要评级表格的联系我
【霍格沃兹测试开发】Pytest 与Allure2 一键生成测试报告/ 测试用例断言/ 数据驱动/ 参数化
【霍格沃兹测试开发】App 功能测试实战快速入门/adb 常用命令/adb 压力测试
【霍格沃兹测试开发】阿里/ 百度/ 腾讯/ 滴滴/ 字节/ 一线大厂面试真题讲解,卷完拿高薪Offer !
【霍格沃兹测试开发】App自动化测试零基础快速入门/Appium/自动化用例录制/参数配置
【霍格沃兹测试开发】如何用Postman 做接口测试,从入门到实战/ 接口抓包(最新最全教程)
【霍格沃兹测试开发】6 小时轻松上手功能测试/ 软件测试工作流程/ 测试用例设计/Bug 管理
【霍格沃兹测试开发】零基础小白如何使用Postman ,从零到一做接口自动化测试/ 从零基础到进阶到实战
【霍格沃兹测试开发】建议收藏全国CCF 测试开发大赛Python 接口自动化测试赛前辅导 / 项目实战
更多软件测试开发视频教程点此
软件测试职业发展
零基础入门
测试必备编程篇
自动化测试
性能测试
测试管理
工程效能篇
面试求职篇
软件测试的面试宝典,内含一线互联网大厂面试真题、面试技巧、软件测试面试简历指导,免费领取!