run_harness_tests() {
local -x HARNESS_OPTIONS=c:j$VCPU_USE
- if [[ "$VCPU_USE" == 1 ]]; then
+ # if we run under docker (! have_sudo) the logic below won't work
+ # it seems as if ulimit acts globally, across the entire OS
+ # and is thus not served properly by a localised `ps xH`
+ if [[ "$VCPU_USE" == 1 ]] && have_sudo ; then
ulim=$(( ( $(ps xH | wc -l) - 3 ) + 4 )) # (real count excluding header + ps + wc) + space for ( make + tee + harness + <actual test> )
echo_err "$(tstamp) Setting process/thread limit to $ulim"
ulimit -u $ulim
- sleep 10 # needed to settle things down a bit
+ sleep 5 # needed to settle things down a bit
fi
make test 2> >(tee "$TEST_STDERR_LOG")
}
run_or_err "Prepare blib" "make pure_all"
run_harness_tests
else
- PROVECMD="prove -lrswj$VCPU_USE xt t"
+ PROVECMD="prove -lrswTj$VCPU_USE xt t"
- # FIXME - temporary, until Package::Stash is fixed
- if perl -M5.010 -e 1 &>/dev/null ; then
- PROVECMD="$PROVECMD -T"
+ # List every single SKIP/TODO when they are visible
+ if [[ "$VCPU_USE" == 1 ]] ; then
+ PROVECMD="$PROVECMD --directives"
fi
echo_err "$(tstamp) running tests with \`$PROVECMD\`"
echo
echo "$(tstamp) Testing took a total of $(( $TEST_T1 - $TEST_T0 ))s"
if [[ -n "$INSTALLDEPS_OUT" ]] ; then
- echo "$(tstamp) Full dep install log at $(/usr/bin/nopaste -q -s Shadowcat -d DepInstall <<< "$INSTALLDEPS_OUT")"
+ echo "$(tstamp) Full dep install log at $(/usr/bin/perl /usr/bin/nopaste -q -s Shadowcat -d DepInstall <<< "$INSTALLDEPS_OUT")"
fi
echo