aboutsummaryrefslogtreecommitdiff
path: root/tests/main.cpp
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2018-07-20 23:34:50 +0200
committerdec05eba <dec05eba@protonmail.com>2020-08-18 23:50:13 +0200
commitab80c5bbc86d45032564b73757e8b09c5ad4f798 (patch)
treee59f69aa55a486750bee744a80df29b6c19ef88a /tests/main.cpp
parent3dd30d705bf9ec6ca8973483100258655cd357f4 (diff)
Initial commit
Diffstat (limited to 'tests/main.cpp')
-rw-r--r--tests/main.cpp47
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/main.cpp b/tests/main.cpp
new file mode 100644
index 0000000..dfcd357
--- /dev/null
+++ b/tests/main.cpp
@@ -0,0 +1,47 @@
+#include <cstdio>
+#include <cstdlib>
+#include <vector>
+#include <sibs/Functional.hpp>
+
+void assertEquals(int expected, int actual)
+{
+ if(actual != expected)
+ {
+ fprintf(stderr, "Assert failed: Expected %d, got %d\n", expected, actual);
+ exit(1);
+ }
+}
+
+int main(int argc, char **argv)
+{
+ std::vector<int> vec1 = { 1, 2, 3, 4, 5 };
+ std::vector<int> vec2 = { 6, 7, 8, 9, 10 };
+ int sum = 0;
+
+ sibs::Function<int> func1(vec1.data(), vec1.data() + vec1.size());
+ for(auto value : func1)
+ {
+ printf("func1 value: %d\n", value);
+ sum += value;
+ }
+ assertEquals(15, sum);
+ sum = 0;
+
+ sibs::Function<int> func2(vec2);
+ for(auto value : func2)
+ {
+ printf("func2 value: %d\n", value);
+ sum += value;
+ }
+ assertEquals(40, sum);
+ sum = 0;
+
+ for(auto value : func1.merge(func2))
+ {
+ printf("func1 and func2 value: %d\n", value);
+ sum += value;
+ }
+ assertEquals(55, sum);
+
+ return 0;
+}