-
Notifications
You must be signed in to change notification settings - Fork 4.5k
/
JavaConfigurationCachePerformanceTest.groovy
106 lines (91 loc) · 3.94 KB
/
JavaConfigurationCachePerformanceTest.groovy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
* Copyright 2019 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* 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.
*/
package org.gradle.performance.regression.java
import org.gradle.initialization.StartParameterBuildOptions.ConfigurationCacheOption
import org.gradle.performance.AbstractCrossVersionPerformanceTest
import org.gradle.performance.annotations.RunFor
import org.gradle.performance.annotations.Scenario
import org.gradle.profiler.BuildContext
import org.gradle.profiler.BuildMutator
import org.gradle.profiler.InvocationSettings
import spock.lang.Unroll
import java.nio.file.Files
import static org.gradle.performance.annotations.ScenarioType.TEST
import static org.gradle.performance.results.OperatingSystem.LINUX
import static org.junit.Assert.assertTrue
class JavaConfigurationCachePerformanceTest extends AbstractCrossVersionPerformanceTest {
private File stateDirectory
def setup() {
stateDirectory = temporaryFolder.file(".gradle/configuration-cache")
}
@RunFor([
@Scenario(type = TEST, operatingSystems = [LINUX], testProjects = ["largeJavaMultiProjectNoBuildSrc", "smallJavaMultiProject"],
iterationMatcher = ".*with hot.*"),
@Scenario(type = TEST, operatingSystems = [LINUX], testProjects = ["largeJavaMultiProjectNoBuildSrc"], iterationMatcher = ".*with cold.*")
])
@Unroll
def "assemble #action configuration cache state with #daemon daemon"() {
given:
runner.targetVersions = ["6.8.2-20210218002439+0000"]
runner.minimumBaseVersion = "6.6"
runner.tasksToRun = ["assemble"]
runner.args = ["-D${ConfigurationCacheOption.PROPERTY_NAME}=true"]
and:
runner.useDaemon = daemon == hot
runner.addBuildMutator { configurationCacheInvocationListenerFor(it, action, stateDirectory) }
runner.warmUpRuns = daemon == hot ? 20 : 1
runner.runs = daemon == hot ? 60 : 25
when:
def result = runner.run()
then:
result.assertCurrentVersionHasNotRegressed()
where:
daemon | action
hot | loading
hot | storing
cold | loading
cold | storing
}
static String loading = "loading"
static String storing = "storing"
static String hot = "hot"
static String cold = "cold"
static BuildMutator configurationCacheInvocationListenerFor(InvocationSettings invocationSettings, String action, File stateDirectory) {
return new BuildMutator() {
@Override
void beforeBuild(BuildContext context) {
if (action == storing) {
stateDirectory.deleteDir()
}
}
@Override
void afterBuild(BuildContext context, Throwable error) {
if (context.iteration > 1) {
def tag = action == storing
? "Calculating task graph as no configuration cache is available"
: "Reusing configuration cache"
File buildLog = new File(invocationSettings.projectDir, "profile.log")
def found = Files.lines(buildLog.toPath()).withCloseable { lines ->
lines.anyMatch { line -> line.contains(tag) }
}
if (!found) {
assertTrue("Configuration cache log '$tag' not found in '$buildLog'\n\n$buildLog.text", found)
}
}
}
}
}
}