org.gradle.language.cpp.internal.DefaultCppLibraryTest.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 2017 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.cpp.internal
import org.gradle.api.internal.CollectionCallbackActionDecorator
import org.gradle.language.cpp.CppPlatform
import org.gradle.nativeplatform.MachineArchitecture
import org.gradle.nativeplatform.OperatingSystemFamily
import org.gradle.nativeplatform.TargetMachine
import org.gradle.nativeplatform.toolchain.internal.NativeToolChainInternal
import org.gradle.nativeplatform.toolchain.internal.PlatformToolProvider
import org.gradle.test.fixtures.file.TestNameTestDirectoryProvider
import org.gradle.util.TestUtil
import org.junit.Rule
import spock.lang.Specification
class DefaultCppLibraryTest extends Specification {
@Rule
TestNameTestDirectoryProvider tmpDir = new TestNameTestDirectoryProvider()
def project = TestUtil.createRootProject(tmpDir.testDirectory)
DefaultCppLibrary library
def setup() {
library = new DefaultCppLibrary("main", project.objects, project.fileOperations, project.configurations, CollectionCallbackActionDecorator.NOOP)
}
def "has display name"() {
expect:
library.displayName.displayName == "C++ library 'main'"
library.toString() == "C++ library 'main'"
}
def "has implementation configuration"() {
expect:
library.implementationDependencies == project.configurations.implementation
}
def "has api configuration"() {
expect:
library.apiDependencies == project.configurations.api
}
def "has api elements configuration"() {
expect:
library.apiElements == project.configurations.cppApiElements
}
def "has main publication"() {
expect:
library.mainPublication
}
def "uses convention for public headers when nothing specified"() {
def d = tmpDir.file("src/main/public")
expect:
library.publicHeaderDirs.files == [d] as Set
}
def "does not include the convention for public headers when some other location specified"() {
def d = tmpDir.file("other")
expect:
library.publicHeaders.from(d)
library.publicHeaderDirs.files == [d] as Set
}
def "can add shared library"() {
def targetPlatform = Stub(CppPlatform)
def toolChain = Stub(NativeToolChainInternal)
def platformToolProvider = Stub(PlatformToolProvider)
expect:
def binary = library.addSharedLibrary(identity, targetPlatform, toolChain, platformToolProvider)
binary.name == 'mainDebug'
binary.debuggable
!binary.optimized
binary.targetPlatform == targetPlatform
binary.toolChain == toolChain
binary.platformToolProvider == platformToolProvider
library.binaries.realizeNow()
library.binaries.get() == [binary] as Set
}
def "can add static library"() {
def targetPlatform = Stub(CppPlatform)
def toolChain = Stub(NativeToolChainInternal)
def platformToolProvider = Stub(PlatformToolProvider)
expect:
def binary = library.addStaticLibrary(identity, targetPlatform, toolChain, platformToolProvider)
binary.name == 'mainDebug'
binary.debuggable
!binary.optimized
binary.targetPlatform == targetPlatform
binary.toolChain == toolChain
binary.platformToolProvider == platformToolProvider
library.binaries.realizeNow()
library.binaries.get() == [binary] as Set
}
def "compile include path includes public and private header dirs"() {
def defaultPrivate = tmpDir.file("src/main/headers")
def defaultPublic = tmpDir.file("src/main/public")
def d1 = tmpDir.file("src/main/d1")
def d2 = tmpDir.file("src/main/d2")
def d3 = tmpDir.file("src/main/d3")
def d4 = tmpDir.file("src/main/d4")
expect:
def binary = library.addSharedLibrary(identity, Stub(CppPlatform), Stub(NativeToolChainInternal), Stub(PlatformToolProvider))
binary.compileIncludePath.files as List == [defaultPublic, defaultPrivate]
library.publicHeaders.from(d1)
library.privateHeaders.from(d2)
binary.compileIncludePath.files as List == [d1, d2]
library.publicHeaders.setFrom(d3)
library.privateHeaders.from(d4)
binary.compileIncludePath.files as List == [d3, d2, d4]
}
def "can query the header files of the library"() {
def d1 = tmpDir.createDir("d1")
def f1 = d1.createFile("a.h")
def f2 = d1.createFile("nested/b.h")
d1.createFile("ignore-me.cpp")
def f3 = tmpDir.createFile("src/main/public/c.h")
def f4 = tmpDir.createFile("src/main/headers/c.h")
tmpDir.createFile("src/main/headers/ignore.cpp")
tmpDir.createFile("src/main/public/ignore.cpp")
expect:
library.headerFiles.files == [f3, f4] as Set
library.privateHeaders.from(d1)
library.headerFiles.files == [f3, f1, f2] as Set
}
def "can query the public header files of the library"() {
def d1 = tmpDir.createDir("d1")
def f1 = d1.createFile("a.h")
def f2 = d1.createFile("nested/b.h")
d1.createFile("ignore-me.cpp")
def f3 = tmpDir.createFile("src/main/public/c.h")
tmpDir.createFile("src/main/headers/ignore.h")
tmpDir.createFile("src/main/headers/ignore.cpp")
tmpDir.createFile("src/main/public/ignore.cpp")
expect:
library.publicHeaderFiles.files == [f3] as Set
library.publicHeaders.from(d1)
library.publicHeaderFiles.files == [f1, f2] as Set
}
def "uses component name to determine header directories"() {
def h1 = tmpDir.createFile("src/a/public")
def h2 = tmpDir.createFile("src/b/public")
def c1 = new DefaultCppLibrary("a", project.objects, project.fileOperations, project.configurations, CollectionCallbackActionDecorator.NOOP)
def c2 = new DefaultCppLibrary("b", project.objects, project.fileOperations, project.configurations, CollectionCallbackActionDecorator.NOOP)
expect:
c1.publicHeaderDirs.files == [h1] as Set
c2.publicHeaderDirs.files == [h2] as Set
}
private NativeVariantIdentity getIdentity() {
// TODO Check that TargetMachine from NativeVariantIdentity is the same as the one from CppPlatform
return Stub(NativeVariantIdentity) {
getName() >> "debug"
getTargetMachine() >> targetMachine(OperatingSystemFamily.WINDOWS, MachineArchitecture.X86_64)
isDebuggable() >> true
isOptimized() >> false
}
}
private TargetMachine targetMachine(String os, String arch) {
def objectFactory = TestUtil.objectFactory()
return Stub(TargetMachine) {
getOperatingSystemFamily() >> objectFactory.named(OperatingSystemFamily.class, os)
getArchitecture() >> objectFactory.named(MachineArchitecture.class, arch)
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy