aboutsummaryrefslogtreecommitdiff
path: root/RhSolutions.SkuParser.Tests/ExcelParserTests.cs
blob: 83e95c13ea55c1c7ce10c64cd5b53f84384bbb6d (plain)
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
using RhSolutions.SkuParser.Services;

namespace RhSolutions.SkuParser.Tests;

public class ExcelParserTests
{
	private static readonly List<ProductQuantity> _expected = new()
	{
		new ProductQuantity() {Product= new Product() {Sku = "11303703100"}, Quantity = 2129.5},
		new ProductQuantity() {Product= new Product() {Sku = "11303803100"}, Quantity = 503},
		new ProductQuantity() {Product= new Product() {Sku = "11303903050"}, Quantity = 52},
		new ProductQuantity() {Product= new Product() {Sku = "11080011001"}, Quantity = 2154},
		new ProductQuantity() {Product= new Product() {Sku = "11080021001"}, Quantity = 134},
		new ProductQuantity() {Product= new Product() {Sku = "11080031001"}, Quantity = 6},
		new ProductQuantity() {Product= new Product() {Sku = "11080311001"}, Quantity = 462},
		new ProductQuantity() {Product= new Product() {Sku = "11080611001"}, Quantity = 38},
		new ProductQuantity() {Product= new Product() {Sku = "11080811001"}, Quantity = 24},
		new ProductQuantity() {Product= new Product() {Sku = "11080831001"}, Quantity = 2},
	};

	[TestCase("simple.xlsx")]
	[TestCase("simpleWithNames.xlsx")]
	[TestCase("withHeader.xlsx")]
	[TestCase("withHeaderAndGarbage.xlsx")]
	[TestCase("twoTables.xlsx")]
	[TestCase("rhSolutionsBsTable.xlsx")]
	[TestCase("simpleWithFormulas.xlsx")]
	public void XlsxTests(string filename)
	{
		var mockFile = FormFileUtil.GetMockFormFile(filename);
		var parser = new ExcelParser();
		var actual = parser.ParseProducts(mockFile.Object);
		Assert.That(actual.Count, Is.EqualTo(_expected.Count()));
		CollectionAssert.AllItemsAreInstancesOfType(actual, typeof(ProductQuantity));
		CollectionAssert.AreEqual(_expected, actual);
	}

	[TestCase("simple.csv")]
	public void CsvTests(string filename)
	{
		var mockFile = FormFileUtil.GetMockFormFile(filename);
		var parser = new CsvParser();
		var actual = parser.ParseProducts(mockFile.Object);
		Assert.That(actual.Count, Is.EqualTo(_expected.Count()));
		CollectionAssert.AllItemsAreInstancesOfType(actual, typeof(ProductQuantity));
		CollectionAssert.AreEqual(_expected, actual);
	}
}