blob: a4b9616fd42c3557f932eaccfcaecef597b8d653 [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 CountIfTests
{
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 CountIfNumeric()
{
_worksheet.Cells["A1"].Value = 1d;
_worksheet.Cells["A2"].Value = 2d;
_worksheet.Cells["A3"].Value = 3d;
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, ">1");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(2d, result.Result);
}
[TestMethod]
public void CountIfNonNumeric()
{
_worksheet.Cells["A1"].Value = "Monday";
_worksheet.Cells["A2"].Value = "Tuesday";
_worksheet.Cells["A3"].Value = "Thursday";
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "T*day");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(2d, result.Result);
}
public void CountIfNullExpression()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = 1d;
_worksheet.Cells["A3"].Value = null;
_worksheet.Cells["B2"].Value = null;
var func = new CountIf();
IRangeInfo range1 = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
IRangeInfo range2 = _provider.GetRange(_worksheet.Name, 2, 2, 2, 2);
var args = FunctionsHelper.CreateArgs(range1, range2);
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(0d, result.Result);
}
[TestMethod]
public void CountIfNumericExpression()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = 1d;
_worksheet.Cells["A3"].Value = "Not Empty";
var func = new CountIf();
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 CountIfEqualToEmptyString()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfNotEqualToNull()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "<>");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(2d, result.Result);
}
[TestMethod]
public void CountIfEqualToZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = 0d;
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "0");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfNotEqualToZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = 0d;
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "<>0");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(2d, result.Result);
}
[TestMethod]
public void CountIfGreaterThanZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = 1d;
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, ">0");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfGreaterThanOrEqualToZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = 1d;
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, ">=0");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfLessThanZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = -1d;
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "<0");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfLessThanOrEqualToZero()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = -1d;
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "<=0");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfLessThanCharacter()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "<a");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfLessThanOrEqualToCharacter()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, "<=a");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfGreaterThanCharacter()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, ">a");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
[TestMethod]
public void CountIfGreaterThanOrEqualToCharacter()
{
_worksheet.Cells["A1"].Value = null;
_worksheet.Cells["A2"].Value = string.Empty;
_worksheet.Cells["A3"].Value = "Not Empty";
var func = new CountIf();
IRangeInfo range = _provider.GetRange(_worksheet.Name, 1, 1, 3, 1);
var args = FunctionsHelper.CreateArgs(range, ">=a");
var result = func.Execute(args, _parsingContext);
Assert.AreEqual(1d, result.Result);
}
}
}