aboutsummaryrefslogtreecommitdiff
path: root/RhSolutions.Tests/CanDoMagic.cs
blob: d3a0bf9526209ccaec9df5a8fb0954980c5776b0 (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
using Microsoft.Extensions.DependencyInjection;
using RhSolutions.AddIn;
using System.IO;

namespace RhSolutions.Tests;

[ExcelTestSettings(OutOfProcess = true)]
public class CanDoMagic : IDisposable
{
    private RhSolutionsAddIn _addIn;
    //private ReaderFactory _readerFactory;
    private IReader _reader;

    public CanDoMagic()
    {
        _addIn = new();
        _addIn.AutoOpen();
        //_readerFactory = RhSolutionsAddIn.ServiceProvider.GetRequiredService<ReaderFactory>();
        _reader = new MagicReader(Util.Application);
    }

    [ExcelFact(Workbook = @"..\..\..\TestWorkbooks\TestSpecificationMagic.xlsx")]
    public void CanWrite()
    {
        Worksheet sourceSheet = Util.Workbook.Worksheets[1];
        RhSolutionsAddIn.Configuration.SetPriceListPath(Path.GetFullPath(@"..\..\..\TestWorkbooks\TargetSpecificationMagic.xlsx"));
        var products = _reader.ReadProducts(new[] { sourceSheet });
        var _writer = new ExcelWriter(Util.Application, RhSolutionsAddIn.Configuration);
        _writer.WriteProducts(products);
        Worksheet targetSheet = Util.Application.ActiveWindow.ActiveSheet;
        var targetProducts = _reader.ReadProducts(new[] { targetSheet });

        Assert.Equal("TestSpecificationMagic", products.First().Item1);
        Assert.Equal("TargetSpecificationMagic", targetProducts.First().Item1);
        Assert.Equal(products.First().Item2.Count(), targetProducts.First().Item2.Count());
        Assert.Equal(products.First().Item2.Values.Sum(), targetProducts.First().Item2.Values.Sum());
    }

    public void Dispose()
    {
        _addIn.AutoClose();
        Util.Application.ActiveWindow.Close(SaveChanges: false);
    }
}