Add the long ptest job and enhance the short job
[src/qa-testdefinitions.git] / common / scripts / ptest-lava-wrapper-all.sh
diff --git a/common/scripts/ptest-lava-wrapper-all.sh b/common/scripts/ptest-lava-wrapper-all.sh
new file mode 100755 (executable)
index 0000000..48348bc
--- /dev/null
@@ -0,0 +1,35 @@
+#!/bin/bash
+
+# Check if ptest packages are installed
+command -v ptest-runner >/dev/null 2>&1
+if [ $? -ne 0 ] ; then
+    lava-test-case ptest-installed --result SKIP
+else
+    # Run ptests for specified packages
+        lava-test-set start ptest-full
+        UNIT_LOG=$(ptest-runner 2> results.log )
+        if [ $? -eq 0 ] ; then
+            # grep: Get only the ptests results, no log
+            # sed 1: replace spaces by hyphens
+            # sed 2: remove any special character
+            # sed 3: find status and test name, wrap it in a lava-test-case call
+            # sh: execute the lava-test-case commands
+            test_pass=$(echo "$UNIT_LOG" | grep -e 'PASS' | wc -l)
+            test_fail=$(echo "$UNIT_LOG" | grep -e 'FAIL' | wc -l)
+            lava-test-case passed-commands --result PASS --measurement $test_pass --units pass
+            if ! [ x"0" = x"$test_fail"] ; then
+              lava-test-case failed-commands --result FAIL --measurement $test_fail --units fail
+              echo "$UNIT_LOG" | grep -e 'FAIL'
+            fi
+        else
+            lava-test-case ptest-runner ptest-full --result fail
+        fi
+        lava-test-set stop ptest-full
+    done
+    lava-test-case ptest-runtime --measurement $SECONDS --units seconds --result PASS
+fi
+
+# Wait for LAVA to parse all the tests from stdout
+sleep 15
+
+cat results.log