Fixed DimTests

This commit is contained in:
Tig
2024-05-30 07:09:20 -06:00
parent ce894345ae
commit 37653cd695

View File

@@ -3,10 +3,6 @@ using System.Text;
using Xunit.Abstractions;
using static Terminal.Gui.Dim;
// Alias Console to MockConsole so we don't accidentally use Console
using Console = Terminal.Gui.FakeConsole;
namespace Terminal.Gui.LayoutTests;
public class DimTests
@@ -28,7 +24,7 @@ public class DimTests
public void DimAbsolute_Calculate_ReturnsCorrectValue ()
{
var dim = new DimAbsolute (10);
var result = dim.Calculate (0, 100, null, Dimension.None);
int result = dim.Calculate (0, 100, null, Dimension.None);
Assert.Equal (10, result);
}
@@ -144,6 +140,7 @@ public class DimTests
Application.Run (top);
Assert.Equal (0, count);
top.Dispose ();
}
// TODO: This actually a SetRelativeLayout/LayoutSubViews test and should be moved
@@ -173,7 +170,7 @@ public class DimTests
[Fact]
public void DimHeight_Set_To_Null_Throws ()
{
Dim dim = Dim.Height (null);
Dim dim = Height (null);
Assert.Throws<NullReferenceException> (() => dim.ToString ());
}
@@ -183,13 +180,13 @@ public class DimTests
{
var testVal = Rectangle.Empty;
var testValview = new View { Frame = testVal };
Dim dim = Dim.Height (testValview);
Dim dim = Height (testValview);
Assert.Equal ($"View(Height,View(){testVal})", dim.ToString ());
testValview.Dispose ();
testVal = new Rectangle (1, 2, 3, 4);
testValview = new View { Frame = testVal };
dim = Dim.Height (testValview);
testVal = new (1, 2, 3, 4);
testValview = new() { Frame = testVal };
dim = Height (testValview);
Assert.Equal ($"View(Height,View(){testVal})", dim.ToString ());
testValview.Dispose ();
}
@@ -212,7 +209,7 @@ public class DimTests
Assert.Equal (dimCombine.Right, dimAbsolute);
Assert.Equal (20, dimCombine.GetAnchor (100));
var view = new View { Frame = new Rectangle (20, 10, 20, 1) };
var view = new View { Frame = new (20, 10, 20, 1) };
var dimViewHeight = new DimView (view, Dimension.Height);
Assert.Equal (1, dimViewHeight.GetAnchor (0));
var dimViewWidth = new DimView (view, Dimension.Width);
@@ -236,7 +233,7 @@ public class DimTests
{
X = 0,
Y = 0,
Width = Dim.Percent (50),
Width = Percent (50),
Height = 5,
Title = "f1"
};
@@ -245,7 +242,7 @@ public class DimTests
{
X = Pos.Right (f1),
Y = 0,
Width = Dim.Fill (),
Width = Fill (),
Height = 5,
Title = "f2"
};
@@ -254,8 +251,8 @@ public class DimTests
{
X = Pos.X (f1) + 2,
Y = Pos.Bottom (f1) + 2,
Width = Dim.Width (f1) - 2,
Height = Dim.Fill () - 2,
Width = Width (f1) - 2,
Height = Fill () - 2,
ValidatePosDim = true,
Text = "v1"
};
@@ -264,32 +261,32 @@ public class DimTests
{
X = Pos.X (f2) + 2,
Y = Pos.Bottom (f2) + 2,
Width = Dim.Width (f2) - 2,
Height = Dim.Fill () - 2,
Width = Width (f2) - 2,
Height = Fill () - 2,
ValidatePosDim = true,
Text = "v2"
};
var v3 = new Button
{
Width = Dim.Percent (10),
Height = Dim.Percent (10),
Width = Percent (10),
Height = Percent (10),
ValidatePosDim = true,
Text = "v3"
};
var v4 = new Button
{
Width = Dim.Absolute (50),
Height = Dim.Absolute (50),
Width = Absolute (50),
Height = Absolute (50),
ValidatePosDim = true,
Text = "v4"
};
var v5 = new Button
{
Width = Dim.Width (v1) - Dim.Width (v3),
Height = Dim.Height (v1) - Dim.Height (v3),
Width = Width (v1) - Width (v3),
Height = Height (v1) - Height (v3),
ValidatePosDim = true,
Text = "v5"
};
@@ -298,8 +295,8 @@ public class DimTests
{
X = Pos.X (f2),
Y = Pos.Bottom (f2) + 2,
Width = Dim.Percent (20, DimPercentMode.Position),
Height = Dim.Percent (20, DimPercentMode.Position),
Width = Percent (20, DimPercentMode.Position),
Height = Percent (20, DimPercentMode.Position),
ValidatePosDim = true,
Text = "v6"
};
@@ -362,10 +359,10 @@ public class DimTests
#else
Assert.Equal ($"Combine(View(Height,Button(){v1.Frame})-View(Height,Button(){v3.Viewport}))", v5.Height.ToString ( ));
#endif
Assert.Equal (38, v5.Frame.Width); // 47-9=38
Assert.Equal (38, v5.Frame.Width); // 47-9=38
Assert.Equal (80, v5.Frame.Height); // 89-9=80
Assert.Equal (9, v6.Frame.Width); // 47*20%=9
Assert.Equal (9, v6.Frame.Width); // 47*20%=9
Assert.Equal (18, v6.Frame.Height); // 89*20%=18
w.Width = 200;
@@ -395,7 +392,7 @@ public class DimTests
Assert.Equal ($"Combine(View(Width,FrameView(){f1.Frame})-Absolute(2))", v1.Width.ToString ());
#endif
Assert.Equal ("Combine(Fill(0)-Absolute(2))", v1.Height.ToString ());
Assert.Equal (97, v1.Frame.Width); // 99-2=97
Assert.Equal (97, v1.Frame.Width); // 99-2=97
Assert.Equal (189, v1.Frame.Height); // 198-2-7=189
v2.Text = "Button2";
@@ -406,21 +403,22 @@ public class DimTests
Assert.Equal ($"Combine(View(Width,FrameView(){f2.Frame})-Absolute(2))", v2.Width.ToString ());
#endif
Assert.Equal ("Combine(Fill(0)-Absolute(2))", v2.Height.ToString ());
Assert.Equal (97, v2.Frame.Width); // 99-2=97
Assert.Equal (97, v2.Frame.Width); // 99-2=97
Assert.Equal (189, v2.Frame.Height); // 198-2-7=189
v3.Text = "Button3";
// 198*10%=19 * Percent is related to the super-view if it isn't null otherwise the view width
Assert.Equal (19, v3.Frame.Width);
// 199*10%=19
Assert.Equal (19, v3.Frame.Height);
v4.Text = "Button4";
v4.Width = Auto(DimAutoStyle.Text);
v4.Width = Auto (DimAutoStyle.Text);
v4.Height = Auto (DimAutoStyle.Text);
Assert.Equal (Dim.Auto (DimAutoStyle.Text), v4.Width);
Assert.Equal (Dim.Auto (DimAutoStyle.Text), v4.Height);
Assert.Equal (Auto (DimAutoStyle.Text), v4.Width);
Assert.Equal (Auto (DimAutoStyle.Text), v4.Height);
Assert.Equal (11, v4.Frame.Width); // 11 is the text length and because is DimAbsolute
Assert.Equal (1, v4.Frame.Height); // 1 because is DimAbsolute
@@ -434,17 +432,18 @@ public class DimTests
Assert.Equal ($"Combine(View(Height,Button(){v1.Frame})-View(Height,Button(){v3.Frame}))", v5.Height.ToString ());
#endif
Assert.Equal (78, v5.Frame.Width); // 97-9=78
Assert.Equal (78, v5.Frame.Width); // 97-9=78
Assert.Equal (170, v5.Frame.Height); // 189-19=170
v6.Text = "Button6";
Assert.Equal (19, v6.Frame.Width); // 99*20%=19
Assert.Equal (19, v6.Frame.Width); // 99*20%=19
Assert.Equal (38, v6.Frame.Height); // 198-7*20=18
};
Application.Iteration += (s, a) => Application.RequestStop ();
Application.Run (t);
t.Dispose ();
}
// TODO: This actually a SetRelativeLayout/LayoutSubViews test and should be moved
@@ -457,8 +456,8 @@ public class DimTests
var view = new View
{
Width = Dim.Width (super), // this is allowed
Height = Dim.Height (super), // this is allowed
Width = Width (super), // this is allowed
Height = Height (super), // this is allowed
Text = "view"
};
@@ -476,39 +475,39 @@ public class DimTests
{
var n1 = 0;
var n2 = 0;
Dim dim1 = Dim.Absolute (n1);
Dim dim2 = Dim.Absolute (n2);
Dim dim1 = Absolute (n1);
Dim dim2 = Absolute (n2);
Assert.Equal (dim1, dim2);
n1 = n2 = 1;
dim1 = Dim.Absolute (n1);
dim2 = Dim.Absolute (n2);
dim1 = Absolute (n1);
dim2 = Absolute (n2);
Assert.Equal (dim1, dim2);
n1 = n2 = -1;
dim1 = Dim.Absolute (n1);
dim2 = Dim.Absolute (n2);
dim1 = Absolute (n1);
dim2 = Absolute (n2);
Assert.Equal (dim1, dim2);
n1 = 0;
n2 = 1;
dim1 = Dim.Absolute (n1);
dim2 = Dim.Absolute (n2);
dim1 = Absolute (n1);
dim2 = Absolute (n2);
Assert.NotEqual (dim1, dim2);
}
[Fact]
public void DimSized_SetsValue ()
{
Dim dim = Dim.Absolute (0);
Dim dim = Absolute (0);
Assert.Equal ("Absolute(0)", dim.ToString ());
var testVal = 5;
dim = Dim.Absolute (testVal);
dim = Absolute (testVal);
Assert.Equal ($"Absolute({testVal})", dim.ToString ());
testVal = -1;
dim = Dim.Absolute (testVal);
dim = Absolute (testVal);
Assert.Equal ($"Absolute({testVal})", dim.ToString ());
}
@@ -523,8 +522,8 @@ public class DimTests
var view = new View
{
Width = Dim.Width (view2), // this is not allowed
Height = Dim.Height (view2), // this is not allowed
Width = Width (view2), // this is not allowed
Height = Height (view2), // this is not allowed
Text = "view"
};
@@ -570,39 +569,39 @@ public class DimTests
var testRect2 = Rectangle.Empty;
var view2 = new View { Frame = testRect2 };
Dim dim1 = Dim.Width (view1);
Dim dim2 = Dim.Width (view1);
Dim dim1 = Width (view1);
Dim dim2 = Width (view1);
// FIXED: Dim.Width should support Equals() and this should change to Equal.
Assert.Equal (dim1, dim2);
dim2 = Dim.Width (view2);
dim2 = Width (view2);
Assert.NotEqual (dim1, dim2);
testRect1 = new Rectangle (0, 1, 2, 3);
view1 = new View { Frame = testRect1 };
testRect2 = new Rectangle (0, 1, 2, 3);
dim1 = Dim.Width (view1);
dim2 = Dim.Width (view1);
testRect1 = new (0, 1, 2, 3);
view1 = new() { Frame = testRect1 };
testRect2 = new (0, 1, 2, 3);
dim1 = Width (view1);
dim2 = Width (view1);
// FIXED: Dim.Width should support Equals() and this should change to Equal.
Assert.Equal (dim1, dim2);
testRect1 = new Rectangle (0, -1, 2, 3);
view1 = new View { Frame = testRect1 };
testRect2 = new Rectangle (0, -1, 2, 3);
dim1 = Dim.Width (view1);
dim2 = Dim.Width (view1);
testRect1 = new (0, -1, 2, 3);
view1 = new() { Frame = testRect1 };
testRect2 = new (0, -1, 2, 3);
dim1 = Width (view1);
dim2 = Width (view1);
// FIXED: Dim.Width should support Equals() and this should change to Equal.
Assert.Equal (dim1, dim2);
testRect1 = new Rectangle (0, -1, 2, 3);
view1 = new View { Frame = testRect1 };
testRect1 = new (0, -1, 2, 3);
view1 = new() { Frame = testRect1 };
testRect2 = Rectangle.Empty;
view2 = new View { Frame = testRect2 };
dim1 = Dim.Width (view1);
dim2 = Dim.Width (view2);
view2 = new() { Frame = testRect2 };
dim1 = Width (view1);
dim2 = Width (view2);
Assert.NotEqual (dim1, dim2);
#if DEBUG_IDISPOSABLE
@@ -615,7 +614,7 @@ public class DimTests
[Fact]
public void DimWidth_Set_To_Null_Throws ()
{
Dim dim = Dim.Width (null);
Dim dim = Width (null);
Assert.Throws<NullReferenceException> (() => dim.ToString ());
}
@@ -625,13 +624,13 @@ public class DimTests
{
var testVal = Rectangle.Empty;
var testValView = new View { Frame = testVal };
Dim dim = Dim.Width (testValView);
Dim dim = Width (testValView);
Assert.Equal ($"View(Width,View(){testVal})", dim.ToString ());
testValView.Dispose ();
testVal = new Rectangle (1, 2, 3, 4);
testValView = new View { Frame = testVal };
dim = Dim.Width (testValView);
testVal = new (1, 2, 3, 4);
testValView = new() { Frame = testVal };
dim = Width (testValView);
Assert.Equal ($"View(Width,View(){testVal})", dim.ToString ());
testValView.Dispose ();
}