使用 Gradle 为 Gatling 构建可执行 Jar

Build Executable Jar with Gradle for Gatling

问题

我创建了一个 Scala 和 Gatling 项目,我想用它执行一些负载测试。这个想法是我构建一个可执行的 jar,然后我简单地执行到 运行 说负载测试。

到目前为止,我 运行 在我的 IDE 中进行负载测试没有任何问题。但是,当我尝试 assemble 它时:

gradle assemble

罐子是空的,即包含我的实用程序 类 来自 src/main/scala,但没有来自 src/gatling/*(我的设置见下文)。

我已经用 fat jar 进行了试验,但该任务给了我错误:

Execution failed for task ':fatJar'.
> Cannot expand ZIP 'D:\projects\load-test\build\classes\java\main' as it does not exist.

我不知道为什么它首先期望 java。

我的设置

我的项目结构如下:

load-test/
├── src/
│   ├── gatling/
│   │   ├── resources
│   │   └── scala
│   ├── main/
│   │   ├── resources
│   │   └── scala
│   └── test/
│       ├── resources
│       └── scala
├── ...
└── build.gradle

我发现 Gatling 插件非常顽固,它只包含 gatlingCompileClasspath 中的 Gatling 依赖项。所以为了能够编写负载测试,我需要有一个 gatling 源集。 main/scala 目录用于实现一些实用功能,例如创建自定义时间戳等。test/scala 测试这些功能。

我的build.gradle如下:

plugins {
    id "com.github.maiflai.scalatest" version "0.25"
    id 'io.gatling.gradle' version "3.4.0"
    id "scala"
}

apply plugin: "scala"
apply plugin: "com.github.maiflai.scalatest"

compileScala.targetCompatibility = 1.8
ScalaCompileOptions.metaClass.useAnt = false

repositories {
    jcenter()
    maven {
        url "https://plugins.gradle.org/m2/"
    }
}

sourceSets {
    gatling {
        scala.srcDirs = ["src/gatling/scala"]
        resources.srcDirs = ["src/gatling/resources"]
    }

    test {
        scala.srcDirs = ["src/test/scala"]
        resources.srcDirs = ["src/test/resources"]
    }

}

dependencies {
    testCompile "gradle.plugin.com.github.maiflai:gradle-scalatest:0.25"
    testCompile "org.scala-lang:scala-library:2.12.12"
    testCompile 'org.scalatest:scalatest_2.12:3.0.0'
    testRuntime 'org.pegdown:pegdown:1.4.2'
}


gatling {
    toolVersion = '3.4.0'
    scalaVersion = '2.12.12'
    simulations = {
        include "**/*Simulation.scala"
    }
    systemProperties = ['file.encoding': 'UTF-8']
}


task fatJar(type: Jar) {
    manifest {
        attributes 'Implementation-Version': project.version,
                'Main-Class': 'io.gatling.app.Gatling'
    }
    setArchiveBaseName project.name + '-all'
    from { 
        configurations.gatlingRuntimeClasspath.collect { it.isDirectory() ? it : zipTree(it) }
    } {
        exclude 'META-INF/MANIFEST.MF'
        exclude 'META-INF/*.SF'
        exclude 'META-INF/*.DSA'
        exclude 'META-INF/*.RSA'

    }
    with jar
}

经过大量试验并在文档中搜索提示数小时后,构建 gradle 代码片段成功了:

configurations {
    fatJarDependencies.extendsFrom gatling
}

task fatJar(type: Jar, dependsOn: [':gatlingClasses', ':processResources']) {
    manifest {
        attributes 'Implementation-Title': 'Preparing test',
                'Implementation-Version': '',
                'Main-Class': 'io.gatling.app.Gatling'
    }
    classifier = 'all'
    from files(sourceSets.main.output.classesDirs)
    from files(sourceSets.gatling.output)
    from { configurations.fatJarDependencies.collect { it.isDirectory() ? it : zipTree(it) } } {
        exclude 'META-INF/MANIFEST.MF'
        exclude 'META-INF/*.SF'
        exclude 'META-INF/*.DSA'
        exclude 'META-INF/*.RSA'
    }
    with jar
}

关键如下:

1.配置

fatJarDependencies.extendsFrom gatling

您需要扩展 gatling,因为像 configurations.gatlingRuntimeClasspath.collectconfigurations.gatling.collect 这样的东西在您的 fatJar 任务中没有任何作用,即使这些配置存在(至少后者)。这是必要的,以便将依赖项放入您的 jar(gatling 本身,scala 等等)。

2。取决于

准确地说:

(type: Jar, dependsOn: [':gatlingClasses', ':processResources'])

特别是 gatlingClasses,这是我通过扫描 gatling gradle plugin 的文档页面发现的。这将在 src/gatling/*

下添加代码

我可以 运行 通过执行以下命令进行模拟(-DConfig 是可选的):

java -Dconfig.resource=myConf.conf -jar the-jar-i-created.jar -s org.comp.pckg.DemoSimulation

正如George Leung所指出的,也可以在jar之外生成报告,如果你像上面那样开始评论(我错误地忘记了我添加了选项-nr) .为了自定义文件夹,我在 src/gatling/resources 中添加了一个具有以下值的 gatling.conf

gatling {
  core {
    directory {
      results = "/gatling/reports"
    }
  }
}

这会覆盖您可以找到的默认值 here