diff --git a/histogram.cpp b/histogram.cpp index ec14323..01ec794 100644 --- a/histogram.cpp +++ b/histogram.cpp @@ -5,7 +5,7 @@ using namespace std; -static void find_minmax(const vector& numbers, double& mini, double& maxi) { +void find_minmax(const vector& numbers, double& mini, double& maxi) { mini = numbers[0]; maxi = numbers[0]; diff --git a/histogram_internal.h b/histogram_internal.h new file mode 100644 index 0000000..c7ffcba --- /dev/null +++ b/histogram_internal.h @@ -0,0 +1,5 @@ +#pragma once +#include + +void +find_minmax(const std::vector& numbers, double& mini, double& maxi); diff --git a/unittest.cbp b/unittest.cbp new file mode 100644 index 0000000..7f9621b --- /dev/null +++ b/unittest.cbp @@ -0,0 +1,38 @@ + + + + + + diff --git a/unittest.cpp b/unittest.cpp new file mode 100644 index 0000000..047dda5 --- /dev/null +++ b/unittest.cpp @@ -0,0 +1,60 @@ +#define DOCTEST_CONFIG_NO_MULTITHREADING +#define DOCTEST_CONFIG_IMPLEMENT_WITH_MAIN +#include "doctest.h" +#include "histogram_internal.h" + +TEST_CASE("distinct positive numbers") { + double mini = 0; + double maxi = 0; + find_minmax({1, 2}, mini, maxi); + CHECK(mini == 1); + CHECK(maxi == 2); +} + +TEST_CASE("empty vector") { + double mini = 0; + double maxi = 0; + find_minmax({1, 2}, mini, maxi); + CHECK(mini == 1); + CHECK(maxi == 2); +} + +TEST_CASE("vector with one element") { + double mini = 0; + double maxi = 0; + find_minmax({1}, mini, maxi); + CHECK(mini == 1); + CHECK(maxi == 1); +} + +TEST_CASE("vector with negative elements") { + double mini = 0; + double maxi = 0; + find_minmax({-1, -2}, mini, maxi); + CHECK(mini == -2); + CHECK(maxi == -1); +} + +TEST_CASE("vector with equivalent elements") { + double mini = 0; + double maxi = 0; + find_minmax({2, 2}, mini, maxi); + CHECK(mini == 2); + CHECK(maxi == 2); +} + +TEST_CASE("vector with 0") { + double mini = 0; + double maxi = 0; + find_minmax({0, 0}, mini, maxi); + CHECK(mini == 0); + CHECK(maxi == 0); +} + +TEST_CASE("vector with fractional numbers") { + double mini = 0; + double maxi = 0; + find_minmax({2.4, 2.2}, mini, maxi); + CHECK(mini == 2.2); + CHECK(maxi == 2.4); +}