X10D/X10D.Tests/src/Linq/UInt64Tests.cs

46 lines
2.0 KiB
C#

using Microsoft.VisualStudio.TestTools.UnitTesting;
using X10D.Linq;
namespace X10D.Tests.Linq;
[TestClass]
[CLSCompliant(false)]
public class UInt64Tests
{
[TestMethod]
public void ProductShouldBeCorrect()
{
ulong Cast(int i) => (ulong)i;
Assert.AreEqual(0UL, Enumerable.Range(0, 10).Select(Cast).Product());
Assert.AreEqual(1UL, Enumerable.Range(1, 1).Select(Cast).Product());
Assert.AreEqual(2UL, Enumerable.Range(1, 2).Select(Cast).Product());
Assert.AreEqual(6UL, Enumerable.Range(1, 3).Select(Cast).Product());
Assert.AreEqual(24UL, Enumerable.Range(1, 4).Select(Cast).Product());
Assert.AreEqual(120UL, Enumerable.Range(1, 5).Select(Cast).Product());
Assert.AreEqual(720UL, Enumerable.Range(1, 6).Select(Cast).Product());
Assert.AreEqual(5040UL, Enumerable.Range(1, 7).Select(Cast).Product());
Assert.AreEqual(40320UL, Enumerable.Range(1, 8).Select(Cast).Product());
Assert.AreEqual(362880UL, Enumerable.Range(1, 9).Select(Cast).Product());
Assert.AreEqual(3628800UL, Enumerable.Range(1, 10).Select(Cast).Product());
}
[TestMethod]
public void ProductOfDoublesShouldBeCorrect()
{
ulong Double(int i) => (ulong)i * 2;
Assert.AreEqual(0UL, Enumerable.Range(0, 10).Product(Double));
Assert.AreEqual(2UL, Enumerable.Range(1, 1).Product(Double));
Assert.AreEqual(8UL, Enumerable.Range(1, 2).Product(Double));
Assert.AreEqual(48UL, Enumerable.Range(1, 3).Product(Double));
Assert.AreEqual(384UL, Enumerable.Range(1, 4).Product(Double));
Assert.AreEqual(3840UL, Enumerable.Range(1, 5).Product(Double));
Assert.AreEqual(46080UL, Enumerable.Range(1, 6).Product(Double));
Assert.AreEqual(645120UL, Enumerable.Range(1, 7).Product(Double));
Assert.AreEqual(10321920UL, Enumerable.Range(1, 8).Product(Double));
Assert.AreEqual(185794560UL, Enumerable.Range(1, 9).Product(Double));
Assert.AreEqual(3715891200UL, Enumerable.Range(1, 10).Product(Double));
}
}