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] 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