org.gradle.integtests.fixtures.FileSystemWatchingFixture.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2020 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.integtests.fixtures
import groovy.transform.SelfType
import org.junit.Before
@SelfType(AbstractIntegrationSpec)
trait FileSystemWatchingFixture {
@Before
void setupFirstBuild() {
// Make the first build in each test drop the VFS state
executer.withArgument(FileSystemWatchingHelper.dropVfsArgument)
}
AbstractIntegrationSpec withWatchFs() {
executer.withArgument(FileSystemWatchingHelper.enableFsWatchingArgument)
this as AbstractIntegrationSpec
}
AbstractIntegrationSpec withoutWatchFs() {
executer.withArgument(FileSystemWatchingHelper.disableFsWatchingArgument)
this as AbstractIntegrationSpec
}
VerboseVfsLogAccessor enableVerboseVfsLogs() {
executer.withArgument(FileSystemWatchingHelper.verboseVfsLoggingArgument)
new VerboseVfsLogAccessor(this as AbstractIntegrationSpec)
}
void waitForChangesToBePickedUp() {
FileSystemWatchingHelper.waitForChangesToBePickedUp()
}
protected static class VerboseVfsLogAccessor {
private final AbstractIntegrationSpec spec
VerboseVfsLogAccessor(AbstractIntegrationSpec spec) {
this.spec = spec
}
int getReceivedFileSystemEventsInCurrentBuild() {
def duringBuildStatusLine = spec.result.getPostBuildOutputLineThatContains(" file system events during the current build")
def numberMatcher = duringBuildStatusLine =~ /Received (\d+) file system events during the current build while watching \d+ locations/
return numberMatcher[0][1] as int
}
int getRetainedFilesInCurrentBuild() {
def retainedInformation = spec.result.getPostBuildOutputLineThatContains("Virtual file system retains information about ")
def numberMatcher = retainedInformation =~ /Virtual file system retains information about (\d+) files, (\d+) directories and (\d+) missing files until next build/
return numberMatcher[0][1] as int
}
int getReceivedFileSystemEventsSinceLastBuild() {
String eventsSinceLastBuild = spec.result.getOutputLineThatContains("file system events since last build")
def numberMatcher = eventsSinceLastBuild =~ /Received (\d+) file system events since last build while watching \d+ locations/
return numberMatcher[0][1] as int
}
int getRetainedFilesSinceLastBuild() {
String retainedInformation = spec.result.getOutputLineThatContains("Virtual file system retained information about ")
def numberMatcher = retainedInformation =~ /Virtual file system retained information about (\d+) files, (\d+) directories and (\d+) missing files since last build/
return numberMatcher[0][1] as int
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy