From 5d91aeb81073cfcf00434efb924c5192e6f6b403 Mon Sep 17 00:00:00 2001 From: julZuern <41326856+julZuern@users.noreply.github.com> Date: Tue, 24 Jul 2018 15:36:49 +0200 Subject: [PATCH 1/2] added cpp adapter (#189) * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Add files via upload * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh --- .../setup_debian_2_install_docker.sh | 2 +- lib/cpp_catch2_adapter.rb | 21 +++++++++++++++++++ 2 files changed, 22 insertions(+), 1 deletion(-) create mode 100644 lib/cpp_catch2_adapter.rb diff --git a/debian_installer/setup_debian_2_install_docker.sh b/debian_installer/setup_debian_2_install_docker.sh index 759ac542..f4a84f70 100644 --- a/debian_installer/setup_debian_2_install_docker.sh +++ b/debian_installer/setup_debian_2_install_docker.sh @@ -83,4 +83,4 @@ if ! (docker images | grep -q co_execenv_python) echo "Done" else echo "Docker images already pulled" -fi \ No newline at end of file +fi diff --git a/lib/cpp_catch2_adapter.rb b/lib/cpp_catch2_adapter.rb new file mode 100644 index 00000000..1a4d32c5 --- /dev/null +++ b/lib/cpp_catch2_adapter.rb @@ -0,0 +1,21 @@ +class CppUnitAdapter < TestingFrameworkAdapter + COUNT_REGEXP = /in (\d+) test cases/ + FAILURES_REGEXP = /test cases: (\d+) | (\d+) failed/ + BOTH_REGEXP = /test cases: (\d+) | (\d+) passed | (\d+) failed/ + ASSERTION_ERROR_REGEXP = /\n(.+) error:(.+); / + + def self.framework_name + 'CppUnit' + end + + def parse_output(output) + if SUCCESS_REGEXP.match(output[:stdout]) + {count: Regexp.last_match(1).to_i, passed: Regexp.last_match(1).to_i} + else + count = COUNT_REGEXP.match(output[:stdout]).try(:captures).try(:first).try(:to_i) || FAILURES_REGEXP.last_match(0).try(:captures).try(:first).try(:to_i) || SUCCESS_REGEXP.last_match(0).try(:captures).try(:first).try(:to_i) || 0 + failed = FAILURES_REGEXP.match(1).try(:captures).try(:first).try(:to_i) || BOTH_REGEXP.match(2).try(:captures).try(:first).try(:to_i) || 0 + error_matches = ASSERTION_ERROR_REGEXP.match(output[:stdout]).try(:captures) || [] + {count: count, failed: failed, error_messages: error_matches} + end + end +end From a89077292091ca00639f8668cf2bab963fb0a602 Mon Sep 17 00:00:00 2001 From: julZuern <41326856+julZuern@users.noreply.github.com> Date: Fri, 27 Jul 2018 08:50:09 +0200 Subject: [PATCH 2/2] CppCatchAdapter (#195) * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Add files via upload * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update setup_debian_2_install_docker.sh * Update cpp_catch2_adapter.rb --- lib/cpp_catch2_adapter.rb | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/lib/cpp_catch2_adapter.rb b/lib/cpp_catch2_adapter.rb index 1a4d32c5..00a838b4 100644 --- a/lib/cpp_catch2_adapter.rb +++ b/lib/cpp_catch2_adapter.rb @@ -1,19 +1,19 @@ -class CppUnitAdapter < TestingFrameworkAdapter - COUNT_REGEXP = /in (\d+) test cases/ - FAILURES_REGEXP = /test cases: (\d+) | (\d+) failed/ - BOTH_REGEXP = /test cases: (\d+) | (\d+) passed | (\d+) failed/ - ASSERTION_ERROR_REGEXP = /\n(.+) error:(.+); / +class CppCatch2Adapter < TestingFrameworkAdapter + ALL_PASSED_REGEXP = /in\s+(\d+)\s+test case/ + COUNT_REGEXP = /test cases:\s+(\d+)/ + FAILURES_REGEXP = / \|\s+(\d+)\s+failed/ + ASSERTION_ERROR_REGEXP = /\n(.+)error:(.+);/ def self.framework_name - 'CppUnit' + 'CppCatch2' end def parse_output(output) - if SUCCESS_REGEXP.match(output[:stdout]) + if ALL_PASSED_REGEXP.match(output[:stdout]) {count: Regexp.last_match(1).to_i, passed: Regexp.last_match(1).to_i} else - count = COUNT_REGEXP.match(output[:stdout]).try(:captures).try(:first).try(:to_i) || FAILURES_REGEXP.last_match(0).try(:captures).try(:first).try(:to_i) || SUCCESS_REGEXP.last_match(0).try(:captures).try(:first).try(:to_i) || 0 - failed = FAILURES_REGEXP.match(1).try(:captures).try(:first).try(:to_i) || BOTH_REGEXP.match(2).try(:captures).try(:first).try(:to_i) || 0 + count = COUNT_REGEXP.match(output[:stdout]).try(:captures).try(:first).try(:to_i) || 0 + failed = FAILURES_REGEXP.match(output[:stdout]).try(:captures).try(:first).try(:to_i) || 0 error_matches = ASSERTION_ERROR_REGEXP.match(output[:stdout]).try(:captures) || [] {count: count, failed: failed, error_messages: error_matches} end