org.gradle.api.internal.file.DefaultFileOperationsTest.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 2010 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.api.internal.file
import org.apache.commons.io.FileUtils
import org.gradle.api.InvalidUserDataException
import org.gradle.api.PathValidation
import org.gradle.api.file.ConfigurableFileCollection
import org.gradle.api.file.FileTree
import org.gradle.api.internal.file.archive.TarFileTree
import org.gradle.api.internal.file.archive.ZipFileTree
import org.gradle.api.internal.file.collections.DefaultConfigurableFileCollection
import org.gradle.api.internal.file.collections.DefaultDirectoryFileTreeFactory
import org.gradle.api.internal.file.collections.FileTreeAdapter
import org.gradle.api.internal.file.collections.ImmutableFileCollection
import org.gradle.api.internal.file.copy.DefaultCopySpec
import org.gradle.api.internal.tasks.TaskResolver
import org.gradle.internal.classloader.ClasspathUtil
import org.gradle.internal.hash.FileHasher
import org.gradle.internal.hash.StreamHasher
import org.gradle.internal.reflect.Instantiator
import org.gradle.internal.resource.TextResourceLoader
import org.gradle.process.ExecResult
import org.gradle.process.internal.ExecException
import org.gradle.process.internal.ExecFactory
import org.gradle.test.fixtures.file.TestFile
import org.gradle.test.fixtures.file.TestNameTestDirectoryProvider
import org.gradle.util.Requires
import org.gradle.util.TestPrecondition
import org.gradle.util.TestUtil
import org.gradle.util.UsesNativeServices
import org.junit.Rule
import spock.lang.Specification
@UsesNativeServices
class DefaultFileOperationsTest extends Specification {
private final FileResolver resolver = Mock() {
getPatternSetFactory() >> TestFiles.getPatternSetFactory()
}
private final TaskResolver taskResolver = Mock()
private final TemporaryFileProvider temporaryFileProvider = Mock()
private final Instantiator instantiator = TestUtil.instantiatorFactory().decorateLenient()
private final FileLookup fileLookup = Mock()
private final DefaultDirectoryFileTreeFactory directoryFileTreeFactory = Mock()
private final StreamHasher streamHasher = Mock()
private final FileHasher fileHasher = Mock()
private final ExecFactory execFactory = TestFiles.execFactory()
private final TextResourceLoader textResourceLoader = Mock()
private DefaultFileOperations fileOperations = instance()
private DefaultFileOperations instance(FileResolver resolver = resolver) {
instantiator.newInstance(DefaultFileOperations, resolver, taskResolver, temporaryFileProvider, instantiator, fileLookup, directoryFileTreeFactory, streamHasher, fileHasher, execFactory, textResourceLoader)
}
@Rule
public final TestNameTestDirectoryProvider tmpDir = new TestNameTestDirectoryProvider()
def resolvesFile() {
when:
TestFile file = expectPathResolved('path')
then:
fileOperations.file('path') == file
}
def resolvesFileWithValidation() {
TestFile file = tmpDir.file('path')
resolver.resolve('path', PathValidation.EXISTS) >> file
expect:
fileOperations.file('path', PathValidation.EXISTS) == file
}
def resolvesURI() {
when:
URI uri = expectPathResolvedToUri('path')
then:
fileOperations.uri('path') == uri
}
def resolvesFilesInOrder() {
when:
def fileCollection = fileOperations.configurableFiles('a', 'b', 'c')
then:
fileCollection instanceof DefaultConfigurableFileCollection
fileCollection.from as List == ['a', 'b', 'c']
fileCollection.resolver.is(resolver)
fileCollection.buildDependency.resolver.is(taskResolver)
when:
def files = fileCollection.files
then:
1 * resolver.resolve('a') >> new File('a')
then:
1 * resolver.resolve('b') >> new File('b')
then:
1 * resolver.resolve('c') >> new File('c')
then:
files*.name as List == ['a', 'b', 'c']
0 * _
}
def resolvesImmutableFilesInOrder() {
when:
def fileCollection = fileOperations.immutableFiles('a', 'b', 'c')
then:
fileCollection instanceof ImmutableFileCollection
when:
def files = fileCollection.files
files*.name as List == ['a', 'b', 'c']
then:
1 * resolver.resolve('a') >> new File('a')
then:
1 * resolver.resolve('b') >> new File('b')
then:
1 * resolver.resolve('c') >> new File('c')
}
def createsFileTree() {
TestFile baseDir = expectPathResolved('base')
when:
def fileTree = fileOperations.fileTree('base')
then:
fileTree instanceof FileTree
fileTree.dir == baseDir
fileTree.resolver.is(resolver)
}
def createsFileTreeFromMap() {
TestFile baseDir = expectPathResolved('base')
when:
def fileTree = fileOperations.fileTree(dir: 'base')
then:
fileTree instanceof FileTree
fileTree.dir == baseDir
fileTree.resolver.is(resolver)
}
def createsZipFileTree() {
expectPathResolved('path')
expectTempFileCreated()
when:
def zipTree = fileOperations.zipTree('path')
then:
zipTree instanceof FileTreeAdapter
zipTree.tree instanceof ZipFileTree
}
def createsTarFileTree() {
TestFile file = tmpDir.file('path')
resolver.resolve('path') >> file
when:
def tarTree = fileOperations.tarTree('path')
then:
tarTree instanceof FileTreeAdapter
tarTree.tree instanceof TarFileTree
}
def copiesFiles() {
def fileTree = Mock(FileTreeInternal)
resolver.resolveFilesAsTree(_) >> fileTree
// todo we should make this work so that we can be more specific
// resolver.resolveFilesAsTree(['file'] as Object[]) >> fileTree
// resolver.resolveFilesAsTree(['file'] as Set) >> fileTree
fileTree.matching(_) >> fileTree
resolver.resolve('dir') >> tmpDir.getTestDirectory()
when:
def result = fileOperations.copy { from 'file'; into 'dir' }
then:
!result.didWork
}
def deletes() {
TestFile fileToBeDeleted = tmpDir.file("file")
ConfigurableFileCollection fileCollection = new DefaultConfigurableFileCollection(resolver, null, "file")
resolver.resolveFiles(["file"] as Object[]) >> fileCollection
resolver.resolve("file") >> fileToBeDeleted
fileToBeDeleted.touch();
expect:
fileOperations.delete('file') == true
fileToBeDeleted.isFile() == false
}
def makesDir() {
TestFile dirToBeCreated = tmpDir.file("parentDir", "dir")
resolver.resolve('parentDir/dir') >> dirToBeCreated
when:
File actualDir = fileOperations.mkdir('parentDir/dir')
then:
actualDir == dirToBeCreated
actualDir.isDirectory() == true
}
def makesDirThrowsExceptionIfPathPointsToFile() {
TestFile dirToBeCreated = tmpDir.file("parentDir", "dir")
dirToBeCreated.touch();
resolver.resolve('parentDir/dir') >> dirToBeCreated
when:
fileOperations.mkdir('parentDir/dir')
then:
thrown(InvalidUserDataException)
}
def createsCopySpec() {
when:
def spec = fileOperations.copySpec { include 'pattern' }
then:
spec instanceof DefaultCopySpec
spec.includes == ['pattern'] as Set
}
private TestFile expectPathResolved(String path) {
TestFile file = tmpDir.file(path)
resolver.resolve(path) >> file
return file
}
private URI expectPathResolvedToUri(String path) {
TestFile file = tmpDir.file(path)
resolver.resolveUri(path) >> file.toURI()
return file.toURI()
}
private TestFile expectTempFileCreated() {
TestFile file = tmpDir.file('expandedArchives')
temporaryFileProvider.newTemporaryFile('expandedArchives') >> file
return file
}
def javaexec() {
File testFile = tmpDir.file("someFile")
fileOperations = instance(resolver())
List files = ClasspathUtil.getClasspath(getClass().classLoader).asFiles
when:
ExecResult result = fileOperations.javaexec {
classpath(files as Object[])
main = SomeMain.name
args testFile.absolutePath
}
then:
testFile.isFile()
result.exitValue == 0
}
def javaexecWithNonZeroExitValueShouldThrowException() {
fileOperations = instance(resolver())
when:
fileOperations.javaexec {
main = 'org.gradle.UnknownMain'
}
then:
thrown(ExecException)
}
def javaexecWithNonZeroExitValueAndIgnoreExitValueShouldNotThrowException() {
fileOperations = instance(resolver())
when:
ExecResult result = fileOperations.javaexec {
main = 'org.gradle.UnknownMain'
ignoreExitValue = true
}
then:
result.exitValue != 0
}
@Requires(TestPrecondition.NOT_WINDOWS)
def exec() {
fileOperations = instance(resolver())
File testFile = tmpDir.file("someFile")
when:
ExecResult result = fileOperations.exec {
executable = "touch"
workingDir = tmpDir.getTestDirectory()
args testFile.name
}
then:
testFile.isFile()
result.exitValue == 0
}
@Requires(TestPrecondition.NOT_WINDOWS)
def execWithNonZeroExitValueShouldThrowException() {
fileOperations = instance(resolver())
when:
fileOperations.exec {
executable = "touch"
workingDir = tmpDir.getTestDirectory()
args tmpDir.testDirectory.name + "/nonExistingDir/someFile"
}
then:
thrown(ExecException)
}
@Requires(TestPrecondition.NOT_WINDOWS)
def execWithNonZeroExitValueAndIgnoreExitValueShouldNotThrowException() {
fileOperations = instance(resolver())
when:
ExecResult result = fileOperations.exec {
ignoreExitValue = true
executable = "touch"
workingDir = tmpDir.getTestDirectory()
args tmpDir.testDirectory.name + "/nonExistingDir/someFile"
}
then:
result.exitValue != 0
}
def resolver() {
return TestFiles.resolver(tmpDir.testDirectory)
}
class SomeMain {
static void main(String[] args) {
FileUtils.touch(new File(args[0]))
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy