blob: 7b77ddb938a94347a3753b25d96b02348027bbac [file] [log] [blame]
if(("${SWIFT_HOST_VARIANT_SDK}" STREQUAL "${SWIFT_PRIMARY_VARIANT_SDK}") AND
("${SWIFT_HOST_VARIANT_ARCH}" STREQUAL "${SWIFT_PRIMARY_VARIANT_ARCH}"))
set(PLATFORM_SOURCES)
set(PLATFORM_TARGET_LINK_LIBRARIES)
if(SWIFT_HOST_VARIANT MATCHES "${SWIFT_DARWIN_VARIANTS}")
# Placeholder for Darwin Foundation tests (currently none)
# find_library(FOUNDATION_LIBRARY Foundation)
# list(APPEND PLATFORM_SOURCES
# YourTestNameHere.mm
# )
# # We need to link swiftCore on Darwin because the runtime still relies on
# # some stdlib hooks to implement SwiftObject.
# list(APPEND PLATFORM_TARGET_LINK_LIBRARIES
# ${FOUNDATION_LIBRARY}
# swiftStdlibUnittest${SWIFT_PRIMARY_VARIANT_SUFFIX}
# )
elseif(SWIFT_HOST_VARIANT STREQUAL "linux")
list(APPEND PLATFORM_TARGET_LINK_LIBRARIES
"atomic"
)
elseif(SWIFT_HOST_VARIANT STREQUAL "freebsd")
find_library(EXECINFO_LIBRARY execinfo)
list(APPEND PLATFORM_TARGET_LINK_LIBRARIES
${EXECINFO_LIBRARY}
)
endif()
add_swift_unittest(SwiftRuntimeLongTests
LongRefcounting.cpp
../Stdlib.cpp
${PLATFORM_SOURCES}
# The runtime tests link to internal runtime symbols, which aren't exported
# from the swiftCore dylib, so we need to link to both the runtime archive
# and the stdlib.
$<TARGET_OBJECTS:swiftRuntime${SWIFT_PRIMARY_VARIANT_SUFFIX}>
)
# The local stdlib implementation provides definitions of the swiftCore
# interfaes to avoid pulling in swiftCore itself. Build the
# SwiftRuntimeLongTests with swiftCore_EXPORTS to permit exporting the stdlib
# interfaces.
target_compile_definitions(SwiftRuntimeLongTests
PRIVATE
swiftCore_EXPORTS)
# FIXME: cross-compile for all variants.
target_link_libraries(SwiftRuntimeLongTests
PRIVATE
swiftCore${SWIFT_PRIMARY_VARIANT_SUFFIX}
${PLATFORM_TARGET_LINK_LIBRARIES}
${swift_runtime_test_extra_libraries}
)
endif()