org.gradle.language.nativeplatform.internal.incremental.DefaultSourceIncludesResolverTest.groovy Maven / Gradle / Ivy
/*
* Copyright 2013 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.language.nativeplatform.internal.incremental
import org.gradle.language.nativeplatform.internal.IncludeDirectives
import org.gradle.language.nativeplatform.internal.incremental.sourceparser.DefaultInclude
import org.gradle.test.fixtures.file.TestFile
import org.gradle.test.fixtures.file.TestNameTestDirectoryProvider
import org.junit.Rule
import spock.lang.Specification
class DefaultSourceIncludesResolverTest extends Specification {
@Rule final TestNameTestDirectoryProvider temporaryFolder = new TestNameTestDirectoryProvider()
def testDirectory = temporaryFolder.testDirectory
def sourceDirectory = testDirectory.createDir("sources")
def quotedIncludes = []
def systemIncludes = []
def macroIncludes = []
def includesParser = Mock(SourceIncludesParser)
def includes
def includePaths = [ ]
def setup() {
includes = Mock(IncludeDirectives)
includesParser.parseIncludes(sourceFile) >> includes
includes.getQuotedIncludes() >> { quotedIncludes.collect { include(it) } }
includes.getSystemIncludes() >> { systemIncludes.collect { include(it) } }
includes.getMacroIncludes() >> { macroIncludes.collect { include(it) } }
}
protected TestFile getSourceFile() {
sourceDirectory.file('source.c')
}
def getDependencies() {
return new DefaultSourceIncludesResolver(includePaths).resolveIncludes(sourceFile, includes).getResolvedIncludes() as List
}
def getCandidates() {
return new DefaultSourceIncludesResolver(includePaths).resolveIncludes(sourceFile, includes).getCheckedLocations() as List
}
def "handles source file with no includes"() {
expect:
dependencies == []
noCandidates()
}
def "ignores include files that do not exist"() {
given:
def test = sourceDirectory.file("test.h")
when:
quotedIncludes << "test.h"
systemIncludes << "system.h"
then:
dependencies == []
searchedCandidates() == [ test ]
}
def "locates quoted includes in same directory"() {
when:
final header1 = sourceDirectory.createFile("test1.h")
final header2 = sourceDirectory.createFile("test2.h")
and:
quotedIncludes << "test1.h" << "test2.h"
then:
dependencies == deps(header1, header2)
searchedCandidates() == [ header1, header2 ]
}
def "locates quoted includes relative to source directory"() {
when:
final header1 = sourceDirectory.createFile("test1.h")
final header2 = sourceDirectory.file("nested", "test2.h").createFile()
final header3 = sourceDirectory.file("..", "sibling", "test3.h").createFile()
and:
quotedIncludes << "test1.h" << "nested/test2.h" << "../sibling/test3.h"
then:
dependencies.collect {it.file} == [header1, header2, header3]
searchedCandidates() == [ header1, header2, header3 ]
}
def "does not locate system includes in same directory"() {
when:
sourceDirectory.file("system.h").createFile()
and:
systemIncludes << "system.h"
then:
dependencies == []
noCandidates()
}
def "locates includes in path"() {
when:
def includeDir1 = testDirectory.file("include1")
final projectHeader1 = includeDir1.file("projectHeader1.h").createFile()
final headerWithSystemName1 = includeDir1.file("headerWithSystemName1.h").createFile()
def includeDir2 = testDirectory.file("include2")
final projectHeader2 = includeDir2.file("projectHeader2.h").createFile()
final headerWithSystemName2 = includeDir2.file("headerWithSystemName2.h").createFile()
and:
includePaths << includeDir1 << includeDir2
quotedIncludes << "projectHeader1.h" << "projectHeader2.h"
systemIncludes << "headerWithSystemName1.h" << "headerWithSystemName2.h"
then:
dependencies == deps(projectHeader1, projectHeader2, headerWithSystemName1, headerWithSystemName2)
searchedCandidates() == [ sourceDirectory.file("projectHeader1.h"), projectHeader1,
sourceDirectory.file("projectHeader2.h"), includeDir1.file("projectHeader2.h"), projectHeader2,
includeDir1.file("headerWithSystemName1.h"),
includeDir1.file("headerWithSystemName2.h"), includeDir2.file("headerWithSystemName2.h")
]
}
def "searches relative before searching include path"() {
when:
final relativeHeader = sourceDirectory.createFile("test.h")
final includeDir = testDirectory.file("include")
includeDir.createFile("test.h")
final otherHeader = includeDir.createFile("other.h")
and:
includePaths << includeDir
quotedIncludes << "test.h" << "other.h"
then:
dependencies == deps(relativeHeader, otherHeader)
searchedCandidates() == [ relativeHeader,
sourceDirectory.file("other.h"), otherHeader ]
}
def "includes unknown source dependency for first macro include"() {
when:
macroIncludes << 'DEFINE_1' << 'DEFINE_2'
then:
dependencies.size() == 1
with (dependencies[0]) {
unknown
include == 'DEFINE_1'
maybeMacro
file == null
}
}
def include(String value) {
return DefaultInclude.parse(value, false)
}
def deps(File... files) {
return files.collect {dep(it)}
}
def dep(File dependencyFile) {
return new ResolvedInclude(dependencyFile.name, dependencyFile)
}
void noCandidates() {
assert searchedCandidates() == []
}
def searchedCandidates() {
candidates.collect { it.canonicalFile } as List
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy