123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481 |
- using Xunit.Abstractions;
- namespace Terminal.Gui.ViewTests;
- /// <summary>
- /// Test the <see cref="View.Viewport"/>.
- /// DOES NOT TEST Adornment.Viewport methods. Those are in ./Adornment/ViewportTests.cs
- /// </summary>
- /// <param name="output"></param>
- public class ViewportTests (ITestOutputHelper output)
- {
- private readonly ITestOutputHelper _output = output;
- [Theory]
- [CombinatorialData]
- public void Get_Viewport_NoSuperView_WithoutAdornments ([CombinatorialRange (-11, 11)] int x)
- {
- // We test with only X because Y is equivalent. Height/Width are irrelevant.
- // Arrange
- var frame = new Rectangle (x, 0, 10, 10);
- var view = new View ();
- view.Frame = frame;
- view.BeginInit ();
- view.EndInit ();
- // Act
- var bounds = view.Viewport;
- // Assert
- Assert.Equal (10, bounds.Width);
- }
- [Theory]
- [InlineData (0, 0, 10)]
- [InlineData (1, 0, 9)]
- [InlineData (-1, 0, 11)]
- [InlineData (10, 0, 0)]
- [InlineData (11, 0, 0)]
- [InlineData (0, 1, 6)]
- [InlineData (1, 1, 5)]
- [InlineData (-1, 1, 7)]
- [InlineData (10, 1, 0)]
- [InlineData (11, 1, 0)]
- public void Get_Viewport_NestedSuperView_WithAdornments (int frameX, int borderThickness, int expectedW)
- {
- // We test with only X because Y is equivalent. Height/Width are irrelevant.
- // Arrange
- var superSuperView = new View ()
- {
- X = 0,
- Y = 0,
- Height = 10,
- Width = 10,
- };
- superSuperView.Border.Thickness = new Thickness (borderThickness);
- var superView = new View ()
- {
- X = 0,
- Y = 0,
- Height = Dim.Fill (),
- Width = Dim.Fill ()
- };
- superView.Border.Thickness = new Thickness (borderThickness);
- superSuperView.Add (superView);
- var view = new View ()
- {
- X = frameX,
- Y = 0,
- Height = Dim.Fill (),
- Width = Dim.Fill ()
- };
- superView.Add (view);
- superSuperView.BeginInit ();
- superSuperView.EndInit ();
- superSuperView.LayoutSubviews ();
- // Act
- var bounds = view.Viewport;
- // Assert
- Assert.Equal (expectedW, bounds.Width);
- }
- [Theory]
- [InlineData (0, 0, 10)]
- [InlineData (1, 0, 9)]
- [InlineData (-1, 0, 11)]
- [InlineData (10, 0, 0)]
- [InlineData (11, 0, 0)]
- [InlineData (0, 1, 4)]
- [InlineData (1, 1, 3)]
- [InlineData (-1, 1, 5)]
- [InlineData (10, 1, 0)]
- [InlineData (11, 1, 0)]
- public void Get_Viewport_NestedSuperView_WithAdornments_WithBorder (int frameX, int borderThickness, int expectedW)
- {
- // We test with only X because Y is equivalent. Height/Width are irrelevant.
- // Arrange
- var superSuperView = new View ()
- {
- X = 0,
- Y = 0,
- Height = 10,
- Width = 10,
- };
- superSuperView.Border.Thickness = new Thickness (borderThickness);
- var superView = new View ()
- {
- X = 0,
- Y = 0,
- Height = Dim.Fill (),
- Width = Dim.Fill ()
- };
- superView.Border.Thickness = new Thickness (borderThickness);
- superSuperView.Add (superView);
- var view = new View ()
- {
- X = frameX,
- Y = 0,
- Height = Dim.Fill (),
- Width = Dim.Fill ()
- };
- view.Border.Thickness = new Thickness (borderThickness);
- superView.Add (view);
- superSuperView.BeginInit ();
- superSuperView.EndInit ();
- superSuperView.LayoutSubviews ();
- // Act
- var bounds = view.Viewport;
- // Assert
- Assert.Equal (expectedW, bounds.Width);
- }
- [Theory]
- [InlineData (0, 0)]
- [InlineData (1, 0)]
- [InlineData (0, 1)]
- [InlineData (-1, -1)]
- public void Set_Viewport_Location_Preserves_Size_And_Frame (int xOffset, int yOffset)
- {
- View view = new ()
- {
- Width = 10,
- Height = 10,
- ViewportSettings = ViewportSettings.AllowNegativeLocation
- };
- Assert.Equal (new Rectangle (0, 0, 10, 10), view.Frame);
- Rectangle testRect = new Rectangle (0, 0, 1, 1);
- Assert.Equal (new Point (0, 0), view.ViewportToScreen (testRect).Location);
- view.Viewport = view.Viewport with { Location = new Point (xOffset, yOffset) };
- Assert.Equal (new Rectangle (xOffset, yOffset, 10, 10), view.Viewport);
- Assert.Equal (new Rectangle (0, 0, 10, 10), view.Frame);
- }
- [Fact]
- public void Set_Viewport_Changes_Frame ()
- {
- var frame = new Rectangle (1, 2, 3, 4);
- var newViewport = new Rectangle (0, 0, 30, 40);
- var v = new View { Frame = frame };
- v.Viewport = newViewport;
- Assert.Equal (newViewport, v.Viewport);
- Assert.Equal (new Rectangle (1, 2, newViewport.Width, newViewport.Height), v.Frame);
- Assert.Equal (new Rectangle (0, 0, newViewport.Width, newViewport.Height), v.Viewport);
- Assert.Equal (Pos.Absolute (1), v.X);
- Assert.Equal (Pos.Absolute (2), v.Y);
- Assert.Equal (Dim.Absolute (30), v.Width);
- Assert.Equal (Dim.Absolute (40), v.Height);
- newViewport = new Rectangle (0, 0, 3, 4);
- v.Viewport = newViewport;
- Assert.Equal (newViewport, v.Viewport);
- Assert.Equal (new Rectangle (1, 2, newViewport.Width, newViewport.Height), v.Frame);
- Assert.Equal (new Rectangle (0, 0, newViewport.Width, newViewport.Height), v.Viewport);
- Assert.Equal (Pos.Absolute (1), v.X);
- Assert.Equal (Pos.Absolute (2), v.Y);
- Assert.Equal (Dim.Absolute (3), v.Width);
- Assert.Equal (Dim.Absolute (4), v.Height);
- v.BorderStyle = LineStyle.Single;
- // Viewport should shrink
- Assert.Equal (new Rectangle (0, 0, 1, 2), v.Viewport);
- // Frame should not change
- Assert.Equal (new Rectangle (1, 2, 3, 4), v.Frame);
- Assert.Equal (Pos.Absolute (1), v.X);
- Assert.Equal (Pos.Absolute (2), v.Y);
- Assert.Equal (Dim.Absolute (3), v.Width);
- Assert.Equal (Dim.Absolute (4), v.Height);
- // Now set bounds bigger as before
- newViewport = new Rectangle (0, 0, 3, 4);
- v.Viewport = newViewport;
- Assert.Equal (newViewport, v.Viewport);
- // Frame grows because there's now a border
- Assert.Equal (new Rectangle (1, 2, 5, 6), v.Frame);
- Assert.Equal (new Rectangle (0, 0, newViewport.Width, newViewport.Height), v.Viewport);
- Assert.Equal (Pos.Absolute (1), v.X);
- Assert.Equal (Pos.Absolute (2), v.Y);
- Assert.Equal (Dim.Absolute (5), v.Width);
- Assert.Equal (Dim.Absolute (6), v.Height);
- }
- [Theory]
- [InlineData (0, 0, 10, 10, 0, 0)]
- [InlineData (10, 0, 10, 10, 9, 0)] // 9 because without AllowGreaterThanContentWidth, the location is clamped to size - 1
- [InlineData (0, 10, 10, 10, 0, 9)]
- [InlineData (10, 10, 10, 10, 9, 9)]
- public void Set_Viewport_ValidValue_UpdatesViewport (int viewWidth, int viewHeight, int viewportX, int viewportY, int expectedX, int expectedY)
- {
- // Arrange
- var view = new View ()
- {
- Width = viewWidth,
- Height = viewHeight,
- };
- var newViewport = new Rectangle (viewportX, viewportY, viewWidth, viewHeight);
- // Act
- view.Viewport = newViewport;
- // Assert
- Assert.Equal (new Rectangle (expectedX, expectedY, viewWidth, viewHeight), view.Viewport);
- }
- [Theory]
- [CombinatorialData]
- public void Set_Viewport_ValidValue_UpdatesViewport_AllowLocationGreaterThanContentSize ([CombinatorialRange (0, 5)] int viewWidth, [CombinatorialRange (0, 5)] int viewHeight)
- {
- // Arrange
- var view = new View ()
- {
- Width = viewWidth,
- Height = viewHeight,
- ViewportSettings = ViewportSettings.AllowLocationGreaterThanContentSize
- };
- var newViewport = new Rectangle (10, 10, viewWidth, viewHeight);
- // Act
- view.Viewport = newViewport;
- // Assert
- Assert.Equal (new Rectangle (10, 10, viewWidth, viewHeight), view.Viewport);
- }
- [Fact]
- public void Set_Viewport_ValueGreaterThanContentSize_UpdatesViewportToContentSize ()
- {
- // Arrange
- var view = new View ();
- view.SetContentSize (new (100, 100));
- var newViewport = new Rectangle (0, 0, 200, 200);
- view.ViewportSettings = ViewportSettings.AllowLocationGreaterThanContentSize;
- // Act
- view.Viewport = newViewport;
- // Assert
- Assert.Equal (newViewport, view.Viewport);
- }
- [Fact]
- public void Set_Viewport_NegativeValue_AllowedBySettings ()
- {
- // Arrange
- var view = new View ();
- var newViewport = new Rectangle (-10, -10, 100, 100);
- view.ViewportSettings = ViewportSettings.AllowNegativeLocation;
- // Act
- view.Viewport = newViewport;
- // Assert
- Assert.Equal (newViewport, view.Viewport);
- }
- [Fact]
- public void Set_Viewport_NegativeValue_NotAllowedBySettings ()
- {
- // Arrange
- var view = new View ();
- var newViewport = new Rectangle (-10, -10, 100, 100);
- view.ViewportSettings = ViewportSettings.None;
- // Act
- view.Viewport = newViewport;
- // Assert
- Assert.Equal (new Rectangle (0, 0, 100, 100), view.Viewport);
- }
- [Theory]
- [InlineData (0, 0)]
- [InlineData (1, 1)]
- public void GetViewportOffset_Returns_Offset_From_Frame (int adornmentThickness, int expectedOffset)
- {
- View view = new ()
- {
- X = 1,
- Y = 1,
- Width = 10,
- Height = 10
- };
- view.BeginInit ();
- view.EndInit ();
- view.Margin.Thickness = new (adornmentThickness);
- Assert.Equal (expectedOffset, view.GetViewportOffsetFromFrame ().X);
- }
- [Fact]
- public void ContentSize_Tracks_ViewportSize_If_Not_Set ()
- {
- View view = new ()
- {
- Width = 1,
- Height = 1
- };
- Assert.True (view.ContentSizeTracksViewport);
- Assert.Equal (view.Viewport.Size, view.GetContentSize ());
- }
- [Fact]
- public void ContentSize_Ignores_ViewportSize_If_Set ()
- {
- View view = new ()
- {
- Width = 1,
- Height = 1,
- };
- view.SetContentSize (new Size (5, 5));
- Assert.False (view.ContentSizeTracksViewport);
- Assert.NotEqual (view.Viewport.Size, view.GetContentSize ());
- }
- [Fact]
- public void ContentSize_Tracks_ViewportSize_If_ContentSizeTracksViewport_Is_True ()
- {
- View view = new ()
- {
- Width = 1,
- Height = 1,
- };
- view.SetContentSize (new Size (5, 5));
- view.Viewport = new (0, 0, 10, 10);
- view.ContentSizeTracksViewport = true;
- Assert.Equal (view.Viewport.Size, view.GetContentSize ());
- }
- [Fact]
- public void ContentSize_Ignores_ViewportSize_If_ContentSizeTracksViewport_Is_False ()
- {
- View view = new ()
- {
- Width = 1,
- Height = 1,
- };
- view.SetContentSize (new Size (5, 5));
- view.Viewport = new (0, 0, 10, 10);
- view.ContentSizeTracksViewport = false;
- Assert.NotEqual (view.Viewport.Size, view.GetContentSize ());
- }
- //[Theory]
- //[InlineData (0, 0, true)]
- //[InlineData (-1, 0, true)]
- //[InlineData (0, -1, true)]
- //[InlineData (-1, -1, true)]
- //[InlineData (-2, -2, true)]
- //[InlineData (-3, -3, true)]
- //[InlineData (-4, -4, true)]
- //[InlineData (-5, -4, false)]
- //[InlineData (-4, -5, false)]
- //[InlineData (-5, -5, false)]
- //[InlineData (1, 1, true)]
- //[InlineData (2, 2, true)]
- //[InlineData (3, 3, true)]
- //[InlineData (4, 4, true)]
- //[InlineData (5, 4, false)]
- //[InlineData (4, 5, false)]
- //[InlineData (5, 5, false)]
- //public void IsVisibleInSuperView_No_Driver_No_SuperView (int x, int y, bool expected)
- //{
- // var view = new View { X = 1, Y = 1, Width = 5, Height = 5 };
- // Assert.True (view.IsVisibleInSuperView (x, y) == expected);
- //}
- //[Theory]
- //[InlineData (0, 0, true)]
- //[InlineData (-1, 0, true)]
- //[InlineData (0, -1, true)]
- //[InlineData (-1, -1, true)]
- //[InlineData (-2, -2, true)]
- //[InlineData (-3, -3, true)]
- //[InlineData (-4, -4, true)]
- //[InlineData (-5, -4, true)]
- //[InlineData (-4, -5, true)]
- //[InlineData (-5, -5, true)]
- //[InlineData (-6, -5, false)]
- //[InlineData (-5, -6, false)]
- //[InlineData (-6, -6, false)]
- //[InlineData (1, 1, true)]
- //[InlineData (2, 2, true)]
- //[InlineData (3, 3, true)]
- //[InlineData (4, 4, true)]
- //[InlineData (5, 4, true)]
- //[InlineData (4, 5, true)]
- //[InlineData (5, 5, true)]
- //[InlineData (6, 5, true)]
- //[InlineData (6, 6, true)]
- //[InlineData (7, 7, true)]
- //[InlineData (8, 8, true)]
- //[InlineData (9, 8, false)]
- //[InlineData (8, 9, false)]
- //[InlineData (9, 9, false)]
- //public void IsVisibleInSuperView_No_Driver_With_SuperView (int x, int y, bool expected)
- //{
- // var view = new View { X = 1, Y = 1, Width = 5, Height = 5 };
- // var top = new Toplevel { Width = 10, Height = 10 };
- // top.Add (view);
- // Assert.True (view.IsVisibleInSuperView (x, y) == expected);
- //}
- //[SetupFakeDriver]
- //[Theory]
- //[InlineData (0, 0, true)]
- //[InlineData (-1, 0, false)]
- //[InlineData (0, -1, false)]
- //[InlineData (-1, -1, false)]
- //[InlineData (1, 0, true)]
- //[InlineData (0, 1, true)]
- //[InlineData (1, 1, true)]
- //[InlineData (2, 2, true)]
- //[InlineData (3, 3, true)]
- //[InlineData (4, 4, true)]
- //[InlineData (5, 4, false)]
- //[InlineData (4, 5, false)]
- //[InlineData (5, 5, false)]
- //public void IsVisibleInSuperView_With_Driver (int x, int y, bool expected)
- //{
- // ((FakeDriver)Application.Driver).SetBufferSize (10, 10);
- // var view = new View { X = 1, Y = 1, Width = 5, Height = 5 };
- // var top = new Toplevel ();
- // top.Add (view);
- // Application.Begin (top);
- // Assert.True (view.IsVisibleInSuperView (x, y) == expected);
- // top.Dispose ();
- // Application.Shutdown ();
- //}
- }
|