天天看點

軟體測試學習筆記丨JUnit5并行政策

作者:測試人666
本文轉自測試人社群,原文連結:jck28-lucio-junit5并行政策【進階】 - 學習筆記 - 測試人社群

并行政策配置

  • 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           
軟體測試學習筆記丨JUnit5并行政策

軟體測試開發免費視訊教程分享 - 公衆号 - 測試人社群

軟體測試學習筆記丨JUnit5并行政策

繼續閱讀