1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
23 #include <sal/types.h>
24 #include <cppunit/TestAssert.h>
25 #include <cppunit/TestFixture.h>
26 #include <cppunit/extensions/HelperMacros.h>
27 #include <cppunit/plugin/TestPlugIn.h>
29 #include <rtl/random.h>
36 class createPool
: public CppUnit::TestFixture
39 // insert your test code here.
40 // this is only demonstration code
43 // this is demonstration code
45 rtlRandomPool aPool
= rtl_random_createPool();
47 // LLA: seems to be that another test is not possible for createPool()
48 CPPUNIT_ASSERT_MESSAGE("create failed", aPool
!= nullptr);
50 rtl_random_destroyPool(aPool
);
53 // Change the following lines only, if you add, remove or rename
54 // member functions of the current class,
55 // because these macros are need by auto register mechanism.
57 CPPUNIT_TEST_SUITE(createPool
);
58 CPPUNIT_TEST(createPool_001
);
59 CPPUNIT_TEST_SUITE_END();
60 }; // class createPool
62 class destroyPool
: public CppUnit::TestFixture
65 // insert your test code here.
66 void destroyPool_000()
69 rtl_random_destroyPool(nullptr);
72 void destroyPool_001()
74 rtlRandomPool aPool
= rtl_random_createPool();
76 // LLA: seems to be that another test is not possible for createPool()
77 CPPUNIT_ASSERT_MESSAGE("create failed", aPool
!= nullptr);
79 rtl_random_destroyPool(aPool
);
81 // Change the following lines only, if you add, remove or rename
82 // member functions of the current class,
83 // because these macros are need by auto register mechanism.
85 CPPUNIT_TEST_SUITE(destroyPool
);
86 CPPUNIT_TEST(destroyPool_000
);
87 CPPUNIT_TEST(destroyPool_001
);
88 CPPUNIT_TEST_SUITE_END();
89 }; // class destroyPool
91 class addBytes
: public CppUnit::TestFixture
94 // insert your test code here.
95 // this is only demonstration code
98 rtlRandomPool aPool
= rtl_random_createPool();
100 sal_uInt32 nBufLen
= 4;
101 std::unique_ptr
<sal_uInt8
[]> pBuffer( new sal_uInt8
[ nBufLen
] );
102 memset(pBuffer
.get(), 0, nBufLen
);
104 rtlRandomError aError
= rtl_random_addBytes(nullptr, nullptr, 0);
105 CPPUNIT_ASSERT_EQUAL_MESSAGE("wrong parameter", rtl_Random_E_Argument
, aError
);
107 /* rtlRandomError */ aError
= rtl_random_addBytes(aPool
, nullptr, 0);
108 CPPUNIT_ASSERT_EQUAL_MESSAGE("wrong parameter", rtl_Random_E_Argument
, aError
);
110 /* rtlRandomError */ aError
= rtl_random_addBytes(aPool
, pBuffer
.get(), nBufLen
);
111 CPPUNIT_ASSERT_EQUAL_MESSAGE("wrong parameter", rtl_Random_E_None
, aError
);
113 rtl_random_destroyPool(aPool
);
118 rtlRandomPool aPool
= rtl_random_createPool();
120 sal_uInt32 nBufLen
= 4;
121 std::unique_ptr
<sal_uInt8
[]> pBuffer( new sal_uInt8
[ nBufLen
] );
123 memset(pBuffer
.get(), 0, nBufLen
);
125 rtl_random_addBytes(aPool
, pBuffer
.get(), nBufLen
);
127 printf("%2x %2x %2x %2x\n", pBuffer
[0], pBuffer
[1], pBuffer
[2], pBuffer
[3]);
129 rtl_random_destroyPool(aPool
);
132 // Change the following lines only, if you add, remove or rename
133 // member functions of the current class,
134 // because these macros are need by auto register mechanism.
136 CPPUNIT_TEST_SUITE(addBytes
);
137 CPPUNIT_TEST(addBytes_000
);
138 CPPUNIT_TEST(addBytes_001
);
139 CPPUNIT_TEST_SUITE_END();
146 int m_nDispensation
[256];
155 void clearDispensation()
157 for (int i
= 0;i
< 256;++i
) // clear array
159 m_nDispensation
[i
] = 0;
172 void addValue(sal_uInt8 _nIndex
, sal_Int32 _nValue
)
174 m_nDispensation
[_nIndex
] += _nValue
;
177 void build(sal_Int32 _nCountMax
)
182 m_nAverage
= _nCountMax
/ 256;
184 m_nMinDeviation
= _nCountMax
;
187 for (int i
= 0;i
< 256;++i
) // show dispensation
189 m_nMin
= std::min(m_nMin
, m_nDispensation
[i
]);
190 m_nMax
= std::max(m_nMax
, m_nDispensation
[i
]);
192 m_nMinDeviation
= std::min(m_nMinDeviation
, abs(m_nAverage
- m_nDispensation
[i
]));
193 m_nMaxDeviation
= std::max(m_nMaxDeviation
, abs(m_nAverage
- m_nDispensation
[i
]));
199 // LLA: these are only info values
200 printf("\nSome statistics\n");
201 printf("Min: %d\n", m_nMin
);
202 printf("Max: %d\n", m_nMax
);
203 printf("Average: %d\n", m_nAverage
);
204 printf("Min abs deviation: %d\n", m_nMinDeviation
);
205 printf("Max abs deviation: %d\n", m_nMaxDeviation
);
208 sal_Int32
getAverage() const {return m_nAverage
;}
209 sal_Int32
getMaxDeviation() const {return m_nMaxDeviation
;}
215 class getBytes
: public CppUnit::TestFixture
218 // insert your test code here.
221 rtlRandomPool aPool
= rtl_random_createPool();
223 sal_uInt32 nBufLen
= 4;
224 std::unique_ptr
<sal_uInt8
[]> pBuffer( new sal_uInt8
[ nBufLen
] );
225 memset(pBuffer
.get(), 0, nBufLen
);
227 rtlRandomError aError
= rtl_random_getBytes(nullptr, nullptr, 0);
228 CPPUNIT_ASSERT_EQUAL_MESSAGE("wrong parameter", rtl_Random_E_Argument
, aError
);
230 /* rtlRandomError */ aError
= rtl_random_getBytes(aPool
, nullptr, 0);
231 CPPUNIT_ASSERT_EQUAL_MESSAGE("wrong parameter", rtl_Random_E_Argument
, aError
);
233 /* rtlRandomError */ aError
= rtl_random_getBytes(aPool
, pBuffer
.get(), nBufLen
);
234 CPPUNIT_ASSERT_EQUAL_MESSAGE("wrong parameter", rtl_Random_E_None
, aError
);
236 rtl_random_destroyPool(aPool
);
241 rtlRandomPool aPool
= rtl_random_createPool();
243 sal_uInt32 nBufLen
= 4;
244 std::unique_ptr
<sal_uInt8
[]> pBuffer( new sal_uInt8
[ nBufLen
] );
245 memset(pBuffer
.get(), 0, nBufLen
);
247 rtlRandomError aError
= rtl_random_getBytes(aPool
, pBuffer
.get(), nBufLen
);
248 CPPUNIT_ASSERT_EQUAL_MESSAGE("wrong parameter", rtl_Random_E_None
, aError
);
250 printf("%2x %2x %2x %2x\n", pBuffer
[0], pBuffer
[1], pBuffer
[2], pBuffer
[3]);
252 rtl_random_destroyPool(aPool
);
257 rtlRandomPool aPool
= rtl_random_createPool();
259 sal_uInt32 nBufLen
= 4;
260 std::unique_ptr
<sal_uInt8
[]> pBuffer( new sal_uInt8
[ nBufLen
<< 1 ] );
261 memset(pBuffer
.get(), 0, nBufLen
<< 1);
263 CPPUNIT_ASSERT_EQUAL_MESSAGE("memset failed", sal_uInt8(0), pBuffer
[4]);
264 CPPUNIT_ASSERT_EQUAL_MESSAGE("memset failed", sal_uInt8(0), pBuffer
[5]);
265 CPPUNIT_ASSERT_EQUAL_MESSAGE("memset failed", sal_uInt8(0), pBuffer
[6]);
266 CPPUNIT_ASSERT_EQUAL_MESSAGE("memset failed", sal_uInt8(0), pBuffer
[7]);
268 rtlRandomError aError
= rtl_random_getBytes(aPool
, pBuffer
.get(), nBufLen
);
269 CPPUNIT_ASSERT_EQUAL_MESSAGE("wrong parameter", rtl_Random_E_None
, aError
);
271 printf("%2x %2x %2x %2x %2x %2x %2x %2x\n", pBuffer
[0], pBuffer
[1], pBuffer
[2], pBuffer
[3], pBuffer
[4], pBuffer
[5], pBuffer
[6], pBuffer
[7]);
273 CPPUNIT_ASSERT_EQUAL_MESSAGE("internal memory overwrite", sal_uInt8(0), pBuffer
[4]);
274 CPPUNIT_ASSERT_EQUAL_MESSAGE("internal memory overwrite", sal_uInt8(0), pBuffer
[5]);
275 CPPUNIT_ASSERT_EQUAL_MESSAGE("internal memory overwrite", sal_uInt8(0), pBuffer
[6]);
276 CPPUNIT_ASSERT_EQUAL_MESSAGE("internal memory overwrite", sal_uInt8(0), pBuffer
[7]);
278 rtl_random_destroyPool(aPool
);
283 rtlRandomPool aPool
= rtl_random_createPool();
285 sal_uInt32 nBufLen
= 1;
286 std::unique_ptr
<sal_uInt8
[]> pBuffer( new sal_uInt8
[ nBufLen
] );
287 memset(pBuffer
.get(), 0, nBufLen
);
291 CPPUNIT_ASSERT_EQUAL_MESSAGE("memset failed", static_cast<sal_uInt8
>(0), pBuffer
[0]);
295 int nCountMax
= 1000000;
296 for(nCount
= 0;nCount
< nCountMax
; ++nCount
) // run 100000000 through getBytes(...)
298 /* rtlRandomError aError = */ rtl_random_getBytes(aPool
, pBuffer
.get(), nBufLen
);
299 /* CPPUNIT_ASSERT_MESSAGE("wrong parameter", aError == rtl_Random_E_None); */
301 aStat
.addValue(pBuffer
[0], 1);
304 aStat
.build(nCountMax
);
307 CPPUNIT_ASSERT_MESSAGE("deviation should be less average", aStat
.getMaxDeviation() < aStat
.getAverage());
309 rtl_random_destroyPool(aPool
);
312 void getBytes_003_1()
314 rtlRandomPool aPool
= rtl_random_createPool();
316 sal_uInt32 nBufLen
= 256;
317 std::unique_ptr
<sal_uInt8
[]> pBuffer( new sal_uInt8
[ nBufLen
] );
318 memset(pBuffer
.get(), 0, nBufLen
);
322 CPPUNIT_ASSERT_EQUAL_MESSAGE("memset failed", static_cast<sal_uInt8
>(0), pBuffer
[0]);
326 int nCountMax
= 10000;
327 for(nCount
= 0;nCount
< nCountMax
; ++nCount
) // run 100000000 through getBytes(...)
329 /* rtlRandomError aError = */ rtl_random_getBytes(aPool
, pBuffer
.get(), nBufLen
);
330 // CPPUNIT_ASSERT_MESSAGE("wrong parameter", aError == rtl_Random_E_None);
332 for (sal_uInt32 i
=0;i
<nBufLen
;++i
)
333 aStat
.addValue(pBuffer
[i
], 1);
336 aStat
.build(nCountMax
* nBufLen
);
339 CPPUNIT_ASSERT_MESSAGE("deviation should be less average", aStat
.getMaxDeviation() < aStat
.getAverage());
341 rtl_random_destroyPool(aPool
);
344 // Change the following lines only, if you add, remove or rename
345 // member functions of the current class,
346 // because these macros are need by auto register mechanism.
348 CPPUNIT_TEST_SUITE(getBytes
);
349 CPPUNIT_TEST(getBytes_000
);
350 CPPUNIT_TEST(getBytes_001
);
351 CPPUNIT_TEST(getBytes_002
);
352 CPPUNIT_TEST(getBytes_003
);
353 CPPUNIT_TEST(getBytes_003_1
);
354 CPPUNIT_TEST_SUITE_END();
357 CPPUNIT_TEST_SUITE_REGISTRATION(rtl_random::createPool
);
358 CPPUNIT_TEST_SUITE_REGISTRATION(rtl_random::destroyPool
);
359 CPPUNIT_TEST_SUITE_REGISTRATION(rtl_random::addBytes
);
360 CPPUNIT_TEST_SUITE_REGISTRATION(rtl_random::getBytes
);
361 } // namespace rtl_random
363 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */