forked from JanKallman/EPPlus
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLoadFromCollectionTests.cs
More file actions
99 lines (89 loc) · 3.3 KB
/
LoadFromCollectionTests.cs
File metadata and controls
99 lines (89 loc) · 3.3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Reflection;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using OfficeOpenXml;
using OfficeOpenXml.Table;
namespace EPPlusTest
{
[TestClass]
public class LoadFromCollectionTests
{
internal abstract class BaseClass
{
public string Id { get; set; }
public string Name { get; set; }
}
internal class Implementation : BaseClass
{
public int Number { get; set; }
}
internal class Aclass
{
public string Id { get; set; }
public string Name { get; set; }
public int Number { get; set; }
}
[TestMethod]
public void ShouldUseAclassProperties()
{
var items = new List<Aclass>()
{
new Aclass(){ Id = "123", Name = "Item 1", Number = 3}
};
using (var pck = new ExcelPackage(new MemoryStream()))
{
var sheet = pck.Workbook.Worksheets.Add("sheet");
sheet.Cells["C1"].LoadFromCollection(items, true, TableStyles.Dark1);
Assert.AreEqual("Id", sheet.Cells["C1"].Value);
}
}
[TestMethod]
public void ShouldUseBaseClassProperties()
{
var items = new List<BaseClass>()
{
new Implementation(){ Id = "123", Name = "Item 1", Number = 3}
};
using (var pck = new ExcelPackage(new MemoryStream()))
{
var sheet = pck.Workbook.Worksheets.Add("sheet");
sheet.Cells["C1"].LoadFromCollection(items, true, TableStyles.Dark1);
Assert.AreEqual("Id", sheet.Cells["C1"].Value);
}
}
[TestMethod]
public void ShouldUseAnonymousProperties()
{
var objs = new List<BaseClass>()
{
new Implementation(){ Id = "123", Name = "Item 1", Number = 3}
};
var items = objs.Select(x => new {Id = x.Id, Name = x.Name}).ToList();
using (var pck = new ExcelPackage(new MemoryStream()))
{
var sheet = pck.Workbook.Worksheets.Add("sheet");
sheet.Cells["C1"].LoadFromCollection(items, true, TableStyles.Dark1);
Assert.AreEqual("Id", sheet.Cells["C1"].Value);
}
}
[TestMethod]
[ExpectedException(typeof(InvalidCastException))]
public void ShouldThrowInvalidCastExceptionIf()
{
var objs = new List<BaseClass>()
{
new Implementation(){ Id = "123", Name = "Item 1", Number = 3}
};
var items = objs.Select(x => new { Id = x.Id, Name = x.Name }).ToList();
using (var pck = new ExcelPackage(new MemoryStream()))
{
var sheet = pck.Workbook.Worksheets.Add("sheet");
sheet.Cells["C1"].LoadFromCollection(items, true, TableStyles.Dark1, BindingFlags.Public | BindingFlags.Instance, typeof(string).GetMembers());
Assert.AreEqual("Id", sheet.Cells["C1"].Value);
}
}
}
}