blob: d46a771263f8a330518312064a8277c16c06d9ac [file] [log] [blame]
using System;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using OfficeOpenXml;
namespace EPPlusTest.FormulaParsing.IntegrationTests.BuiltInFunctions
{
[TestClass]
public class DatabaseTests
{
[TestMethod]
public void DgetShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["C1"].Value = "crit3";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["C2"].Value = "output";
sheet.Cells["A3"].Value = "test";
sheet.Cells["B3"].Value = 3;
sheet.Cells["C3"].Value = "aaa";
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
sheet.Cells["E1"].Value = "crit2";
sheet.Cells["E2"].Value = 2;
// function
sheet.Cells["F1"].Formula = "DGET(A1:C3,\"Crit3\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual("output", sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DcountShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["C1"].Value = "crit3";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["C2"].Value = "output";
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = "2";
sheet.Cells["C3"].Value = "aaa";
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
sheet.Cells["E1"].Value = "crit2";
sheet.Cells["E2"].Value = 2;
// function
sheet.Cells["F1"].Formula = "DCOUNT(A1:C3,\"Crit2\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(1, sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DcountaShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["C1"].Value = "crit3";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["C2"].Value = "output";
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = "2";
sheet.Cells["C3"].Value = "aaa";
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
sheet.Cells["E1"].Value = "crit2";
sheet.Cells["E2"].Value = 2;
// function
sheet.Cells["F1"].Formula = "DCOUNTA(A1:C3,\"Crit2\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(2, sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DMaxShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = 1;
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
// function
sheet.Cells["F1"].Formula = "DMAX(A1:B3,\"Crit2\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(2d, sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DMinShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = 1;
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
// function
sheet.Cells["F1"].Formula = "DMIN(A1:B3,\"Crit2\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(1d, sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DSumShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = 1;
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
// function
sheet.Cells["F1"].Formula = "DSUM(A1:B3,\"Crit2\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(3d, sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DAverageShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = 1;
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
// function
sheet.Cells["F1"].Formula = "DAVERAGE(A1:B3,\"Crit2\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(1.5d, sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DVarShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = 1;
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
// function
sheet.Cells["F1"].Formula = "DVAR(A1:B3,\"Crit2\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(0.5d, sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DVarpShouldReturnCorrectResult()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = 1;
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
// function
sheet.Cells["F1"].Formula = "DVARP(A1:B3,\"Crit2\",D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(0.25d, sheet.Cells["F1"].Value);
}
}
[TestMethod]
public void DVarpShouldReturnByFieldIndex()
{
using (var package = new ExcelPackage())
{
var sheet = package.Workbook.Worksheets.Add("test");
// database
sheet.Cells["A1"].Value = "crit1";
sheet.Cells["B1"].Value = "crit2";
sheet.Cells["A2"].Value = "test";
sheet.Cells["B2"].Value = 2;
sheet.Cells["A3"].Value = "tesst";
sheet.Cells["B3"].Value = 1;
// criteria
sheet.Cells["D1"].Value = "crit1";
sheet.Cells["D2"].Value = "t*t";
// function
sheet.Cells["F1"].Formula = "DVARP(A1:B3,2,D1:E2)";
sheet.Workbook.Calculate();
Assert.AreEqual(0.25d, sheet.Cells["F1"].Value);
}
}
}
}