0021-harness-add-support-for-skipping-tests.patch 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. From 90ec55ab2675bc2b6b4d256f78a3db26adf75900 Mon Sep 17 00:00:00 2001
  2. From: Jeff Moyer <jmoyer@redhat.com>
  3. Date: Mon, 29 Jul 2019 13:16:18 -0400
  4. Subject: [PATCH libaio 21/28] harness: add support for skipping tests
  5. Skipped tests will not cause the test harness to return failure. An
  6. exit status of "3" was chosen for skipped tests. This doesn't
  7. conflict with any of the current tests.
  8. Signed-off-by: Jeff Moyer <jmoyer@redhat.com>
  9. ---
  10. harness/main.c | 20 ++++++++++++++++----
  11. harness/runtests.sh | 14 ++++++++++++--
  12. 2 files changed, 28 insertions(+), 6 deletions(-)
  13. diff --git a/harness/main.c b/harness/main.c
  14. index 9ecd5da..82e9c69 100644
  15. --- a/harness/main.c
  16. +++ b/harness/main.c
  17. @@ -26,15 +26,27 @@ char test_name[] = TEST_NAME;
  18. int main(void)
  19. {
  20. int res;
  21. + const char *test_result;
  22. #if defined(SETUP)
  23. SETUP;
  24. #endif
  25. res = test_main();
  26. - printf("test %s completed %s.\n", test_name,
  27. - res ? "FAILED" : "PASSED"
  28. - );
  29. + switch(res) {
  30. + case 0:
  31. + test_result = "PASSED";
  32. + break;
  33. + case 3:
  34. + test_result = "SKIPPED";
  35. + break;
  36. + default:
  37. + test_result = "FAILED";
  38. + res = 1;
  39. + break;
  40. + }
  41. +
  42. + printf("test %s completed %s.\n", test_name, test_result);
  43. fflush(stdout);
  44. - return res ? 1 : 0;
  45. + return res;
  46. }
  47. diff --git a/harness/runtests.sh b/harness/runtests.sh
  48. index ef269a7..e9ceec8 100755
  49. --- a/harness/runtests.sh
  50. +++ b/harness/runtests.sh
  51. @@ -2,6 +2,7 @@
  52. passes=0
  53. fails=0
  54. +skips=0
  55. echo "Test run starting at" `date`
  56. @@ -11,11 +12,20 @@ while [ $# -ge 1 ] ; do
  57. echo "Starting $this_test"
  58. $this_test 2>&1
  59. res=$?
  60. - if [ $res -eq 0 ] ; then str="" ; passes=$[passes + 1] ; else str=" -- FAILED" ; fails=$[fails + 1] ; fi
  61. + if [ $res -eq 0 ]; then
  62. + str="";
  63. + passes=$((passes + 1));
  64. + elif [ $res -eq 3 ]; then
  65. + str=" -- SKIPPED";
  66. + skips=$((skips + 1));
  67. + else
  68. + str=" -- FAILED"
  69. + fails=$((fails + 1));
  70. + fi
  71. echo "Completed $this_test with $res$str".
  72. done
  73. -echo "Pass: $passes Fail: $fails"
  74. +echo "Pass: $passes Fail: $fails Skip: $skips"
  75. echo "Test run complete at" `date`
  76. exit $fails
  77. --
  78. 2.26.0.292.g33ef6b2f38