--- a/sbsv2/raptor/test/smoke_suite/featurevariants.py Tue Mar 30 20:25:06 2010 +0100
+++ b/sbsv2/raptor/test/smoke_suite/featurevariants.py Wed Apr 07 12:26:04 2010 +0100
@@ -1,5 +1,5 @@
#
-# Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+# Copyright (c) 2009-2010 Nokia Corporation and/or its subsidiary(-ies).
# All rights reserved.
# This component and the accompanying materials are made available
# under the terms of the License "Eclipse Public License v1.0"
@@ -14,89 +14,134 @@
# Description:
#
-from raptor_tests import SmokeTest
+from raptor_tests import AntiTargetSmokeTest, ReplaceEnvs
import os
def run():
- t = SmokeTest()
-
- # tests for building feature variants
- t.id = "56"
- t.name = "featurevariants"
+ t = AntiTargetSmokeTest()
t.usebash = True
- t.command = "sbs -b smoke_suite/test_resources/bv/bld.inf -c armv5 " + \
- "-c armv5.test_bv_1 -c armv5.test_bv_2 -c armv5.test_bv_3 " + \
- "--configpath=test/smoke_suite/test_resources/bv -f-"
- t.targets = [
- # prebuilt files
+
+ preBuiltTargets = [
"$(EPOCROOT)/epoc32/release/armv5/udeb/dummy.lib",
"$(EPOCROOT)/epoc32/release/armv5/urel/dummy.lib",
"$(EPOCROOT)/epoc32/release/armv5/udeb/debfake.lib",
- "$(EPOCROOT)/epoc32/release/armv5/urel/relfake.lib",
-
- # built files
+ "$(EPOCROOT)/epoc32/release/armv5/urel/relfake.lib"
+ ]
+
+ invariantTargets = [
"$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_invariant.dll",
"$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_invariant.dll.map",
"$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_invariant.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_invariant.dll",
"$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_invariant.dll.map",
"$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_invariant.dll.sym",
+ "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_invariant.dso",
+ "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_invariant{000a0000}.dso"
+ ]
+
+ variantTargetsDefaultTree = [
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_variant1.dll",
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_variant1.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_variant1.dll.sym",
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_variant2.dll",
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_variant2.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createstaticdll_variant2.dll.sym",
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createexe_variant3.exe",
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createexe_variant3.exe.map",
+ "$(EPOCROOT)/epoc32/release/armv5/udeb/createexe_variant3.exe.sym",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_variant1.dll",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_variant1.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_variant1.dll.sym",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_variant2.dll",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_variant2.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createstaticdll_variant2.dll.sym",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createexe_variant3.exe",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createexe_variant3.exe.map",
+ "$(EPOCROOT)/epoc32/release/armv5/urel/createexe_variant3.exe.sym"
+ ]
+
+ variantTargetsProductTrees = [
"$(EPOCROOT)/epoc32/release/armv5.one/udeb/createstaticdll_variant1.dll",
"$(EPOCROOT)/epoc32/release/armv5.one/udeb/createstaticdll_variant1.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.one/udeb/createstaticdll_variant1.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.one/udeb/createstaticdll_variant1.dll.vmap",
"$(EPOCROOT)/epoc32/release/armv5.one/udeb/createstaticdll_variant2.dll",
"$(EPOCROOT)/epoc32/release/armv5.one/udeb/createstaticdll_variant2.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.one/udeb/createstaticdll_variant1.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.one/udeb/createstaticdll_variant2.dll.vmap",
+ "$(EPOCROOT)/epoc32/release/armv5.one/udeb/createexe_variant3.exe",
+ "$(EPOCROOT)/epoc32/release/armv5.one/udeb/createexe_variant3.exe.map",
+ "$(EPOCROOT)/epoc32/release/armv5.one/udeb/createexe_variant3.exe.sym",
"$(EPOCROOT)/epoc32/release/armv5.one/udeb/createexe_variant3.exe.vmap",
"$(EPOCROOT)/epoc32/release/armv5.one/urel/createstaticdll_variant1.dll",
"$(EPOCROOT)/epoc32/release/armv5.one/urel/createstaticdll_variant1.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.one/urel/createstaticdll_variant1.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.one/urel/createstaticdll_variant1.dll.vmap",
"$(EPOCROOT)/epoc32/release/armv5.one/urel/createstaticdll_variant2.dll",
"$(EPOCROOT)/epoc32/release/armv5.one/urel/createstaticdll_variant2.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.one/urel/createstaticdll_variant2.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.one/urel/createstaticdll_variant2.dll.vmap",
+ "$(EPOCROOT)/epoc32/release/armv5.one/urel/createexe_variant3.exe",
+ "$(EPOCROOT)/epoc32/release/armv5.one/urel/createexe_variant3.exe.map",
+ "$(EPOCROOT)/epoc32/release/armv5.one/urel/createexe_variant3.exe.sym",
"$(EPOCROOT)/epoc32/release/armv5.one/urel/createexe_variant3.exe.vmap",
"$(EPOCROOT)/epoc32/release/armv5.two/udeb/createstaticdll_variant1.dll",
"$(EPOCROOT)/epoc32/release/armv5.two/udeb/createstaticdll_variant1.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.two/udeb/createstaticdll_variant1.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.two/udeb/createstaticdll_variant1.dll.vmap",
"$(EPOCROOT)/epoc32/release/armv5.two/udeb/createstaticdll_variant2.dll",
"$(EPOCROOT)/epoc32/release/armv5.two/udeb/createstaticdll_variant2.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.two/udeb/createstaticdll_variant2.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.two/udeb/createstaticdll_variant2.dll.vmap",
+ "$(EPOCROOT)/epoc32/release/armv5.two/udeb/createexe_variant3.exe",
+ "$(EPOCROOT)/epoc32/release/armv5.two/udeb/createexe_variant3.exe.map",
+ "$(EPOCROOT)/epoc32/release/armv5.two/udeb/createexe_variant3.exe.sym",
"$(EPOCROOT)/epoc32/release/armv5.two/udeb/createexe_variant3.exe.vmap",
"$(EPOCROOT)/epoc32/release/armv5.two/urel/createstaticdll_variant1.dll",
"$(EPOCROOT)/epoc32/release/armv5.two/urel/createstaticdll_variant1.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.two/urel/createstaticdll_variant1.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.two/urel/createstaticdll_variant1.dll.vmap",
"$(EPOCROOT)/epoc32/release/armv5.two/urel/createstaticdll_variant2.dll",
"$(EPOCROOT)/epoc32/release/armv5.two/urel/createstaticdll_variant2.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.two/urel/createstaticdll_variant2.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.two/urel/createstaticdll_variant2.dll.vmap",
+ "$(EPOCROOT)/epoc32/release/armv5.two/urel/createexe_variant3.exe",
+ "$(EPOCROOT)/epoc32/release/armv5.two/urel/createexe_variant3.exe.map",
+ "$(EPOCROOT)/epoc32/release/armv5.two/urel/createexe_variant3.exe.sym",
"$(EPOCROOT)/epoc32/release/armv5.two/urel/createexe_variant3.exe.vmap",
"$(EPOCROOT)/epoc32/release/armv5.three/udeb/createstaticdll_variant1.dll",
"$(EPOCROOT)/epoc32/release/armv5.three/udeb/createstaticdll_variant1.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.three/udeb/createstaticdll_variant1.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.three/udeb/createstaticdll_variant1.dll.vmap",
"$(EPOCROOT)/epoc32/release/armv5.three/udeb/createstaticdll_variant2.dll",
"$(EPOCROOT)/epoc32/release/armv5.three/udeb/createstaticdll_variant2.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.three/udeb/createstaticdll_variant2.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.three/udeb/createstaticdll_variant2.dll.vmap",
+ "$(EPOCROOT)/epoc32/release/armv5.three/udeb/createexe_variant3.exe",
+ "$(EPOCROOT)/epoc32/release/armv5.three/udeb/createexe_variant3.exe.map",
+ "$(EPOCROOT)/epoc32/release/armv5.three/udeb/createexe_variant3.exe.sym",
"$(EPOCROOT)/epoc32/release/armv5.three/udeb/createexe_variant3.exe.vmap",
"$(EPOCROOT)/epoc32/release/armv5.three/urel/createstaticdll_variant1.dll",
"$(EPOCROOT)/epoc32/release/armv5.three/urel/createstaticdll_variant1.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.three/urel/createstaticdll_variant1.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.three/urel/createstaticdll_variant1.dll.vmap",
"$(EPOCROOT)/epoc32/release/armv5.three/urel/createstaticdll_variant2.dll",
"$(EPOCROOT)/epoc32/release/armv5.three/urel/createstaticdll_variant2.dll.map",
+ "$(EPOCROOT)/epoc32/release/armv5.three/urel/createstaticdll_variant2.dll.sym",
"$(EPOCROOT)/epoc32/release/armv5.three/urel/createstaticdll_variant2.dll.vmap",
+ "$(EPOCROOT)/epoc32/release/armv5.three/urel/createexe_variant3.exe",
+ "$(EPOCROOT)/epoc32/release/armv5.three/urel/createexe_variant3.exe.map",
+ "$(EPOCROOT)/epoc32/release/armv5.three/urel/createexe_variant3.exe.sym",
"$(EPOCROOT)/epoc32/release/armv5.three/urel/createexe_variant3.exe.vmap",
-
- "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_invariant.dso",
- "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_invariant{000a0000}.dso",
- "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_variant1.dso",
- "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_variant1{000a0000}.dso",
- "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_variant2.dso",
- "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_variant2{000a0000}.dso",
-
+ ]
+
+ variantTargetsGeneric = [
"$(EPOCROOT)/epoc32/data/z/resource/apps/dummy_var1.rsc",
"$(EPOCROOT)/epoc32/include/dummy_var1.rsg",
"$(EPOCROOT)/epoc32/data/z/resource/apps/dummy_var2.rsc",
@@ -104,9 +149,14 @@
"$(EPOCROOT)/epoc32/data/z/resource/apps/dummy_var3.rsc",
"$(EPOCROOT)/epoc32/include/dummy_var3.rsg",
"$(EPOCROOT)/epoc32/data/z/resource/apps/dummy_inv.rsc",
- "$(EPOCROOT)/epoc32/include/dummy_inv.rsg"
+ "$(EPOCROOT)/epoc32/include/dummy_inv.rsg",
+ "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_variant1.dso",
+ "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_variant1{000a0000}.dso",
+ "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_variant2.dso",
+ "$(EPOCROOT)/epoc32/release/armv5/lib/createstaticdll_variant2{000a0000}.dso"
]
- t.addbuildtargets('smoke_suite/test_resources/bv/bld.inf', [
+
+ invariantBuildTargets = [
"createstaticdll_invariant_dll/armv5/udeb/CreateStaticDLL_invariant.o",
"createstaticdll_invariant_dll/armv5/udeb/CreateStaticDLL_invariant.o.d",
"createstaticdll_invariant_dll/armv5/udeb/createstaticdll_invariant_udeb_objects.via",
@@ -119,15 +169,41 @@
"createstaticdll_invariant_dll/armv5/urel/createstaticdll_invariant{000a0000}.dso",
"dummy_inv_dll/dummy_inv__resource_apps_sc.rpp",
- "dummy_inv_dll/dummy_inv__resource_apps_sc.rpp.d",
- "dummy_var1_dll/dummy_var1__resource_apps_sc.rpp",
- "dummy_var1_dll/dummy_var1__resource_apps_sc.rpp.d",
- "dummy_var2_dll/dummy_var2__resource_apps_sc.rpp",
- "dummy_var2_dll/dummy_var2__resource_apps_sc.rpp.d",
- "dummy_var3_exe/dummy_var3__resource_apps_sc.rpp",
- "dummy_var3_exe/dummy_var3__resource_apps_sc.rpp.d",
+ "dummy_inv_dll/dummy_inv__resource_apps_sc.rpp.d"
+ ]
+
+ variantBuildTargetsDefaultTree = [
+ "createstaticdll_variant1_dll/armv5/udeb/CreateStaticDLL_variant1.o",
+ "createstaticdll_variant1_dll/armv5/udeb/CreateStaticDLL_variant1.o.d",
+ "createstaticdll_variant1_dll/armv5/udeb/createstaticdll_variant1_udeb_objects.via",
+ "createstaticdll_variant1_dll/armv5/udeb/createstaticdll_variant1{000a0000}.def",
+ "createstaticdll_variant1_dll/armv5/udeb/createstaticdll_variant1{000a0000}.dso",
+ "createstaticdll_variant1_dll/armv5/urel/CreateStaticDLL_variant1.o",
+ "createstaticdll_variant1_dll/armv5/urel/CreateStaticDLL_variant1.o.d",
+ "createstaticdll_variant1_dll/armv5/urel/createstaticdll_variant1_urel_objects.via",
+ "createstaticdll_variant1_dll/armv5/urel/createstaticdll_variant1{000a0000}.def",
+ "createstaticdll_variant1_dll/armv5/urel/createstaticdll_variant1{000a0000}.dso",
+ "createstaticdll_variant2_dll/armv5/udeb/CreateStaticDLL_variant2.o",
+ "createstaticdll_variant2_dll/armv5/udeb/CreateStaticDLL_variant2.o.d",
+ "createstaticdll_variant2_dll/armv5/udeb/createstaticdll_variant2_udeb_objects.via",
+ "createstaticdll_variant2_dll/armv5/udeb/createstaticdll_variant2{000a0000}.def",
+ "createstaticdll_variant2_dll/armv5/udeb/createstaticdll_variant2{000a0000}.dso",
+ "createstaticdll_variant2_dll/armv5/urel/CreateStaticDLL_variant2.o",
+ "createstaticdll_variant2_dll/armv5/urel/CreateStaticDLL_variant2.o.d",
+ "createstaticdll_variant2_dll/armv5/urel/createstaticdll_variant2_urel_objects.via",
+ "createstaticdll_variant2_dll/armv5/urel/createstaticdll_variant2{000a0000}.def",
+ "createstaticdll_variant2_dll/armv5/urel/createstaticdll_variant2{000a0000}.dso",
+ "createexe_variant3_exe/armv5/udeb/CreateEXE_variant3.o",
+ "createexe_variant3_exe/armv5/udeb/CreateEXE_variant3.o.d",
+ "createexe_variant3_exe/armv5/udeb/createexe_variant3_udeb_objects.via",
+ "createexe_variant3_exe/armv5/urel/CreateEXE_variant3.o",
+ "createexe_variant3_exe/armv5/urel/CreateEXE_variant3.o.d",
+ "createexe_variant3_exe/armv5/urel/createexe_variant3_urel_objects.via"
+ ]
+
+ variantBuildTargetsProductTrees = [
"createstaticdll_variant1_dll/armv5.one/udeb/CreateStaticDLL_variant1.o",
"createstaticdll_variant1_dll/armv5.one/udeb/CreateStaticDLL_variant1.o.d",
"createstaticdll_variant1_dll/armv5.one/udeb/createstaticdll_variant1_udeb_objects.via",
@@ -157,7 +233,6 @@
"createexe_variant3_exe/armv5.one/urel/CreateEXE_variant3.o.d",
"createexe_variant3_exe/armv5.one/urel/createexe_variant3_urel_objects.via",
-
"createstaticdll_variant1_dll/armv5.two/udeb/CreateStaticDLL_variant1.o",
"createstaticdll_variant1_dll/armv5.two/udeb/CreateStaticDLL_variant1.o.d",
"createstaticdll_variant1_dll/armv5.two/udeb/createstaticdll_variant1_udeb_objects.via",
@@ -187,7 +262,6 @@
"createexe_variant3_exe/armv5.two/urel/CreateEXE_variant3.o.d",
"createexe_variant3_exe/armv5.two/urel/createexe_variant3_urel_objects.via",
-
"createstaticdll_variant1_dll/armv5.three/udeb/CreateStaticDLL_variant1.o",
"createstaticdll_variant1_dll/armv5.three/udeb/CreateStaticDLL_variant1.o.d",
"createstaticdll_variant1_dll/armv5.three/udeb/createstaticdll_variant1_udeb_objects.via",
@@ -216,14 +290,59 @@
"createexe_variant3_exe/armv5.three/urel/CreateEXE_variant3.o",
"createexe_variant3_exe/armv5.three/urel/CreateEXE_variant3.o.d",
"createexe_variant3_exe/armv5.three/urel/createexe_variant3_urel_objects.via"
- ])
+ ]
+
+ variantBuildTargetsGeneric = [
+ "dummy_var1_dll/dummy_var1__resource_apps_sc.rpp",
+ "dummy_var1_dll/dummy_var1__resource_apps_sc.rpp.d",
+ "dummy_var2_dll/dummy_var2__resource_apps_sc.rpp",
+ "dummy_var2_dll/dummy_var2__resource_apps_sc.rpp.d",
+ "dummy_var3_exe/dummy_var3__resource_apps_sc.rpp",
+ "dummy_var3_exe/dummy_var3__resource_apps_sc.rpp.d"
+ ]
+
+ sbscommand = "sbs -b smoke_suite/test_resources/bv/bld.inf -c armv5 " + \
+ "-c armv5.test_bv_1 -c armv5.test_bv_2 -c armv5.test_bv_3 -f- " + \
+ "--configpath=test/smoke_suite/test_resources/bv/config/variants"
+
+ t.id = "56a"
+ t.description = """Build variant and invariant components.
+ In this default mode of operation, all components build for the non-product armv5 config whereas
+ only variant components build for the armv5.* bv configs."""
+ t.name = "featurevariant_build"
+ t.command = sbscommand
+ t.targets = preBuiltTargets + invariantTargets + variantTargetsGeneric + variantTargetsDefaultTree + variantTargetsProductTrees
+ t.addbuildtargets('smoke_suite/test_resources/bv/bld.inf',
+ invariantBuildTargets + variantBuildTargetsGeneric + variantBuildTargetsDefaultTree + variantBuildTargetsProductTrees
+ )
# Test that static libs are linked from the invariant place.
t.mustmatch = [
"armlink.*epoc32/release/armv5/urel/bv_static_lib.lib",
"armlink.*epoc32/release/armv5/udeb/bv_static_lib.lib"
- ]
+ ]
t.run()
+ t.id = "56b"
+ t.description = """Build variant and invariant components using an os_properties.xml that sets FEATUREVARIANTSAFE=1.
+ With FEATUREVARIANTSAFE only invariant components build for the non-product armv5 config and
+ only variant components build for the armv5.* bv configs."""
+ t.name = "featurevariant_build_featurevariantsafe"
+ t.command = sbscommand + " --configpath=test/smoke_suite/test_resources/bv/config/properties"
+ t.targets = preBuiltTargets + invariantTargets + variantTargetsGeneric + variantTargetsProductTrees
+ t.addbuildtargets('smoke_suite/test_resources/bv/bld.inf',
+ invariantBuildTargets + variantBuildTargetsGeneric + variantBuildTargetsProductTrees
+ )
+ t.antitargets = variantTargetsDefaultTree
+ t.addbuildantitargets('smoke_suite/test_resources/bv/bld.inf',
+ variantBuildTargetsDefaultTree
+ )
+ # Test that static libs are linked from the invariant place.
+ t.mustmatch = [
+ "armlink.*epoc32/release/armv5/urel/bv_static_lib.lib",
+ "armlink.*epoc32/release/armv5/udeb/bv_static_lib.lib"
+ ]
+ t.run()
+
# tests for the createvmap script
createvmap = "python $(SBS_HOME)/bin/createvmap.py"
@@ -247,7 +366,7 @@
srcWithout = " -s " + bvdata + "/without_macros.cpp"
badSrc = " -s " + bvdata + "/with_errors.cpp"
- t.id = "56a"
+ t.id = "56c"
t.name = "createvmap exits with an error"
t.usebash = True
t.command = createvmap
@@ -257,7 +376,7 @@
t.run()
- t.id = "56b"
+ t.id = "56d"
t.name = "createvmap shows cpp errors"
t.usebash = True
t.command = createvmap + vmap + bvcpp + preinc + listA + badSrc
@@ -267,7 +386,7 @@
t.run()
- t.id = "56c"
+ t.id = "56e"
t.name = "createvmap errors on missing feature list"
t.usebash = True
t.command = createvmap + vmap + bvcpp + preinc + listC + srcWith
@@ -277,7 +396,7 @@
t.run()
- t.id = "56d"
+ t.id = "56f"
t.name = "createvmap warns on featureless code"
t.usebash = True
t.command = createvmap + vmap + bvcpp + preinc + listA + srcWithout
@@ -287,7 +406,7 @@
t.run()
- t.id = "56e"
+ t.id = "56g"
t.name = "createvmap creates the right vmap file"
t.usebash = True
t.command = createvmap + vmap + bvcpp + preinc + listA + listB + srcWith + srcWithout + " && cat " + vmapfile