using ClosedXML.Attributes;
using ClosedXML.Excel;
using NUnit.Framework;
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
namespace ClosedXML_Tests.Excel
{
/// <summary>
/// Summary description for UnitTest1
/// </summary>
[TestFixture]
public class TablesTests
{
public class TestObjectWithoutAttributes
{
public String Column1 { get; set; }
public String Column2 { get; set; }
}
public class TestObjectWithAttributes
{
public int UnOrderedColumn { get; set; }
[XLColumn(Header = "SecondColumn", Order = 1)]
public String Column1 { get; set; }
[XLColumn(Header = "FirstColumn", Order = 0)]
public String Column2 { get; set; }
[XLColumn(Header = "SomeFieldNotProperty", Order = 2)]
public int MyField;
}
[Test]
public void CanSaveTableCreatedFromEmptyDataTable()
{
var dt = new DataTable("sheet1");
dt.Columns.Add("col1", typeof(string));
dt.Columns.Add("col2", typeof(double));
using (var wb = new XLWorkbook())
{
wb.AddWorksheet(dt);
using (var ms = new MemoryStream())
wb.SaveAs(ms, true);
}
}
[Test]
public void PreventAddingOfEmptyDataTable()
{
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
var dt = new DataTable();
var table = ws.FirstCell().InsertTable(dt);
Assert.AreEqual(null, table);
}
}
[Test]
public void CanSaveTableCreatedFromSingleRow()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().SetValue("Title");
ws.Range("A1").CreateTable();
using (var ms = new MemoryStream())
wb.SaveAs(ms, true);
}
}
[Test]
public void CreatingATableFromHeadersPushCellsBelow()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().SetValue("Title")
.CellBelow().SetValue("X");
ws.Range("A1").CreateTable();
Assert.AreEqual(String.Empty, ws.Cell("A2").GetString());
Assert.AreEqual("X", ws.Cell("A3").GetString());
}
}
[Test]
public void Inserting_Column_Sets_Header()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().SetValue("Categories")
.CellBelow().SetValue("A")
.CellBelow().SetValue("B")
.CellBelow().SetValue("C");
IXLTable table = ws.RangeUsed().CreateTable();
table.InsertColumnsAfter(1);
Assert.AreEqual("Column2", table.HeadersRow().LastCell().GetString());
}
}
[Test]
public void SavingLoadingTableWithNewLineInHeader()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
string columnName = "Line1" + Environment.NewLine + "Line2";
ws.FirstCell().SetValue(columnName)
.CellBelow().SetValue("A");
ws.RangeUsed().CreateTable();
using (var ms = new MemoryStream())
{
wb.SaveAs(ms, true);
var wb2 = new XLWorkbook(ms);
IXLWorksheet ws2 = wb2.Worksheet(1);
IXLTable table2 = ws2.Table(0);
string fieldName = table2.Field(0).Name;
Assert.AreEqual("Line1\nLine2", fieldName);
}
}
}
[Test]
public void SavingLoadingTableWithNewLineInHeader2()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.Worksheets.Add("Test");
var dt = new DataTable();
string columnName = "Line1" + Environment.NewLine + "Line2";
dt.Columns.Add(columnName);
DataRow dr = dt.NewRow();
dr[columnName] = "some text";
dt.Rows.Add(dr);
ws.Cell(1, 1).InsertTable(dt);
IXLTable table1 = ws.Table(0);
string fieldName1 = table1.Field(0).Name;
Assert.AreEqual(columnName, fieldName1);
using (var ms = new MemoryStream())
{
wb.SaveAs(ms, true);
var wb2 = new XLWorkbook(ms);
IXLWorksheet ws2 = wb2.Worksheet(1);
IXLTable table2 = ws2.Table(0);
string fieldName2 = table2.Field(0).Name;
Assert.AreEqual("Line1\nLine2", fieldName2);
}
}
}
[Test]
public void TableCreatedFromEmptyDataTable()
{
var dt = new DataTable("sheet1");
dt.Columns.Add("col1", typeof(string));
dt.Columns.Add("col2", typeof(double));
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().InsertTable(dt);
Assert.AreEqual(2, ws.Tables.First().ColumnCount());
}
}
[Test]
public void TableCreatedFromEmptyListOfInt()
{
var l = new List<Int32>();
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().InsertTable(l);
Assert.AreEqual(1, ws.Tables.First().ColumnCount());
}
}
[Test]
public void TableCreatedFromEmptyListOfObject()
{
var l = new List<TestObjectWithoutAttributes>();
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().InsertTable(l);
Assert.AreEqual(2, ws.Tables.First().ColumnCount());
}
}
[Test]
public void TableCreatedFromListOfObjectWithPropertyAttributes()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().InsertTable(l);
Assert.AreEqual(4, ws.Tables.First().ColumnCount());
Assert.AreEqual("FirstColumn", ws.FirstCell().Value);
Assert.AreEqual("SecondColumn", ws.FirstCell().CellRight().Value);
Assert.AreEqual("SomeFieldNotProperty", ws.FirstCell().CellRight().CellRight().Value);
Assert.AreEqual("UnOrderedColumn", ws.FirstCell().CellRight().CellRight().CellRight().Value);
}
}
[Test]
public void TableInsertAboveFromData()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().SetValue("Value");
IXLTable table = ws.Range("A1:A2").CreateTable();
table.SetShowTotalsRow()
.Field(0).TotalsRowFunction = XLTotalsRowFunction.Sum;
IXLTableRow row = table.DataRange.FirstRow();
row.Field("Value").Value = 3;
row = table.DataRange.InsertRowsAbove(1).First();
row.Field("Value").Value = 2;
row = table.DataRange.InsertRowsAbove(1).First();
row.Field("Value").Value = 1;
Assert.AreEqual(1, ws.Cell(2, 1).GetDouble());
Assert.AreEqual(2, ws.Cell(3, 1).GetDouble());
Assert.AreEqual(3, ws.Cell(4, 1).GetDouble());
}
}
[Test]
public void TableInsertAboveFromRows()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().SetValue("Value");
IXLTable table = ws.Range("A1:A2").CreateTable();
table.SetShowTotalsRow()
.Field(0).TotalsRowFunction = XLTotalsRowFunction.Sum;
IXLTableRow row = table.DataRange.FirstRow();
row.Field("Value").Value = 3;
row = row.InsertRowsAbove(1).First();
row.Field("Value").Value = 2;
row = row.InsertRowsAbove(1).First();
row.Field("Value").Value = 1;
Assert.AreEqual(1, ws.Cell(2, 1).GetDouble());
Assert.AreEqual(2, ws.Cell(3, 1).GetDouble());
Assert.AreEqual(3, ws.Cell(4, 1).GetDouble());
}
}
[Test]
public void TableInsertBelowFromData()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().SetValue("Value");
IXLTable table = ws.Range("A1:A2").CreateTable();
table.SetShowTotalsRow()
.Field(0).TotalsRowFunction = XLTotalsRowFunction.Sum;
IXLTableRow row = table.DataRange.FirstRow();
row.Field("Value").Value = 1;
row = table.DataRange.InsertRowsBelow(1).First();
row.Field("Value").Value = 2;
row = table.DataRange.InsertRowsBelow(1).First();
row.Field("Value").Value = 3;
Assert.AreEqual(1, ws.Cell(2, 1).GetDouble());
Assert.AreEqual(2, ws.Cell(3, 1).GetDouble());
Assert.AreEqual(3, ws.Cell(4, 1).GetDouble());
}
}
[Test]
public void TableInsertBelowFromRows()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().SetValue("Value");
IXLTable table = ws.Range("A1:A2").CreateTable();
table.SetShowTotalsRow()
.Field(0).TotalsRowFunction = XLTotalsRowFunction.Sum;
IXLTableRow row = table.DataRange.FirstRow();
row.Field("Value").Value = 1;
row = row.InsertRowsBelow(1).First();
row.Field("Value").Value = 2;
row = row.InsertRowsBelow(1).First();
row.Field("Value").Value = 3;
Assert.AreEqual(1, ws.Cell(2, 1).GetDouble());
Assert.AreEqual(2, ws.Cell(3, 1).GetDouble());
Assert.AreEqual(3, ws.Cell(4, 1).GetDouble());
}
}
[Test]
public void TableShowHeader()
{
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().SetValue("Categories")
.CellBelow().SetValue("A")
.CellBelow().SetValue("B")
.CellBelow().SetValue("C");
IXLTable table = ws.RangeUsed().CreateTable();
Assert.AreEqual("Categories", table.Fields.First().Name);
table.SetShowHeaderRow(false);
Assert.AreEqual("Categories", table.Fields.First().Name);
Assert.IsTrue(ws.Cell(1, 1).IsEmpty(true));
Assert.AreEqual(null, table.HeadersRow());
Assert.AreEqual("A", table.DataRange.FirstRow().Field("Categories").GetString());
Assert.AreEqual("C", table.DataRange.LastRow().Field("Categories").GetString());
Assert.AreEqual("A", table.DataRange.FirstCell().GetString());
Assert.AreEqual("C", table.DataRange.LastCell().GetString());
table.SetShowHeaderRow();
IXLRangeRow headerRow = table.HeadersRow();
Assert.AreNotEqual(null, headerRow);
Assert.AreEqual("Categories", headerRow.Cell(1).GetString());
table.SetShowHeaderRow(false);
ws.FirstCell().SetValue("x");
table.SetShowHeaderRow();
Assert.AreEqual("x", ws.FirstCell().GetString());
Assert.AreEqual("Categories", ws.Cell("A2").GetString());
Assert.AreNotEqual(null, headerRow);
Assert.AreEqual("A", table.DataRange.FirstRow().Field("Categories").GetString());
Assert.AreEqual("C", table.DataRange.LastRow().Field("Categories").GetString());
Assert.AreEqual("A", table.DataRange.FirstCell().GetString());
Assert.AreEqual("C", table.DataRange.LastCell().GetString());
}
}
[Test]
public void ChangeFieldName()
{
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet");
ws.Cell("A1").SetValue("FName")
.CellBelow().SetValue("John");
ws.Cell("B1").SetValue("LName")
.CellBelow().SetValue("Doe");
var tbl = ws.RangeUsed().CreateTable();
var nameBefore = tbl.Field(tbl.Fields.Last().Index).Name;
tbl.Field(tbl.Fields.Last().Index).Name = "LastName";
var nameAfter = tbl.Field(tbl.Fields.Last().Index).Name;
var cellValue = ws.Cell("B1").GetString();
Assert.AreEqual("LName", nameBefore);
Assert.AreEqual("LastName", nameAfter);
Assert.AreEqual("LastName", cellValue);
tbl.ShowHeaderRow = false;
tbl.Field(tbl.Fields.Last().Index).Name = "LastNameChanged";
nameAfter = tbl.Field(tbl.Fields.Last().Index).Name;
Assert.AreEqual("LastNameChanged", nameAfter);
tbl.SetShowHeaderRow(true);
nameAfter = tbl.Cell("B1").Value.ToString();
Assert.AreEqual("LastNameChanged", nameAfter);
var field = tbl.Field("LastNameChanged");
Assert.AreEqual("LastNameChanged", field.Name);
tbl.Cell(1, 1).Value = "FirstName";
Assert.AreEqual("FirstName", tbl.Field(0).Name);
}
}
[Test]
public void CanDeleteTableColumn()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
var table = ws.FirstCell().InsertTable(l);
table.Column("C").Delete();
Assert.AreEqual(3, table.Fields.Count());
Assert.AreEqual("FirstColumn", table.Fields.First().Name);
Assert.AreEqual(0, table.Fields.First().Index);
Assert.AreEqual("UnOrderedColumn", table.Fields.Last().Name);
Assert.AreEqual(2, table.Fields.Last().Index);
}
}
[Test]
public void CanDeleteTable()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var ms = new MemoryStream())
{
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().InsertTable(l);
wb.SaveAs(ms);
}
ms.Seek(0, SeekOrigin.Begin);
using (var wb = new XLWorkbook(ms))
{
var ws = wb.Worksheets.First();
var table = ws.Tables.First();
ws.Tables.Remove(table.Name);
Assert.AreEqual(0, ws.Tables.Count());
wb.Save();
}
}
}
[Test]
public void CanDeleteTableField()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
var table = ws.Cell("B2").InsertTable(l);
Assert.AreEqual("B2:E4", table.RangeAddress.ToString());
table.Field("SomeFieldNotProperty").Delete();
Assert.AreEqual(3, table.Fields.Count());
Assert.AreEqual("FirstColumn", table.Fields.First().Name);
Assert.AreEqual(0, table.Fields.First().Index);
Assert.AreEqual("UnOrderedColumn", table.Fields.Last().Name);
Assert.AreEqual(2, table.Fields.Last().Index);
Assert.AreEqual("B2:D4", table.RangeAddress.ToString());
}
}
[Test]
public void CanDeleteTableRows()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 },
new TestObjectWithAttributes() { Column1 = "e", Column2 = "f", MyField = 6, UnOrderedColumn = 555 },
new TestObjectWithAttributes() { Column1 = "g", Column2 = "h", MyField = 7, UnOrderedColumn = 333 }
};
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
var table = ws.Cell("B2").InsertTable(l);
Assert.AreEqual("B2:E6", table.RangeAddress.ToString());
table.DataRange.Rows(3, 4).Delete();
Assert.AreEqual(2, table.DataRange.Rows().Count());
Assert.AreEqual("b", table.DataRange.FirstCell().Value);
Assert.AreEqual(777, table.DataRange.LastCell().Value);
Assert.AreEqual("B2:E4", table.RangeAddress.ToString());
}
}
[Test]
public void OverlappingTablesThrowsException()
{
var dt = new DataTable("sheet1");
dt.Columns.Add("col1", typeof(string));
dt.Columns.Add("col2", typeof(double));
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().InsertTable(dt, true);
Assert.Throws<InvalidOperationException>(() => ws.FirstCell().CellRight().InsertTable(dt, true));
}
}
[Test]
public void OverwritingTableTotalsRow()
{
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
var data1 = Enumerable.Range(1, 10)
.Select(i =>
new
{
Index = i,
Character = Convert.ToChar(64 + i),
String = new String('a', i)
});
var table = ws.FirstCell().InsertTable(data1, true)
.SetShowHeaderRow()
.SetShowTotalsRow();
table.Fields.First().TotalsRowFunction = XLTotalsRowFunction.Sum;
var data2 = Enumerable.Range(1, 20)
.Select(i =>
new
{
Index = i,
Character = Convert.ToChar(64 + i),
String = new String('b', i),
Int = 64 + i
});
ws.FirstCell().CellBelow().InsertData(data2);
table.Fields.ForEach(f => Assert.AreEqual(XLTotalsRowFunction.None, f.TotalsRowFunction));
Assert.AreEqual("11", table.Field(0).TotalsRowLabel);
Assert.AreEqual("K", table.Field(1).TotalsRowLabel);
Assert.AreEqual("bbbbbbbbbbb", table.Field(2).TotalsRowLabel);
}
}
[Test]
public void TableRenameTests()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
var table1 = ws.FirstCell().InsertTable(l);
var table2 = ws.Cell("A10").InsertTable(l);
Assert.AreEqual("Table1", table1.Name);
Assert.AreEqual("Table2", table2.Name);
table1.Name = "table1";
Assert.AreEqual("table1", table1.Name);
Assert.Throws<ArgumentException>(() => table1.Name = "");
Assert.Throws<ArgumentException>(() => table1.Name = "R");
Assert.Throws<ArgumentException>(() => table1.Name = "C");
Assert.Throws<ArgumentException>(() => table1.Name = "r");
Assert.Throws<ArgumentException>(() => table1.Name = "c");
Assert.Throws<ArgumentException>(() => table1.Name = "123");
Assert.Throws<ArgumentException>(() => table1.Name = new String('A', 256));
Assert.Throws<ArgumentException>(() => table1.Name = "Table2");
Assert.Throws<ArgumentException>(() => table1.Name = "TABLE2");
}
}
[Test]
public void CanResizeTable()
{
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
var data1 = Enumerable.Range(1, 10)
.Select(i =>
new
{
Index = i,
Character = Convert.ToChar(64 + i),
String = new String('a', i)
});
var table = ws.FirstCell().InsertTable(data1, true)
.SetShowHeaderRow()
.SetShowTotalsRow();
table.Fields.First().TotalsRowFunction = XLTotalsRowFunction.Sum;
var data2 = Enumerable.Range(1, 10)
.Select(i =>
new
{
Index = i,
Character = Convert.ToChar(64 + i),
String = new String('b', i),
Integer = 64 + i
});
ws.FirstCell().CellBelow().InsertData(data2);
table.Resize(table.FirstCell().Address, table.AsRange().LastCell().CellRight().Address);
Assert.AreEqual(4, table.Fields.Count());
Assert.AreEqual("Column4", table.Field(3).Name);
ws.Cell("D1").Value = "Integer";
Assert.AreEqual("Integer", table.Field(3).Name);
}
}
[Test]
public void TableAsDynamicEnumerable()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
var table = ws.FirstCell().InsertTable(l);
foreach (var d in table.AsDynamicEnumerable())
{
Assert.DoesNotThrow(() =>
{
object value;
value = d.FirstColumn;
value = d.SecondColumn;
value = d.UnOrderedColumn;
value = d.SomeFieldNotProperty;
});
}
}
}
[Test]
public void TableAsDotNetDataTable()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
var table = ws.FirstCell().InsertTable(l).AsNativeDataTable();
Assert.AreEqual(4, table.Columns.Count);
Assert.AreEqual("FirstColumn", table.Columns[0].ColumnName);
Assert.AreEqual("SecondColumn", table.Columns[1].ColumnName);
Assert.AreEqual("SomeFieldNotProperty", table.Columns[2].ColumnName);
Assert.AreEqual("UnOrderedColumn", table.Columns[3].ColumnName);
Assert.AreEqual(typeof(String), table.Columns[0].DataType);
Assert.AreEqual(typeof(String), table.Columns[1].DataType);
Assert.AreEqual(typeof(Double), table.Columns[2].DataType);
Assert.AreEqual(typeof(Double), table.Columns[3].DataType);
var dr = table.Rows[0];
Assert.AreEqual("b", dr["FirstColumn"]);
Assert.AreEqual("a", dr["SecondColumn"]);
Assert.AreEqual(4, dr["SomeFieldNotProperty"]);
Assert.AreEqual(999, dr["UnOrderedColumn"]);
dr = table.Rows[1];
Assert.AreEqual("d", dr["FirstColumn"]);
Assert.AreEqual("c", dr["SecondColumn"]);
Assert.AreEqual(5, dr["SomeFieldNotProperty"]);
Assert.AreEqual(777, dr["UnOrderedColumn"]);
}
}
[Test]
public void TestTableCellTypes()
{
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
var data1 = Enumerable.Range(1, 10)
.Select(i =>
new
{
Index = i,
Character = Convert.ToChar(64 + i),
String = new String('a', i)
});
var table = ws.FirstCell().InsertTable(data1, true)
.SetShowHeaderRow()
.SetShowTotalsRow();
table.Fields.First().TotalsRowFunction = XLTotalsRowFunction.Sum;
Assert.AreEqual(XLTableCellType.Header, table.HeadersRow().Cell(1).TableCellType());
Assert.AreEqual(XLTableCellType.Data, table.HeadersRow().Cell(1).CellBelow().TableCellType());
Assert.AreEqual(XLTableCellType.Total, table.TotalsRow().Cell(1).TableCellType());
Assert.AreEqual(XLTableCellType.None, ws.Cell("Z100").TableCellType());
}
}
[Test]
public void TotalsFunctionsOfHeadersWithWeirdCharacters()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var wb = new XLWorkbook())
{
var ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().InsertTable(l, false);
// Give the headings weird names (i.e. spaces, hashes, single quotes
ws.Cell("A1").Value = "ABCD ";
ws.Cell("B1").Value = " #BCD";
ws.Cell("C1").Value = " as'df ";
ws.Cell("D1").Value = "Normal";
var table = ws.RangeUsed().CreateTable();
Assert.IsNotNull(table);
table.ShowTotalsRow = true;
table.Field(0).TotalsRowFunction = XLTotalsRowFunction.Count;
table.Field(1).TotalsRowFunction = XLTotalsRowFunction.Count;
table.Field(2).TotalsRowFunction = XLTotalsRowFunction.Sum;
table.Field(3).TotalsRowFunction = XLTotalsRowFunction.Sum;
Assert.AreEqual("SUBTOTAL(103,Table1[[ABCD ]])", table.Field(0).TotalsRowFormulaA1);
Assert.AreEqual("SUBTOTAL(103,Table1[[ '#BCD]])", table.Field(1).TotalsRowFormulaA1);
Assert.AreEqual("SUBTOTAL(109,Table1[[ as''df ]])", table.Field(2).TotalsRowFormulaA1);
Assert.AreEqual("SUBTOTAL(109,[Normal])", table.Field(3).TotalsRowFormulaA1);
}
}
[Test]
public void CannotCreateDuplicateTablesOverSameRange()
{
var l = new List<TestObjectWithAttributes>()
{
new TestObjectWithAttributes() { Column1 = "a", Column2 = "b", MyField = 4, UnOrderedColumn = 999 },
new TestObjectWithAttributes() { Column1 = "c", Column2 = "d", MyField = 5, UnOrderedColumn = 777 }
};
using (var wb = new XLWorkbook())
{
IXLWorksheet ws = wb.AddWorksheet("Sheet1");
ws.FirstCell().InsertTable(l);
Assert.Throws<ArgumentException>(() => ws.RangeUsed().CreateTable());
}
}
[Test]
public void CopyTableSameWorksheet()
{
var wb = new XLWorkbook();
var ws1 = wb.Worksheets.Add("Sheet1");
var table = ws1.Range("A1:C2").AsTable();
TestDelegate action = () => table.CopyTo(ws1);
Assert.Throws(typeof(InvalidOperationException), action);
}
[Test]
public void CopyDetachedTableDifferentWorksheets()
{
var wb = new XLWorkbook();
var ws1 = wb.Worksheets.Add("Sheet1");
ws1.Cell("A1").Value = "Custom column 1";
ws1.Cell("B1").Value = "Custom column 2";
ws1.Cell("C1").Value = "Custom column 3";
ws1.Cell("A2").Value = "Value 1";
ws1.Cell("B2").Value = 123.45;
ws1.Cell("C2").Value = new DateTime(2018, 5, 10);
var original = ws1.Range("A1:C2").AsTable("Detached table");
var ws2 = wb.Worksheets.Add("Sheet2");
var copy = original.CopyTo(ws2);
Assert.AreEqual(0, ws1.Tables.Count()); // We did not add it
Assert.AreEqual(1, ws2.Tables.Count());
AssertTablesAreEqual(original, copy);
Assert.AreEqual("Sheet2!A1:C2", copy.RangeAddress.ToString(XLReferenceStyle.A1, true));
Assert.AreEqual("Custom column 1", ws2.Cell("A1").Value);
Assert.AreEqual("Custom column 2", ws2.Cell("B1").Value);
Assert.AreEqual("Custom column 3", ws2.Cell("C1").Value);
Assert.AreEqual("Value 1", ws2.Cell("A2").Value);
Assert.AreEqual(123.45, (double)ws2.Cell("B2").Value, XLHelper.Epsilon);
Assert.AreEqual(new DateTime(2018, 5, 10), ws2.Cell("C2").Value);
}
[Test]
public void CopyTableDifferentWorksheets()
{
var wb = new XLWorkbook();
var ws1 = wb.Worksheets.Add("Sheet1");
ws1.Cell("A1").Value = "Custom column 1";
ws1.Cell("B1").Value = "Custom column 2";
ws1.Cell("C1").Value = "Custom column 3";
ws1.Cell("A2").Value = "Value 1";
ws1.Cell("B2").Value = 123.45;
ws1.Cell("C2").Value = new DateTime(2018, 5, 10);
var original = ws1.Range("A1:C2").AsTable("Attached table");
ws1.Tables.Add(original);
var ws2 = wb.Worksheets.Add("Sheet2");
original.CopyTo(ws2);
Assert.AreEqual(1, ws1.Tables.Count());
Assert.AreEqual(1, ws2.Tables.Count());
var copy = ws2.Tables.First();
AssertTablesAreEqual(original, copy);
Assert.AreEqual("Sheet2!A1:C2", copy.RangeAddress.ToString(XLReferenceStyle.A1, true));
Assert.AreEqual("Custom column 1", ws2.Cell("A1").Value);
Assert.AreEqual("Custom column 2", ws2.Cell("B1").Value);
Assert.AreEqual("Custom column 3", ws2.Cell("C1").Value);
Assert.AreEqual("Value 1", ws2.Cell("A2").Value);
Assert.AreEqual(123.45, (double)ws2.Cell("B2").Value, XLHelper.Epsilon);
Assert.AreEqual(new DateTime(2018, 5, 10), ws2.Cell("C2").Value);
}
[Test]
public void CopyTableWithoutData()
{
var wb = new XLWorkbook();
var ws1 = wb.Worksheets.Add("Sheet1");
ws1.Cell("A1").Value = "Custom column 1";
ws1.Cell("B1").Value = "Custom column 2";
ws1.Cell("C1").Value = "Custom column 3";
ws1.Cell("A2").Value = "Value 1";
ws1.Cell("B2").Value = 123.45;
ws1.Cell("C2").Value = new DateTime(2018, 5, 10);
var original = ws1.Range("A1:C2").AsTable("Attached table");
ws1.Tables.Add(original);
var ws2 = wb.Worksheets.Add("Sheet2") as XLWorksheet;
var copy = (original as XLTable).CopyTo(ws2, false);
AssertTablesAreEqual(original, copy);
Assert.AreEqual("Sheet2!A1:C2", copy.RangeAddress.ToString(XLReferenceStyle.A1, true));
Assert.AreEqual("Custom column 1", ws2.Cell("A1").Value);
Assert.AreEqual("Custom column 2", ws2.Cell("B1").Value);
Assert.AreEqual("Custom column 3", ws2.Cell("C1").Value);
Assert.AreEqual("", ws2.Cell("A2").Value);
Assert.AreEqual("", ws2.Cell("B2").Value);
Assert.AreEqual("", ws2.Cell("C2").Value);
}
private void AssertTablesAreEqual(IXLTable table1, IXLTable table2)
{
Assert.AreEqual(table1.RangeAddress.ToString(XLReferenceStyle.A1, false), table2.RangeAddress.ToString(XLReferenceStyle.A1, false));
Assert.AreEqual(table1.Fields.Count(), table2.Fields.Count());
for (int j = 0; j < table1.Fields.Count(); j++)
{
var originalField = table1.Fields.ElementAt(j);
var copyField = table2.Fields.ElementAt(j);
Assert.AreEqual(originalField.Name, copyField.Name);
if (table1.ShowTotalsRow)
{
Assert.AreEqual(originalField.TotalsRowFormulaA1, copyField.TotalsRowFormulaA1);
Assert.AreEqual(originalField.TotalsRowFunction, copyField.TotalsRowFunction);
}
}
Assert.AreEqual(table1.Name, table2.Name);
Assert.AreEqual(table1.ShowAutoFilter, table2.ShowAutoFilter);
Assert.AreEqual(table1.ShowColumnStripes, table2.ShowColumnStripes);
Assert.AreEqual(table1.ShowHeaderRow, table2.ShowHeaderRow);
Assert.AreEqual(table1.ShowRowStripes, table2.ShowRowStripes);
Assert.AreEqual(table1.ShowTotalsRow, table2.ShowTotalsRow);
Assert.AreEqual((table1.Style as XLStyle).Value, (table2.Style as XLStyle).Value);
Assert.AreEqual(table1.Theme, table2.Theme);
}
//TODO: Delete table (not underlying range)
}
}