// random_test.cpp /* Copyright 2012 10gen Inc. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * * As a special exception, the copyright holders give permission to link the * code of portions of this program with the OpenSSL library under certain * conditions as described in each individual source file and distribute * linked combinations including the program with the OpenSSL library. You * must comply with the GNU Affero General Public License in all respects * for all of the code used other than as permitted herein. If you modify * file(s) with this exception, you may extend this exception to your * version of the file(s), but you are not obligated to do so. If you do not * wish to do so, delete this exception statement from your version. If you * delete this exception statement from all source files in the program, * then also delete it in the license file. */ #include #include "mongo/platform/random.h" #include "mongo/unittest/unittest.h" namespace mongo { TEST( RandomTest, Seed1 ) { PseudoRandom a( 12 ); PseudoRandom b( 12 ); for ( int i = 0; i < 100; i++ ) { ASSERT_EQUALS( a.nextInt32(), b.nextInt32() ); } } TEST( RandomTest, Seed2 ) { PseudoRandom a( 12 ); PseudoRandom b( 12 ); for ( int i = 0; i < 100; i++ ) { ASSERT_EQUALS( a.nextInt64(), b.nextInt64() ); } } TEST( RandomTest, Seed3 ) { PseudoRandom a( 11 ); PseudoRandom b( 12 ); ASSERT_NOT_EQUALS( a.nextInt32(), b.nextInt32() ); } TEST( RandomTest, Seed4 ) { PseudoRandom a( 11 ); std::set s; for ( int i = 0; i < 100; i++ ) { s.insert( a.nextInt32() ); } ASSERT_EQUALS( 100U, s.size() ); } TEST( RandomTest, Seed5 ) { const int64_t seed = 0xCC453456FA345FABLL; PseudoRandom a(seed); std::set s; for ( int i = 0; i < 100; i++ ) { s.insert( a.nextInt32() ); } ASSERT_EQUALS( 100U, s.size() ); } TEST( RandomTest, R1 ) { PseudoRandom a( 11 ); std::set s; for ( int i = 0; i < 100; i++ ) { s.insert( a.nextInt32() ); } ASSERT_EQUALS( 100U, s.size() ); } TEST( RandomTest, R2 ) { PseudoRandom a( 11 ); std::set s; for ( int i = 0; i < 100; i++ ) { s.insert( a.nextInt64() ); } ASSERT_EQUALS( 100U, s.size() ); } TEST( RandomTest, Secure1 ) { SecureRandom* a = SecureRandom::create(); SecureRandom* b = SecureRandom::create(); for ( int i = 0; i< 100; i++ ) { ASSERT_NOT_EQUALS( a->nextInt64(), b->nextInt64() ); } delete a; delete b; } }