blob: 48594989efd45d6977cc8fdfc0d24de32bb0aed8 [file] [log] [blame]
using EPPlusTest.FormulaParsing.TestHelpers;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using OfficeOpenXml;
using OfficeOpenXml.FormulaParsing;
using OfficeOpenXml.FormulaParsing.Excel.Functions.Math;
using OfficeOpenXml.FormulaParsing.ExcelUtilities;
using static OfficeOpenXml.FormulaParsing.ExcelDataProvider;
namespace EPPlusTest.FormulaParsing.Excel.Functions.Math
{
[TestClass]
public class AverageIfTests
{
private ExcelPackage _package;
private EpplusExcelDataProvider _provider;
private ParsingContext _parsingContext;
private ExcelWorksheet _worksheet;
[TestInitialize]
public void Initialize()
{
_package = new ExcelPackage();
_provider = new EpplusExcelDataProvider(_package);
_parsingContext = ParsingContext.Create();
_parsingContext.Scopes.NewScope(RangeAddress.Empty);
_worksheet = _package.Workbook.Worksheets.Add("testsheet");
}
[TestCleanup]
public void Cleanup()
{
_package.Dispose();
}
[TestMethod]
public void AverageIfNumeric()
{
_worksheet.Cells["A1"].Value = 1d;
_worksheet.Cells["A2"].Value = 2d;
_worksheet.Cells["A3"].Value = 3d;
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, ">1", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(4d, result.Result);
}
[TestMethod]
public void AverageIfNonNumeric()
{
_worksheet.Cells["A1"].Value = "Monday";
_worksheet.Cells["A2"].Value = "Tuesday";
_worksheet.Cells["A3"].Value = "Thursday";
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "T*day", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(4d, result.Result);
}
[TestMethod]
public void AverageIfNumericExpression()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = 1d;
_worksheet.Cells["A3"].Value = "Not Empty";
var func = new AverageIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, 1d);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void AverageIfEqualToEmptyString()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void AverageIfNotEqualToNull()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "<>", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(4d, result.Result);
}
[TestMethod]
public void AverageIfEqualToZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = 0d;
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "0", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(5d, result.Result);
}
[TestMethod]
public void AverageIfNotEqualToZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = 0d;
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "<>0", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(2d, result.Result);
}
[TestMethod]
public void AverageIfGreaterThanZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = 1d;
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, ">0", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(5d, result.Result);
}
[TestMethod]
public void AverageIfGreaterThanOrEqualToZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = 1d;
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, ">=0", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(5d, result.Result);
}
[TestMethod]
public void AverageIfLessThanZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = -1d;
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "<0", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(5d, result.Result);
}
[TestMethod]
public void AverageIfLessThanOrEqualToZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = -1d;
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "<=0", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(5d, result.Result);
}
[TestMethod]
public void AverageIfLessThanCharacter()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "<a", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(3d, result.Result);
}
[TestMethod]
public void AverageIfLessThanOrEqualToCharacter()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, "<=a", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(3d, result.Result);
}
[TestMethod]
public void AverageIfGreaterThanCharacter()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, ">a", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(5d, result.Result);
}
[TestMethod]
public void AverageIfGreaterThanOrEqualToCharacter()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
_worksheet.Cells["B1"].Value = 1d;
_worksheet.Cells["B2"].Value = 3d;
_worksheet.Cells["B3"].Value = 5d;
var func = new AverageIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 1, 2, 3, 2);
var args = FunctionsHelper.CreateArgs(range1, ">=a", range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(5d, result.Result);
}
}
}