2023-06-21 07:24:47 +03:00
|
|
|
|
using RhSolutions.AddIn;
|
|
|
|
|
|
|
|
|
|
namespace RhSolutions.Tests;
|
|
|
|
|
|
|
|
|
|
[ExcelTestSettings(OutOfProcess = true)]
|
|
|
|
|
public class CanFillSleeves : IDisposable
|
|
|
|
|
{
|
|
|
|
|
private RhSolutionsAddIn _addIn;
|
2023-11-02 23:07:06 +03:00
|
|
|
|
private IFittingsCalculator _calculator;
|
2023-06-21 07:24:47 +03:00
|
|
|
|
private IReader _reader;
|
|
|
|
|
private IWriter _writer;
|
|
|
|
|
private Worksheet _worksheet;
|
|
|
|
|
|
|
|
|
|
public CanFillSleeves()
|
|
|
|
|
{
|
2023-12-09 23:04:49 +03:00
|
|
|
|
Environment.SetEnvironmentVariable("ISTESTING", "true");
|
2023-06-21 07:24:47 +03:00
|
|
|
|
_addIn = new();
|
|
|
|
|
_addIn.AutoOpen();
|
|
|
|
|
_calculator = new SleevesCalculator();
|
|
|
|
|
_reader = new ExcelReader(Util.Application, RhSolutionsAddIn.Configuration);
|
|
|
|
|
_writer = new CurrentPriceWriter(Util.Application, RhSolutionsAddIn.Configuration);
|
|
|
|
|
_worksheet = Util.Workbook.Worksheets[1];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[ExcelFact(Workbook = @"..\..\..\TestWorkbooks\TestSpecificationSleeves.xlsx")]
|
|
|
|
|
public void CanCalculateSleeves()
|
|
|
|
|
{
|
|
|
|
|
var products = _reader.ReadProducts(new[] { _worksheet });
|
2023-11-02 23:07:06 +03:00
|
|
|
|
var sleeves = _calculator.Calculate(products.First().Item2);
|
2023-06-21 07:24:47 +03:00
|
|
|
|
_writer.WriteProducts(sleeves);
|
2024-10-31 23:31:14 +03:00
|
|
|
|
for (int i = 2; i < 14; i++)
|
|
|
|
|
{
|
|
|
|
|
Assert.Equal(_worksheet.Range[$"F{i}"].Value, _worksheet.Range[$"E{i}"].Value);
|
|
|
|
|
}
|
2023-06-21 07:24:47 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Dispose()
|
|
|
|
|
{
|
|
|
|
|
_addIn.AutoClose();
|
|
|
|
|
}
|
|
|
|
|
}
|