174 lines
3.3 KiB
Lua
Executable File
174 lines
3.3 KiB
Lua
Executable File
--
|
|
-- tests/project/test_eachconfig.lua
|
|
-- Test the project object configuration iterator function.
|
|
-- Copyright (c) 2011-2012 Jason Perkins and the Premake project
|
|
--
|
|
|
|
T.project_eachconfig = { }
|
|
local suite = T.project_eachconfig
|
|
|
|
|
|
--
|
|
-- Setup and teardown
|
|
--
|
|
|
|
local sln, prj
|
|
|
|
function suite.setup()
|
|
sln = solution("MySolution")
|
|
end
|
|
|
|
local function prepare(buildcfgs)
|
|
project("MyProject")
|
|
if buildcfgs then
|
|
configurations ( buildcfgs )
|
|
end
|
|
prj = premake.solution.getproject(sln, 1)
|
|
for cfg in premake.project.eachconfig(prj) do
|
|
_p(2,'%s:%s', cfg.buildcfg or "", cfg.platform or "")
|
|
end
|
|
end
|
|
|
|
|
|
--
|
|
-- If no configurations have been defined, the iterator
|
|
-- should not return any values.
|
|
--
|
|
|
|
function suite.returnsNoValues_onNoConfigurationsAndNoPlatforms()
|
|
prepare()
|
|
test.isemptycapture()
|
|
end
|
|
|
|
|
|
--
|
|
-- If platforms have been defined, but no configurations, the
|
|
-- iterator should still not return any values.
|
|
--
|
|
|
|
function suite.returnsNoValues_onNoConfigurationsButPlatforms()
|
|
platforms { "x32", "x64" }
|
|
prepare()
|
|
test.isemptycapture()
|
|
end
|
|
|
|
|
|
--
|
|
-- Configurations should be iterated in the order in which they
|
|
-- appear in the script.
|
|
--
|
|
|
|
function suite.iteratesConfigsInOrder()
|
|
configurations { "Debug", "Profile", "Release", "Deploy" }
|
|
prepare()
|
|
test.capture [[
|
|
Debug:
|
|
Profile:
|
|
Release:
|
|
Deploy:
|
|
]]
|
|
end
|
|
|
|
|
|
--
|
|
-- If platforms are supplied, they should be paired with build
|
|
-- configurations, with the order of both maintained.
|
|
--
|
|
|
|
function suite.pairsConfigsAndPlatformsInOrder()
|
|
configurations { "Debug", "Release" }
|
|
platforms { "x32", "x64" }
|
|
prepare()
|
|
test.capture [[
|
|
Debug:x32
|
|
Debug:x64
|
|
Release:x32
|
|
Release:x64
|
|
]]
|
|
end
|
|
|
|
|
|
--
|
|
-- Test the mapping of a build configuration from solution to project.
|
|
--
|
|
|
|
function suite.mapsBuildCfg_toBuildCfg()
|
|
configurations { "Debug", "Release" }
|
|
configmap { ["Debug"] = "ProjectDebug" }
|
|
prepare()
|
|
test.capture [[
|
|
ProjectDebug:
|
|
Release:
|
|
]]
|
|
end
|
|
|
|
|
|
--
|
|
-- Test mapping a platform from solution to project.
|
|
--
|
|
|
|
function suite.mapsPlatform_toPlatform()
|
|
configurations { "Debug", "Release" }
|
|
platforms { "Win32" }
|
|
configmap { ["Win32"] = "x64" }
|
|
prepare()
|
|
test.capture [[
|
|
Debug:x64
|
|
Release:x64
|
|
]]
|
|
end
|
|
|
|
|
|
--
|
|
-- Test mapping a build configuration to a build config/platform pair.
|
|
-- This will cause a second platform to appear in the project, alongside
|
|
-- the one defined by the solution.
|
|
--
|
|
|
|
function suite.mapsBuildCfg_toBuildCfgAndPlatform()
|
|
configurations { "Debug", "Release" }
|
|
platforms { "Win32" }
|
|
configmap { ["Debug"] = { "ProjectDebug", "x64" } }
|
|
prepare()
|
|
test.capture [[
|
|
ProjectDebug:x64
|
|
ProjectDebug:Win32
|
|
Release:x64
|
|
Release:Win32
|
|
]]
|
|
end
|
|
|
|
|
|
--
|
|
-- Any duplicate configurations created by the mapping should be removed.
|
|
--
|
|
|
|
function suite.removesDups_onConfigMapping()
|
|
configurations { "Debug", "Development", "Release" }
|
|
configmap { ["Development"] = "Debug" }
|
|
prepare()
|
|
test.capture [[
|
|
Debug:
|
|
Release:
|
|
]]
|
|
end
|
|
|
|
|
|
--
|
|
-- If there is overlap in the solution and project configuration lists,
|
|
-- the ordering at the project level should be maintained to avoid
|
|
-- unnecessarily dirtying the project file.
|
|
--
|
|
|
|
function suite.maintainsProjectOrdering_onSolutionOverlap()
|
|
configurations { "Debug", "Release" }
|
|
prepare { "Debug", "Development", "Profile", "Release" }
|
|
test.capture [[
|
|
Debug:
|
|
Development:
|
|
Profile:
|
|
Release:
|
|
]]
|
|
end
|
|
|