Skip to content

Commit

Permalink
Fix duplicated compilation of Gatling simulation for 'gatling' config…
Browse files Browse the repository at this point in the history
…uration, close gatling/gatling#3490

This is caused by the `gatling` configuration rewiring too much of the
test settings into its configuration, will still linking some of its
setting to the `test` configuration.
This PR replaces `Defaults.testSettings` by `Defaults.testTasks`, which
wires less settings into the `gatling` configuration while still
achieving what we require (eg. splitting Gatling simulation from other
unit tests and integration tests).
  • Loading branch information
Pierre Dal-Pra committed Apr 7, 2020
1 parent e3c3c26 commit dec05d6
Showing 1 changed file with 4 additions and 10 deletions.
14 changes: 4 additions & 10 deletions src/main/scala/io/gatling/sbt/GatlingPlugin.scala
Original file line number Diff line number Diff line change
Expand Up @@ -42,12 +42,12 @@ object GatlingPlugin extends AutoPlugin {
/**************/
/** Settings **/
/**************/
lazy val gatlingSettings =
inConfig(Gatling)(Defaults.testSettings ++ gatlingBaseSettings(Gatling, Test))
lazy val gatlingSettings: Seq[Def.Setting[_]] =
inConfig(Gatling)(Defaults.testTasks ++ gatlingBaseSettings(Gatling, Test))

lazy val gatlingItSettings: Seq[Def.Setting[_]] =
inConfig(GatlingIt)(
Defaults.itSettings ++ Defaults.testTasks ++ gatlingBaseSettings(GatlingIt, IntegrationTest, filterClasspath = false)
Defaults.itSettings ++ Defaults.testTasks ++ gatlingBaseSettings(GatlingIt, IntegrationTest)
)

lazy val gatlingAllSettings: Seq[Def.Setting[_]] =
Expand All @@ -56,17 +56,11 @@ object GatlingPlugin extends AutoPlugin {
/********************/
/** Helper methods **/
/********************/
private def gatlingBaseSettings(config: Configuration, parent: Configuration, filterClasspath: Boolean = true) = Seq(
private def gatlingBaseSettings(config: Configuration, parent: Configuration) = Seq(
testFrameworks in config := Seq(gatlingTestFramework),
target in config := target.value / config.name,
fullClasspath in config := {
val path = (fullClasspath in parent).value
val dir = (classDirectory in config).value
if (filterClasspath) path.filterNot(_.data == dir) else path
},
testOptions in config += Argument(gatlingTestFramework, "-rf", (target in config).value.getPath),
javaOptions in config ++= overrideDefaultJavaOptions(),
sourceDirectory in config := (sourceDirectory in parent).value,
parallelExecution in config := false,
fork in config := true,
testGrouping in config := (testGrouping in config).value flatMap singleTestGroup,
Expand Down

0 comments on commit dec05d6

Please sign in to comment.