From dfb35e704c3eae31a08535a2aa5dbaf365ffab64 Mon Sep 17 00:00:00 2001 From: Eric Berquist Date: Thu, 15 Aug 2024 15:29:41 -0600 Subject: [PATCH 1/3] use NOBUILD variable instead of bare string literal --- buildsys/bamboo.sh | 75 ++++++++++++++++++++++++---------------------- 1 file changed, 39 insertions(+), 36 deletions(-) diff --git a/buildsys/bamboo.sh b/buildsys/bamboo.sh index 938be291..882ccc98 100755 --- a/buildsys/bamboo.sh +++ b/buildsys/bamboo.sh @@ -360,6 +360,9 @@ setConvenienceVars() { echo " junobaseoptions = $junobaseoptions" } +# Singleton used for setting config line of a codebase when it should not be built. +NOBUILD="NOBUILD" + #------------------------------------------------------------------------- # Function: getconfig # Description: @@ -421,7 +424,7 @@ getconfig() { setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions $coreMiscEnv" elementsConfigStr="$elementsbaseoptions --with-hbmdramsim=$SST_DEPS_INSTALL_HBM_DRAMSIM2 --with-ramulator=$SST_DEPS_INSTALL_RAMULATOR --with-goblin-hmcsim=$SST_DEPS_INSTALL_GOBLIN_HMCSIM --with-dramsim3=$SST_DEPS_INSTALL_DRAMSIM3 --with-dramsim=$SST_DEPS_INSTALL_DRAMSIM --with-nvdimmsim=$SST_DEPS_INSTALL_NVDIMMSIM --with-hybridsim=$SST_DEPS_INSTALL_HYBRIDSIM --with-pin=$SST_DEPS_INSTALL_INTEL_PIN $elementsMiscEnv" - macroConfigStr="NOBUILD" + macroConfigStr="${NOBUILD}" externalelementConfigStr="$externalelementbaseoptions" junoConfigStr="$junobaseoptions" ;; @@ -437,10 +440,10 @@ getconfig() { depsStr="-r none" # Dependencies only needed for elements setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions $coreMiscEnv" - elementsConfigStr="NOBUILD" - macroConfigStr="NOBUILD" - externalelementConfigStr="NOBUILD" - junoConfigStr="NOBUILD" + elementsConfigStr="${NOBUILD}" + macroConfigStr="${NOBUILD}" + externalelementConfigStr="${NOBUILD}" + junoConfigStr="${NOBUILD}" ;; sstmainline_config_linux_with_cuda) #----------------------------------------------------------------- @@ -456,7 +459,7 @@ getconfig() { setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions $coreMiscEnv --disable-mem-pools" elementsConfigStr="$elementsbaseoptions --with-cuda=$CUDA_ROOT --with-gpgpusim=$SST_DEPS_INSTALL_GPGPUSIM --with-hbmdramsim=$SST_DEPS_INSTALL_HBM_DRAMSIM2 --with-ramulator=$SST_DEPS_INSTALL_RAMULATOR --with-goblin-hmcsim=$SST_DEPS_INSTALL_GOBLIN_HMCSIM --with-dramsim3=$SST_DEPS_INSTALL_DRAMSIM3 --with-dramsim=$SST_DEPS_INSTALL_DRAMSIM --with-nvdimmsim=$SST_DEPS_INSTALL_NVDIMMSIM --with-hybridsim=$SST_DEPS_INSTALL_HYBRIDSIM --with-pin=$SST_DEPS_INSTALL_INTEL_PIN $elementsMiscEnv" - macroConfigStr="NOBUILD" + macroConfigStr="${NOBUILD}" externalelementConfigStr="$externalelementbaseoptions" junoConfigStr="$junobaseoptions" # Must Setup the GPGPUSIM Environment @@ -485,9 +488,9 @@ getconfig() { setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions $coreMiscEnv --disable-mem-pools --disable-mpi" elementsConfigStr="$elementsbaseoptions --with-cuda=$CUDA_ROOT --with-gpgpusim=$SST_DEPS_INSTALL_GPGPUSIM --with-hbmdramsim=$SST_DEPS_INSTALL_HBM_DRAMSIM2 --with-ramulator=$SST_DEPS_INSTALL_RAMULATOR --with-goblin-hmcsim=$SST_DEPS_INSTALL_GOBLIN_HMCSIM --with-dramsim3=$SST_DEPS_INSTALL_DRAMSIM3 --with-dramsim=$SST_DEPS_INSTALL_DRAMSIM --with-nvdimmsim=$SST_DEPS_INSTALL_NVDIMMSIM --with-hybridsim=$SST_DEPS_INSTALL_HYBRIDSIM --with-pin=$SST_DEPS_INSTALL_INTEL_PIN $elementsMiscEnv" - macroConfigStr="NOBUILD" - externalelementConfigStr="NOBUILD" - junoConfigStr="NOBUILD" + macroConfigStr="${NOBUILD}" + externalelementConfigStr="${NOBUILD}" + junoConfigStr="${NOBUILD}" # Must Setup the GPGPUSIM Environment echo "SETUP THE GPGPUSIM ENVIRONMENT" echo "==== ENV BEFORE GPGPUSIM ENV SETUP ===" @@ -514,7 +517,7 @@ getconfig() { setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions $coreMiscEnv --disable-mpi" elementsConfigStr="$elementsbaseoptions --with-hbmdramsim=$SST_DEPS_INSTALL_HBM_DRAMSIM2 --with-ramulator=$SST_DEPS_INSTALL_RAMULATOR --with-goblin-hmcsim=$SST_DEPS_INSTALL_GOBLIN_HMCSIM --with-dramsim3=$SST_DEPS_INSTALL_DRAMSIM3 --with-dramsim=$SST_DEPS_INSTALL_DRAMSIM --with-nvdimmsim=$SST_DEPS_INSTALL_NVDIMMSIM --with-hybridsim=$SST_DEPS_INSTALL_HYBRIDSIM --with-pin=$SST_DEPS_INSTALL_INTEL_PIN $elementsMiscEnv" - macroConfigStr="NOBUILD" + macroConfigStr="${NOBUILD}" externalelementConfigStr="$externalelementbaseoptions" junoConfigStr="$junobaseoptions" ;; @@ -528,7 +531,7 @@ getconfig() { setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions" elementsConfigStr="$elementsbaseoptions" - macroConfigStr="NOBUILD" + macroConfigStr="${NOBUILD}" externalelementConfigStr="$externalelementbaseoptions" junoConfigStr="$junobaseoptions" ;; @@ -544,7 +547,7 @@ getconfig() { setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions $coreMiscEnv" elementsConfigStr="$elementsbaseoptions --with-hbmdramsim=$SST_DEPS_INSTALL_HBM_DRAMSIM2 --with-ramulator=$SST_DEPS_INSTALL_RAMULATOR --with-goblin-hmcsim=$SST_DEPS_INSTALL_GOBLIN_HMCSIM --with-dramsim3=$SST_DEPS_INSTALL_DRAMSIM3 --with-dramsim=$SST_DEPS_INSTALL_DRAMSIM --with-nvdimmsim=$SST_DEPS_INSTALL_NVDIMMSIM --with-hybridsim=$SST_DEPS_INSTALL_HYBRIDSIM $elementsMiscEnv" - macroConfigStr="NOBUILD" + macroConfigStr="${NOBUILD}" externalelementConfigStr="$externalelementbaseoptions" junoConfigStr="$junobaseoptions" ;; @@ -560,10 +563,10 @@ getconfig() { depsStr="-r none" setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions" - elementsConfigStr="NOBUILD" + elementsConfigStr="${NOBUILD}" macroConfigStr="--prefix=$SST_MACRO_INSTALL CC=`which clang` CXX=`which clang++` --with-pth=$PTH_HOME --disable-regex --with-sst-core=$SST_CORE_INSTALL" - externalelementConfigStr="NOBUILD" - junoConfigStr="NOBUILD" + externalelementConfigStr="${NOBUILD}" + junoConfigStr="${NOBUILD}" ;; sst-macro_nosstcore_mac) @@ -576,11 +579,11 @@ getconfig() { miscEnv="${cc_environment} ${mpi_environment}" depsStr="-r none" setConvenienceVars "$depsStr" - coreConfigStr="NOBUILD" - elementsConfigStr="NOBUILD" + coreConfigStr="${NOBUILD}" + elementsConfigStr="${NOBUILD}" macroConfigStr="--prefix=$SST_MACRO_INSTALL CC=`which clang` CXX=`which clang++` --with-pth=$PTH_HOME --disable-regex" - externalelementConfigStr="NOBUILD" - junoConfigStr="NOBUILD" + externalelementConfigStr="${NOBUILD}" + junoConfigStr="${NOBUILD}" ;; sst-macro_withsstcore_linux) @@ -594,10 +597,10 @@ getconfig() { depsStr="-r none" setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions" - elementsConfigStr="NOBUILD" + elementsConfigStr="${NOBUILD}" macroConfigStr="--prefix=$SST_MACRO_INSTALL CC=`which gcc` CXX=`which g++` --disable-regex --disable-unordered-containers --with-sst-core=$SST_CORE_INSTALL" - externalelementConfigStr="NOBUILD" - junoConfigStr="NOBUILD" + externalelementConfigStr="${NOBUILD}" + junoConfigStr="${NOBUILD}" ;; sst-macro_nosstcore_linux) @@ -610,11 +613,11 @@ getconfig() { miscEnv="${cc_environment} ${mpi_environment}" depsStr="-r none" setConvenienceVars "$depsStr" - coreConfigStr="NOBUILD" - elementsConfigStr="NOBUILD" + coreConfigStr="${NOBUILD}" + elementsConfigStr="${NOBUILD}" macroConfigStr="--prefix=$SST_MACRO_INSTALL CC=`which gcc` CXX=`which g++` --disable-regex --disable-unordered-containers" - externalelementConfigStr="NOBUILD" - junoConfigStr="NOBUILD" + externalelementConfigStr="${NOBUILD}" + junoConfigStr="${NOBUILD}" ;; sst_Macro_make_dist) @@ -629,10 +632,10 @@ getconfig() { depsStr="-r none" setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions" - elementsConfigStr="NOBUILD" + elementsConfigStr="${NOBUILD}" macroConfigStr="--prefix=$SST_MACRO_INSTALL CC=`which gcc` CXX=`which g++` --disable-regex --disable-unordered-containers --with-sst-core=$SST_CORE_INSTALL" - externalelementConfigStr="NOBUILD" - junoConfigStr="NOBUILD" + externalelementConfigStr="${NOBUILD}" + junoConfigStr="${NOBUILD}" ;; sstmainline_config_make_dist_test) @@ -648,7 +651,7 @@ getconfig() { setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions" elementsConfigStr="$elementsbaseoptions" - macroConfigStr="NOBUILD" + macroConfigStr="${NOBUILD}" externalelementConfigStr="$externalelementbaseoptions" junoConfigStr="$junobaseoptions" ;; @@ -665,10 +668,10 @@ getconfig() { depsStr="-r none" setConvenienceVars "$depsStr" coreConfigStr="$corebaseoptions" - elementsConfigStr="NOBUILD" - macroConfigStr="NOBUILD" - externalelementConfigStr="NOBUILD" - junoConfigStr="NOBUILD" + elementsConfigStr="${NOBUILD}" + macroConfigStr="${NOBUILD}" + externalelementConfigStr="${NOBUILD}" + junoConfigStr="${NOBUILD}" ;; *) @@ -1123,7 +1126,7 @@ config_and_build() { local source_dir="$4" local conf_script_name="$5" - if [[ "${selected_config}" == "NOBUILD" ]] + if [[ "${selected_config}" == "${NOBUILD}" ]] then echo "============== ${repo_name} - NO BUILD REQUIRED ===============" else @@ -1355,7 +1358,7 @@ config_and_build_simple() { local repo_name="$1" local selected_config="$2" - if [[ "${selected_config}" == "NOBUILD" ]] + if [[ "${selected_config}" == "${NOBUILD}" ]] then echo "============== ${repo_name} - NO BUILD REQUIRED ===============" else From 5f486c2dbedbb0a1a60af80828ec34424f483b64 Mon Sep 17 00:00:00 2001 From: Eric Berquist Date: Thu, 15 Aug 2024 15:55:20 -0600 Subject: [PATCH 2/3] factor out running core tests from elements wildcard determination --- buildsys/bamboo.sh | 29 ++++++++++++++++++----------- 1 file changed, 18 insertions(+), 11 deletions(-) diff --git a/buildsys/bamboo.sh b/buildsys/bamboo.sh index 882ccc98..1abacbed 100755 --- a/buildsys/bamboo.sh +++ b/buildsys/bamboo.sh @@ -2129,6 +2129,21 @@ then echo "BAMBOO: SST original dotests retval = $retval" # NOW RUN THE FRAMEWORKS ELEMENTS TESTS + if [[ ${SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS:+isSet} != isSet ]] ; then + echo "**************************************************************************" + echo "*** " + echo "*** RUNNING NEW TEST FRAMEWORKS CORE - FULL SET OF TESTS" + echo "*** " + echo "**************************************************************************" + # WE ARE RUNNING THE FRAMEWORKS ELEMENTS FULL SET OF TESTS AFTER DOTESTS() HAVE RUN + cd $SST_ROOT + + $SST_PYTHON_APP_EXE $SST_TEST_FRAMEWORKS_CORE_APP_EXE $SST_TEST_FRAMEWORKS_PARAMS -z -r $SST_MULTI_RANK_COUNT -t $SST_MULTI_THREAD_COUNT + core_frameworks_retval=$? + echo "BAMBOO: SST Frameworks Core Test retval = $core_frameworks_retval" + fi + + cd $SST_ROOT if [[ ${SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS:+isSet} == isSet ]] ; then echo "**************************************************************************" echo "*** " @@ -2136,26 +2151,18 @@ then echo "*** " echo "**************************************************************************" # WE ARE RUNNING THE FRAMEWORKS ELEMENTS SUBSET OF TESTS (Set by wildcard) AFTER DOTESTS() HAVE RUN - cd $SST_ROOT $SST_PYTHON_APP_EXE $SST_TEST_FRAMEWORKS_ELEMENTS_APP_EXE $SST_TEST_FRAMEWORKS_PARAMS -z -r $SST_MULTI_RANK_COUNT -t $SST_MULTI_THREAD_COUNT -w $SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS - frameworks_retval=$? - echo "BAMBOO: SST Frameworks Elements Test retval = $frameworks_retval" else echo "**************************************************************************" echo "*** " - echo "*** RUNNING NEW TEST FRAMEWORKS CORE AND ELEMENTS - FULL SET OF TESTS" + echo "*** RUNNING NEW TEST FRAMEWORKS ELEMENTS - FULL SET OF TESTS" echo "*** " echo "**************************************************************************" # WE ARE RUNNING THE FRAMEWORKS ELEMENTS FULL SET OF TESTS AFTER DOTESTS() HAVE RUN - cd $SST_ROOT - - $SST_PYTHON_APP_EXE $SST_TEST_FRAMEWORKS_CORE_APP_EXE $SST_TEST_FRAMEWORKS_PARAMS -z -r $SST_MULTI_RANK_COUNT -t $SST_MULTI_THREAD_COUNT - core_frameworks_retval=$? $SST_PYTHON_APP_EXE $SST_TEST_FRAMEWORKS_ELEMENTS_APP_EXE $SST_TEST_FRAMEWORKS_PARAMS -k -z -r $SST_MULTI_RANK_COUNT -t $SST_MULTI_THREAD_COUNT - elements_frameworks_retval=$? - echo "BAMBOO: SST Frameworks Core Test retval = $core_frameworks_retval" - echo "BAMBOO: SST Frameworks Elements Test retval = $elements_frameworks_retval" fi + elements_frameworks_retval=$? + echo "BAMBOO: SST Frameworks Elements Test retval = $elements_frameworks_retval" # Check the retval result from the bamboo dotests then check the frameworks_retval results with the frameworks run if [ $retval -eq 0 ]; then From 47184273c53daaba24292a038482bd9b3675869f Mon Sep 17 00:00:00 2001 From: Eric Berquist Date: Thu, 15 Aug 2024 16:14:49 -0600 Subject: [PATCH 3/3] skip elements tests if intentionally not built --- buildsys/bamboo.sh | 33 +++++++++++++++++++++------------ 1 file changed, 21 insertions(+), 12 deletions(-) diff --git a/buildsys/bamboo.sh b/buildsys/bamboo.sh index 1abacbed..e3632781 100755 --- a/buildsys/bamboo.sh +++ b/buildsys/bamboo.sh @@ -2144,24 +2144,33 @@ then fi cd $SST_ROOT - if [[ ${SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS:+isSet} == isSet ]] ; then - echo "**************************************************************************" - echo "*** " - echo "*** RUNNING NEW TEST FRAMEWORKS ELEMENTS - SUBSET OF TESTS : ${SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS}" - echo "*** " - echo "**************************************************************************" - # WE ARE RUNNING THE FRAMEWORKS ELEMENTS SUBSET OF TESTS (Set by wildcard) AFTER DOTESTS() HAVE RUN - $SST_PYTHON_APP_EXE $SST_TEST_FRAMEWORKS_ELEMENTS_APP_EXE $SST_TEST_FRAMEWORKS_PARAMS -z -r $SST_MULTI_RANK_COUNT -t $SST_MULTI_THREAD_COUNT -w $SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS + elements_frameworks_retval=0 + if [[ "${SST_SELECTED_ELEMENTS_CONFIG}" != "${NOBUILD}" ]]; then + if [[ ${SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS:+isSet} == isSet ]] ; then + echo "**************************************************************************" + echo "*** " + echo "*** RUNNING NEW TEST FRAMEWORKS ELEMENTS - SUBSET OF TESTS : ${SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS}" + echo "*** " + echo "**************************************************************************" + # WE ARE RUNNING THE FRAMEWORKS ELEMENTS SUBSET OF TESTS (Set by wildcard) AFTER DOTESTS() HAVE RUN + $SST_PYTHON_APP_EXE $SST_TEST_FRAMEWORKS_ELEMENTS_APP_EXE $SST_TEST_FRAMEWORKS_PARAMS -z -r $SST_MULTI_RANK_COUNT -t $SST_MULTI_THREAD_COUNT -w $SST_TEST_FRAMEWORKS_ELEMENTS_WILDCARD_TESTS + else + echo "**************************************************************************" + echo "*** " + echo "*** RUNNING NEW TEST FRAMEWORKS ELEMENTS - FULL SET OF TESTS" + echo "*** " + echo "**************************************************************************" + # WE ARE RUNNING THE FRAMEWORKS ELEMENTS FULL SET OF TESTS AFTER DOTESTS() HAVE RUN + $SST_PYTHON_APP_EXE $SST_TEST_FRAMEWORKS_ELEMENTS_APP_EXE $SST_TEST_FRAMEWORKS_PARAMS -k -z -r $SST_MULTI_RANK_COUNT -t $SST_MULTI_THREAD_COUNT + fi + elements_frameworks_retval=$? else echo "**************************************************************************" echo "*** " - echo "*** RUNNING NEW TEST FRAMEWORKS ELEMENTS - FULL SET OF TESTS" + echo "*** RUNNING NEW TEST FRAMEWORKS - SKIPPING ELEMENTS, NOT BUILT" echo "*** " echo "**************************************************************************" - # WE ARE RUNNING THE FRAMEWORKS ELEMENTS FULL SET OF TESTS AFTER DOTESTS() HAVE RUN - $SST_PYTHON_APP_EXE $SST_TEST_FRAMEWORKS_ELEMENTS_APP_EXE $SST_TEST_FRAMEWORKS_PARAMS -k -z -r $SST_MULTI_RANK_COUNT -t $SST_MULTI_THREAD_COUNT fi - elements_frameworks_retval=$? echo "BAMBOO: SST Frameworks Elements Test retval = $elements_frameworks_retval" # Check the retval result from the bamboo dotests then check the frameworks_retval results with the frameworks run