Rename DEVELOPMENT -> DEVELOP.md and add some stuff about player stress testing.
[dcpomatic.git] / test / crypto_test.cc
1 /*
2     Copyright (C) 2018 Carl Hetherington <cth@carlh.net>
3
4     This file is part of DCP-o-matic.
5
6     DCP-o-matic is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     DCP-o-matic is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
18
19 */
20
21 #include "lib/crypto.h"
22 #include "lib/exceptions.h"
23 #include "test.h"
24 #include <openssl/rand.h>
25 #include <boost/test/unit_test.hpp>
26
27 using std::string;
28 using std::list;
29 using boost::shared_array;
30
31 BOOST_AUTO_TEST_CASE (crypto_test)
32 {
33         dcp::Data key (dcpomatic::crypto_key_length());
34         dcp::Data iv = dcpomatic::random_iv ();
35
36         RAND_bytes (key.data().get(), dcpomatic::crypto_key_length());
37
38         dcp::Data ciphertext = dcpomatic::encrypt ("Can you see any fish?", key, iv);
39         BOOST_REQUIRE_EQUAL (dcpomatic::decrypt (ciphertext, key, iv), "Can you see any fish?");
40
41         key.data()[5]++;
42         BOOST_REQUIRE_THROW (dcpomatic::decrypt (ciphertext, key, iv), CryptoError);
43 }
44