aboutsummaryrefslogtreecommitdiff
path: root/tests/test_olm_decrypt.cpp
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2020-11-05 01:45:06 +0100
committerdec05eba <dec05eba@protonmail.com>2020-11-05 01:45:06 +0100
commit2a8202e74846d191a321cca1202175af9db6107d (patch)
treea6f455caf07da1186851f343a237a4c4e4484f46 /tests/test_olm_decrypt.cpp
parent8efa0ec17d8c262f9c3fd7603e8074f74a053708 (diff)
Convert to sibs projectHEADmaster
Diffstat (limited to 'tests/test_olm_decrypt.cpp')
-rw-r--r--tests/test_olm_decrypt.cpp92
1 files changed, 0 insertions, 92 deletions
diff --git a/tests/test_olm_decrypt.cpp b/tests/test_olm_decrypt.cpp
deleted file mode 100644
index 0c8feb8..0000000
--- a/tests/test_olm_decrypt.cpp
+++ /dev/null
@@ -1,92 +0,0 @@
-#include "olm/olm.h"
-#include "unittest.hh"
-
-#include <vector>
-
-struct test_case {
- const char *msghex;
- const char *expected_error;
-};
-
-const test_case test_cases[] = {
- { "41776f", "BAD_MESSAGE_FORMAT" },
- { "7fff6f0101346d671201", "BAD_MESSAGE_FORMAT" },
- { "ee776f41496f674177804177778041776f6716670a677d6f670a67c2677d", "BAD_MESSAGE_FORMAT" },
- { "e9e9c9c1e9e9c9e9c9c1e9e9c9c1", "BAD_MESSAGE_FORMAT" },
-};
-
-
-const char * session_data =
- "E0p44KO2y2pzp9FIjv0rud2wIvWDi2dx367kP4Fz/9JCMrH+aG369HGymkFtk0+PINTLB9lQRt"
- "ohea5d7G/UXQx3r5y4IWuyh1xaRnojEZQ9a5HRZSNtvmZ9NY1f1gutYa4UtcZcbvczN8b/5Bqg"
- "e16cPUH1v62JKLlhoAJwRkH1wU6fbyOudERg5gdXA971btR+Q2V8GKbVbO5fGKL5phmEPVXyMs"
- "rfjLdzQrgjOTxN8Pf6iuP+WFPvfnR9lDmNCFxJUVAdLIMnLuAdxf1TGcS+zzCzEE8btIZ99mHF"
- "dGvPXeH8qLeNZA";
-
-void decode_hex(
- const char * input,
- std::uint8_t * output, std::size_t output_length
-) {
- std::uint8_t * end = output + output_length;
- while (output != end) {
- char high = *(input++);
- char low = *(input++);
- if (high >= 'a') high -= 'a' - ('9' + 1);
- if (low >= 'a') low -= 'a' - ('9' + 1);
- uint8_t value = ((high - '0') << 4) | (low - '0');
- *(output++) = value;
- }
-}
-
-void decrypt_case(int message_type, const test_case * test_case) {
- std::vector<std::uint8_t> session_memory(olm_session_size());
- ::OlmSession * session = ::olm_session(session_memory.data());
-
- std::vector<std::uint8_t> pickled(strlen(session_data));
- ::memcpy(pickled.data(), session_data, pickled.size());
- assert_not_equals(
- ::olm_error(),
- ::olm_unpickle_session(session, "", 0, pickled.data(), pickled.size())
- );
-
- std::size_t message_length = strlen(test_case->msghex) / 2;
- std::uint8_t * message = (std::uint8_t *) ::malloc(message_length);
- decode_hex(test_case->msghex, message, message_length);
-
- size_t max_length = olm_decrypt_max_plaintext_length(
- session, message_type, message, message_length
- );
-
- if (test_case->expected_error) {
- assert_equals(::olm_error(), max_length);
- assert_equals(
- std::string(test_case->expected_error),
- std::string(::olm_session_last_error(session))
- );
- free(message);
- return;
- }
-
- assert_not_equals(::olm_error(), max_length);
-
- std::vector<uint8_t> plaintext(max_length);
- decode_hex(test_case->msghex, message, message_length);
- olm_decrypt(
- session, message_type,
- message, message_length,
- plaintext.data(), max_length
- );
- free(message);
-}
-
-
-int main() {
-{
-TestCase my_test("Olm decrypt test");
-
-for (unsigned int i = 0; i < sizeof(test_cases)/ sizeof(test_cases[0]); ++i) {
- decrypt_case(0, &test_cases[i]);
-}
-
-}
-}