| using System; |
| using System.IO; |
| using EPPlusTest.FormulaParsing.TestHelpers; |
| using Microsoft.VisualStudio.TestTools.UnitTesting; |
| using OfficeOpenXml; |
| using OfficeOpenXml.FormulaParsing; |
| using OfficeOpenXml.FormulaParsing.Excel.Functions.RefAndLookup; |
| using OfficeOpenXml.FormulaParsing.Exceptions; |
| |
| namespace EPPlusTest.FormulaParsing.Excel.Functions.RefAndLookup |
| { |
| [TestClass] |
| public class ChooseTests |
| { |
| private ParsingContext _parsingContext; |
| private ExcelPackage _package; |
| private ExcelWorksheet _worksheet; |
| |
| [TestInitialize] |
| public void Initialize() |
| { |
| _parsingContext = ParsingContext.Create(); |
| _package = new ExcelPackage(new MemoryStream()); |
| _worksheet = _package.Workbook.Worksheets.Add("test"); |
| } |
| |
| [TestCleanup] |
| public void Cleanup() |
| { |
| _package.Dispose(); |
| } |
| |
| [TestMethod] |
| public void ChooseSingleValue() |
| { |
| fillChooseOptions(); |
| _worksheet.Cells["B1"].Formula = "CHOOSE(4, A1, A2, A3, A4, A5)"; |
| _worksheet.Calculate(); |
| |
| Assert.AreEqual("5", _worksheet.Cells["B1"].Value); |
| } |
| |
| [TestMethod] |
| public void ChooseSingleFormula() |
| { |
| fillChooseOptions(); |
| _worksheet.Cells["B1"].Formula = "CHOOSE(6, A1, A2, A3, A4, A5, A6)"; |
| _worksheet.Calculate(); |
| |
| Assert.AreEqual("12", _worksheet.Cells["B1"].Value); |
| } |
| |
| [TestMethod] |
| public void ChooseMultipleValues() |
| { |
| fillChooseOptions(); |
| _worksheet.Cells["B1"].Formula = "SUM(CHOOSE({1,3,4}, A1, A2, A3, A4, A5))"; |
| _worksheet.Calculate(); |
| |
| Assert.AreEqual(9D, _worksheet.Cells["B1"].Value); |
| } |
| |
| [TestMethod] |
| public void ChooseValueAndFormula() |
| { |
| fillChooseOptions(); |
| _worksheet.Cells["B1"].Formula = "SUM(CHOOSE({2,6}, A1, A2, A3, A4, A5, A6))"; |
| _worksheet.Calculate(); |
| |
| Assert.AreEqual(14D, _worksheet.Cells["B1"].Value); |
| } |
| |
| private void fillChooseOptions() |
| { |
| _worksheet.Cells["A1"].Value = 1d; |
| _worksheet.Cells["A2"].Value = 2d; |
| _worksheet.Cells["A3"].Value = 3d; |
| _worksheet.Cells["A4"].Value = 5d; |
| _worksheet.Cells["A5"].Value = 7d; |
| _worksheet.Cells["A6"].Formula = "A4 + A5"; |
| } |
| } |
| } |