blob: 205bd2c9fa4e8e91f5618fea4b3eccbeb75ebfaf [file] [log] [blame]
using System;
using System.Text;
using System.Collections.Generic;
using System.Linq;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using OfficeOpenXml.FormulaParsing;
using OfficeOpenXml.FormulaParsing.Excel.Functions.Text;
using EPPlusTest.FormulaParsing.TestHelpers;
using OfficeOpenXml.FormulaParsing.ExpressionGraph;
namespace EPPlusTest.Excel.Functions.Text
{
[TestClass]
public class TextFunctionsTests
{
private ParsingContext _parsingContext = ParsingContext.Create();
[TestMethod]
public void CStrShouldConvertNumberToString()
{
var func = new CStr();
var result = func.Execute(FunctionsHelper.CreateArgs(1), _parsingContext);
Assert.AreEqual(DataType.String, result.DataType);
Assert.AreEqual("1", result.Result);
}
[TestMethod]
public void LenShouldReturnStringsLength()
{
var func = new Len();
var result = func.Execute(FunctionsHelper.CreateArgs("abc"), _parsingContext);
Assert.AreEqual(3d, result.Result);
}
[TestMethod]
public void LowerShouldReturnLowerCaseString()
{
var func = new Lower();
var result = func.Execute(FunctionsHelper.CreateArgs("ABC"), _parsingContext);
Assert.AreEqual("abc", result.Result);
}
[TestMethod]
public void UpperShouldReturnUpperCaseString()
{
var func = new Upper();
var result = func.Execute(FunctionsHelper.CreateArgs("abc"), _parsingContext);
Assert.AreEqual("ABC", result.Result);
}
[TestMethod]
public void LeftShouldReturnSubstringFromLeft()
{
var func = new Left();
var result = func.Execute(FunctionsHelper.CreateArgs("abcd", 2), _parsingContext);
Assert.AreEqual("ab", result.Result);
}
[TestMethod]
public void RightShouldReturnSubstringFromRight()
{
var func = new Right();
var result = func.Execute(FunctionsHelper.CreateArgs("abcd", 2), _parsingContext);
Assert.AreEqual("cd", result.Result);
}
[TestMethod]
public void MidShouldReturnSubstringAccordingToParams()
{
var func = new Mid();
var result = func.Execute(FunctionsHelper.CreateArgs("abcd", 1, 2), _parsingContext);
Assert.AreEqual("ab", result.Result);
}
[TestMethod]
public void ReplaceShouldReturnAReplacedStringAccordingToParamsWhenStartIxIs1()
{
var func = new Replace();
var result = func.Execute(FunctionsHelper.CreateArgs("testar", 1, 2, "hej"), _parsingContext);
Assert.AreEqual("hejstar", result.Result);
}
[TestMethod]
public void ReplaceShouldReturnAReplacedStringAccordingToParamsWhenStartIxIs3()
{
var func = new Replace();
var result = func.Execute(FunctionsHelper.CreateArgs("testar", 3, 3, "hej"), _parsingContext);
Assert.AreEqual("tehejr", result.Result);
}
[TestMethod]
public void SubstituteShouldReturnAReplacedStringAccordingToParamsWhen()
{
var func = new Substitute();
var result = func.Execute(FunctionsHelper.CreateArgs("testar testar", "es", "xx"), _parsingContext);
Assert.AreEqual("txxtar txxtar", result.Result);
}
[TestMethod]
public void ConcatenateShouldConcatenateThreeStrings()
{
var func = new Concatenate();
var result = func.Execute(FunctionsHelper.CreateArgs("One", "Two", "Three"), _parsingContext);
Assert.AreEqual("OneTwoThree", result.Result);
}
[TestMethod]
public void ConcatenateShouldConcatenateStringWithInt()
{
var func = new Concatenate();
var result = func.Execute(FunctionsHelper.CreateArgs(1, "Two"), _parsingContext);
Assert.AreEqual("1Two", result.Result);
}
[TestMethod]
public void ExactShouldReturnTrueWhenTwoEqualStrings()
{
var func = new Exact();
var result = func.Execute(FunctionsHelper.CreateArgs("abc", "abc"), _parsingContext);
Assert.IsTrue((bool)result.Result);
}
[TestMethod]
public void ExactShouldReturnTrueWhenEqualStringAndDouble()
{
var func = new Exact();
var result = func.Execute(FunctionsHelper.CreateArgs("1", 1d), _parsingContext);
Assert.IsTrue((bool)result.Result);
}
[TestMethod]
public void ExactShouldReturnFalseWhenStringAndNull()
{
var func = new Exact();
var result = func.Execute(FunctionsHelper.CreateArgs("1", null), _parsingContext);
Assert.IsFalse((bool)result.Result);
}
[TestMethod]
public void ExactShouldReturnFalseWhenTwoEqualStringsWithDifferentCase()
{
var func = new Exact();
var result = func.Execute(FunctionsHelper.CreateArgs("abc", "Abc"), _parsingContext);
Assert.IsFalse((bool)result.Result);
}
[TestMethod]
public void FindShouldReturnIndexOfFoundPhrase()
{
var func = new Find();
var result = func.Execute(FunctionsHelper.CreateArgs("hopp", "hej hopp"), _parsingContext);
Assert.AreEqual(5, result.Result);
}
[TestMethod]
public void FindShouldReturnIndexOfFoundPhraseBasedOnStartIndex()
{
var func = new Find();
var result = func.Execute(FunctionsHelper.CreateArgs("hopp", "hopp hopp", 2), _parsingContext);
Assert.AreEqual(6, result.Result);
}
[TestMethod]
public void ProperShouldSetFirstLetterToUpperCase()
{
var func = new Proper();
var result = func.Execute(FunctionsHelper.CreateArgs("this IS A tEst.wi3th SOME w0rds östEr"), _parsingContext);
Assert.AreEqual("This Is A Test.Wi3Th Some W0Rds Öster", result.Result);
}
[TestMethod]
public void HyperLinkShouldReturnArgIfOneArgIsSupplied()
{
var func = new Hyperlink();
var result = func.Execute(FunctionsHelper.CreateArgs("http://epplus.codeplex.com"), _parsingContext);
Assert.AreEqual("http://epplus.codeplex.com", result.Result);
}
[TestMethod]
public void HyperLinkShouldReturnLastArgIfTwoArgsAreSupplied()
{
var func = new Hyperlink();
var result = func.Execute(FunctionsHelper.CreateArgs("http://epplus.codeplex.com", "EPPlus"), _parsingContext);
Assert.AreEqual("EPPlus", result.Result);
}
}
}