blob: 130e242462a0bbeb30387dd4dbab1f62a7613cc4 [file] [log] [blame]
using System;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using OfficeOpenXml;
namespace EPPlusTest
{
[TestClass]
public class ExcelCellBaseTest
{
#region UpdateFormulaReferences Tests
[TestMethod]
public void UpdateFormulaReferencesOnTheSameSheet()
{
var result = ExcelCellBase.UpdateFormulaReferences("C3", 3, 3, 2, 2, "sheet", "sheet");
Assert.AreEqual("F6", result);
}
[TestMethod]
public void UpdateFormulaReferencesIgnoresIncorrectSheet()
{
var result = ExcelCellBase.UpdateFormulaReferences("C3", 3, 3, 2, 2, "sheet", "other sheet");
Assert.AreEqual("C3", result);
}
[TestMethod]
public void UpdateFormulaReferencesFullyQualifiedReferenceOnTheSameSheet()
{
var result = ExcelCellBase.UpdateFormulaReferences("'sheet name here'!C3", 3, 3, 2, 2, "sheet name here", "sheet name here");
Assert.AreEqual("'sheet name here'!F6", result);
}
[TestMethod]
public void UpdateFormulaReferencesFullyQualifiedCrossSheetReferenceArray()
{
var result = ExcelCellBase.UpdateFormulaReferences("SUM('sheet name here'!B2:D4)", 3, 3, 3, 3, "cross sheet", "sheet name here");
Assert.AreEqual("SUM('sheet name here'!B2:G7)", result);
}
[TestMethod]
public void UpdateFormulaReferencesFullyQualifiedReferenceOnADifferentSheet()
{
var result = ExcelCellBase.UpdateFormulaReferences("'updated sheet'!C3", 3, 3, 2, 2, "boring sheet", "updated sheet");
Assert.AreEqual("'updated sheet'!F6", result);
}
[TestMethod]
public void UpdateFormulaReferencesReferencingADifferentSheetIsNotUpdated()
{
var result = ExcelCellBase.UpdateFormulaReferences("'boring sheet'!C3", 3, 3, 2, 2, "boring sheet", "updated sheet");
Assert.AreEqual("'boring sheet'!C3", result);
}
#endregion
#region UpdateCrossSheetReferenceNames Tests
[TestMethod]
public void UpdateFormulaSheetReferences()
{
var result = ExcelCellBase.UpdateFormulaSheetReferences("5+'OldSheet'!$G3+'Some Other Sheet'!C3+SUM(1,2,3)", "OldSheet", "NewSheet");
Assert.AreEqual("5+'NewSheet'!$G3+'Some Other Sheet'!C3+SUM(1,2,3)", result);
}
[TestMethod]
[ExpectedException(typeof(ArgumentNullException))]
public void UpdateFormulaSheetReferencesNullOldSheetThrowsException()
{
ExcelCellBase.UpdateFormulaSheetReferences("formula", null, "sheet2");
}
[TestMethod]
[ExpectedException(typeof(ArgumentNullException))]
public void UpdateFormulaSheetReferencesEmptyOldSheetThrowsException()
{
ExcelCellBase.UpdateFormulaSheetReferences("formula", string.Empty, "sheet2");
}
[TestMethod]
[ExpectedException(typeof(ArgumentNullException))]
public void UpdateFormulaSheetReferencesNullNewSheetThrowsException()
{
ExcelCellBase.UpdateFormulaSheetReferences("formula", "sheet1", null);
}
[TestMethod]
[ExpectedException(typeof(ArgumentNullException))]
public void UpdateFormulaSheetReferencesEmptyNewSheetThrowsException()
{
ExcelCellBase.UpdateFormulaSheetReferences("formula", "sheet1", string.Empty);
}
#endregion
}
}