コード例 #1
0
ファイル: RNGesusTests.cs プロジェクト: lukepothier/rngesus
 public void GenerateLong_Minimum_Maximum_Throws_AEx(long minimum, long maximum)
 {
     using (var rngesus = new RNGesus())
     {
         Assert.Throws <ArgumentException>(() => rngesus.GenerateLong(minimum, maximum));
     }
 }
コード例 #2
0
ファイル: RNGesusTests.cs プロジェクト: lukepothier/rngesus
 public void GenerateLong_Minimum_Maximum_DoesNotThrow(long minimum, long maximum)
 {
     using (var rngesus = new RNGesus())
     {
         Assert.DoesNotThrow(() => rngesus.GenerateLong(minimum, maximum));
     }
 }
コード例 #3
0
ファイル: RNGesusTests.cs プロジェクト: lukepothier/rngesus
 public void GenerateLong_DoesNotThrow()
 {
     using (var rngesus = new RNGesus())
     {
         Assert.DoesNotThrow(() => rngesus.GenerateLong());
     }
 }
コード例 #4
0
ファイル: RNGesusTests.cs プロジェクト: lukepothier/rngesus
        public void SharedBufferTest()
        {
            const int iterations     = 999;
            var       integerResults = new int[iterations];
            var       longResults    = new long[iterations];
            var       boolResults    = new bool[iterations];
            var       floatResults   = new float[iterations];
            var       doubleResults  = new double[iterations];
            var       byteResults    = new byte[iterations][];
            var       stringResults  = new string[iterations];

            using (var rngesus = new RNGesus())
            {
                for (var i = 0; i < iterations; i++)
                {
                    integerResults[i] = rngesus.GenerateInt();
                }

                for (var i = 0; i < iterations; i++)
                {
                    longResults[i] = rngesus.GenerateLong();
                }

                for (var i = 0; i < iterations; i++)
                {
                    boolResults[i] = rngesus.GenerateBool();
                }

                for (var i = 0; i < iterations; i++)
                {
                    floatResults[i] = rngesus.GenerateFloat();
                }

                for (var i = 0; i < iterations; i++)
                {
                    doubleResults[i] = rngesus.GenerateDouble();
                }

                for (var i = 0; i < iterations; i++)
                {
                    byteResults[i] = rngesus.GenerateByteArray(99);
                }

                for (var i = 0; i < iterations; i++)
                {
                    stringResults[i] = rngesus.GenerateString(99);
                }
            }

            Assert.That(integerResults.Length == iterations);
            Assert.That(longResults.Length == iterations);
            Assert.That(boolResults.Length == iterations);
            Assert.That(floatResults.Length == iterations);
            Assert.That(doubleResults.Length == iterations);
            Assert.That(byteResults.Length == iterations);
            Assert.That(stringResults.Length == iterations);
        }
コード例 #5
0
ファイル: RNGesusTests.cs プロジェクト: lukepothier/rngesus
        public void GenerateLong_MinimumAndMaximum_ReturnsInRange()
        {
            using (var rngesus = new RNGesus())
            {
                var result = rngesus.GenerateLong(999, 999999);

                Assert.That(() => result >= 999);
                Assert.That(() => result <= 999999);
            }
        }
コード例 #6
0
ファイル: RNGesusTests.cs プロジェクト: lukepothier/rngesus
        public void GenerateLong_MinimumAndMaximum_ReturnsNoDuplicates()
        {
            var results = new long[9];

            for (var i = 0; i < results.Length; i++)
            {
                using (var rngesus = new RNGesus())
                {
                    results[i] = rngesus.GenerateLong(999, 999999);
                }
            }

            Assert.That(results.Distinct().Count() == results.Count());
        }