|  | 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); | 
|  | } | 
|  | } | 
|  | } | 
|  | } |