mirror of
https://github.com/gui-cs/Terminal.Gui.git
synced 2026-01-01 00:46:39 +01:00
merged line canvas etc
This commit is contained in:
@@ -1,15 +1,19 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Reflection.Emit;
|
||||
using Xunit;
|
||||
using Xunit.Abstractions;
|
||||
using Rune = System.Rune;
|
||||
|
||||
namespace Terminal.Gui.CoreTests {
|
||||
public class BorderTests {
|
||||
[Fact]
|
||||
[AutoInitShutdown]
|
||||
readonly ITestOutputHelper output;
|
||||
|
||||
public BorderTests (ITestOutputHelper output)
|
||||
{
|
||||
this.output = output;
|
||||
}
|
||||
|
||||
[Fact, AutoInitShutdown]
|
||||
public void Constructor_Defaults ()
|
||||
{
|
||||
var b = new Border ();
|
||||
@@ -45,8 +49,7 @@ namespace Terminal.Gui.CoreTests {
|
||||
Assert.False (b.DrawMarginFrame);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
[AutoInitShutdown]
|
||||
[Fact, AutoInitShutdown]
|
||||
public void ActualWidth_ActualHeight ()
|
||||
{
|
||||
var v = new View (new Rect (5, 10, 60, 20), "", new Border ());
|
||||
@@ -81,8 +84,7 @@ namespace Terminal.Gui.CoreTests {
|
||||
Assert.Equal (new Thickness (5, 5, 5, 5), b.GetSumThickness ());
|
||||
}
|
||||
|
||||
[Fact]
|
||||
[AutoInitShutdown]
|
||||
[Fact, AutoInitShutdown]
|
||||
public void DrawContent_With_Child_Border ()
|
||||
{
|
||||
var top = Application.Top;
|
||||
@@ -303,8 +305,7 @@ namespace Terminal.Gui.CoreTests {
|
||||
}
|
||||
}
|
||||
|
||||
[Fact]
|
||||
[AutoInitShutdown]
|
||||
[Fact, AutoInitShutdown]
|
||||
public void DrawContent_With_Parent_Border ()
|
||||
{
|
||||
var top = Application.Top;
|
||||
@@ -540,8 +541,7 @@ namespace Terminal.Gui.CoreTests {
|
||||
}
|
||||
}
|
||||
|
||||
[Fact]
|
||||
[AutoInitShutdown]
|
||||
[Fact, AutoInitShutdown]
|
||||
public void BorderOnControlWithNoChildren ()
|
||||
{
|
||||
var label = new TextField ("Loading...") {
|
||||
@@ -557,5 +557,57 @@ namespace Terminal.Gui.CoreTests {
|
||||
|
||||
Assert.Null (Record.Exception (() => label.Redraw (label.Bounds)));
|
||||
}
|
||||
|
||||
[Fact, AutoInitShutdown]
|
||||
public void BorderStyle_And_DrawMarginFrame_Gets_Sets ()
|
||||
{
|
||||
var lblTop = new Label ("At 0,0");
|
||||
var lblFrame = new Label ("Centered") { X = Pos.Center (), Y = Pos.Center () };
|
||||
var frame = new FrameView () { Y = 1, Width = 20, Height = 3 };
|
||||
var lblFill = new Label () { Width = Dim.Fill(),Height = Dim.Fill(), Visible = false };
|
||||
var fillText = new System.Text.StringBuilder ();
|
||||
for (int i = 0; i < frame.Bounds.Height; i++) {
|
||||
if (i > 0) {
|
||||
fillText.AppendLine ("");
|
||||
}
|
||||
for (int j = 0; j < frame.Bounds.Width; j++) {
|
||||
fillText.Append ("█");
|
||||
}
|
||||
}
|
||||
lblFill.Text = fillText.ToString ();
|
||||
frame.Add (lblFill, lblFrame);
|
||||
var lblBottom = new Label ("At 0,4") { Y = 4 };
|
||||
Application.Top.Add (lblTop, frame, lblBottom);
|
||||
Application.Begin (Application.Top);
|
||||
|
||||
Assert.Equal (BorderStyle.Single, frame.Border.BorderStyle);
|
||||
Assert.True (frame.Border.DrawMarginFrame);
|
||||
TestHelpers.AssertDriverContentsWithFrameAre (@"
|
||||
At 0,0
|
||||
┌──────────────────┐
|
||||
│ Centered │
|
||||
└──────────────────┘
|
||||
At 0,4 ", output);
|
||||
|
||||
frame.Border.BorderStyle = BorderStyle.None;
|
||||
Application.Refresh ();
|
||||
Assert.True (frame.Border.DrawMarginFrame);
|
||||
TestHelpers.AssertDriverContentsWithFrameAre (@"
|
||||
At 0,0
|
||||
|
||||
Centered
|
||||
|
||||
At 0,4 ", output);
|
||||
|
||||
frame.Border.DrawMarginFrame = false;
|
||||
lblFill.Visible = true;
|
||||
Application.Refresh ();
|
||||
TestHelpers.AssertDriverContentsWithFrameAre (@"
|
||||
At 0,0
|
||||
████████████████████
|
||||
██████Centered██████
|
||||
████████████████████
|
||||
At 0,4 ", output);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +1,7 @@
|
||||
using Terminal.Gui.Graphs;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Text;
|
||||
using Terminal.Gui.Graphs;
|
||||
using Xunit;
|
||||
using Xunit.Abstractions;
|
||||
|
||||
@@ -157,34 +160,6 @@ namespace Terminal.Gui.CoreTests {
|
||||
TestHelpers.AssertDriverContentsAre (looksLike, output);
|
||||
}
|
||||
|
||||
[Fact, AutoInitShutdown]
|
||||
public void TestLineCanvas_ScreenCoords ()
|
||||
{
|
||||
var x = 3;
|
||||
var y = 5;
|
||||
var screenCanvas = new LineCanvas ();
|
||||
|
||||
// outer box
|
||||
screenCanvas.AddLine (new Point (x, y), 9, Orientation.Horizontal, BorderStyle.Single);
|
||||
screenCanvas.AddLine (new Point (x + 9, y + 0), 4, Orientation.Vertical, BorderStyle.Single);
|
||||
screenCanvas.AddLine (new Point (x + 9, y + 4), -9, Orientation.Horizontal, BorderStyle.Single);
|
||||
screenCanvas.AddLine (new Point (x + 0, y + 4), -4, Orientation.Vertical, BorderStyle.Single);
|
||||
|
||||
screenCanvas.AddLine (new Point (x + 5, y + 0), 4, Orientation.Vertical, BorderStyle.Single);
|
||||
screenCanvas.AddLine (new Point (x + 0, y + 2), 9, Orientation.Horizontal, BorderStyle.Single);
|
||||
|
||||
screenCanvas.Draw (null, new Rect (x, y, 10, 5));
|
||||
|
||||
string looksLike =
|
||||
@$"
|
||||
{new string ('\n', y)}{new string (' ', x)}┌────┬───┐
|
||||
{new string (' ', x)}│ │ │
|
||||
{new string (' ', x)}├────┼───┤
|
||||
{new string (' ', x)}│ │ │
|
||||
{new string (' ', x)}└────┴───┘";
|
||||
TestHelpers.AssertDriverContentsAre (looksLike, output);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Demonstrates when <see cref="BorderStyle.Rounded"/> corners are used. Notice how
|
||||
/// not all lines declare rounded. If there are 1+ lines intersecting and a corner is
|
||||
@@ -309,16 +284,60 @@ namespace Terminal.Gui.CoreTests {
|
||||
TestHelpers.AssertDriverContentsAre (looksLike, output);
|
||||
}
|
||||
|
||||
private View GetCanvas (out LineCanvas canvas, int x = 0, int y = 0)
|
||||
[Fact, AutoInitShutdown]
|
||||
public void TestLineCanvas_LeaveMargin_Top1_Left1 ()
|
||||
{
|
||||
// Draw at 1,1 within client area of View (i.e. leave a top and left margin of 1)
|
||||
var v = GetCanvas (out var canvas, 1, 1);
|
||||
|
||||
// outer box
|
||||
canvas.AddLine (new Point (0, 0), 8, Orientation.Horizontal, BorderStyle.Single);
|
||||
canvas.AddLine (new Point (8, 0), 3, Orientation.Vertical, BorderStyle.Single);
|
||||
canvas.AddLine (new Point (8, 3), -8, Orientation.Horizontal, BorderStyle.Single);
|
||||
canvas.AddLine (new Point (0, 3), -3, Orientation.Vertical, BorderStyle.Single);
|
||||
|
||||
|
||||
canvas.AddLine (new Point (5, 0), 3, Orientation.Vertical, BorderStyle.Single);
|
||||
canvas.AddLine (new Point (0, 2), 8, Orientation.Horizontal, BorderStyle.Single);
|
||||
|
||||
v.Redraw (v.Bounds);
|
||||
|
||||
string looksLike =
|
||||
@"
|
||||
┌────┬──┐
|
||||
│ │ │
|
||||
├────┼──┤
|
||||
└────┴──┘
|
||||
";
|
||||
TestHelpers.AssertDriverContentsAre (looksLike, output);
|
||||
}
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// Creates a new <see cref="View"/> into which a <see cref="LineCanvas"/> is rendered
|
||||
/// at <see cref="View.DrawContentComplete"/> time.
|
||||
/// </summary>
|
||||
/// <param name="canvas">The <see cref="LineCanvas"/> you can draw into.</param>
|
||||
/// <param name="offsetX">How far to offset drawing in X</param>
|
||||
/// <param name="offsetY">How far to offset drawing in Y</param>
|
||||
/// <returns></returns>
|
||||
private View GetCanvas (out LineCanvas canvas, int offsetX = 0, int offsetY = 0)
|
||||
{
|
||||
var v = new View {
|
||||
Width = 10,
|
||||
Height = 5,
|
||||
Bounds = new Rect (x, y, 10, 5)
|
||||
Bounds = new Rect (0, 0, 10, 5)
|
||||
};
|
||||
|
||||
var canvasCopy = canvas = new LineCanvas ();
|
||||
v.DrawContentComplete += (r) => canvasCopy.Draw (v, v.Bounds);
|
||||
v.DrawContentComplete += (r) => {
|
||||
foreach (var p in canvasCopy.GenerateImage (v.Bounds)) {
|
||||
v.AddRune (
|
||||
offsetX + p.Key.X,
|
||||
offsetY + p.Key.Y,
|
||||
p.Value);
|
||||
}
|
||||
};
|
||||
|
||||
return v;
|
||||
}
|
||||
|
||||
@@ -218,13 +218,13 @@ namespace Terminal.Gui.DriverTests {
|
||||
attr = new Attribute (Color.Red, Color.Green);
|
||||
Assert.True (attr.HasValidColors);
|
||||
|
||||
attr = new Attribute (Color.Red, Color.Invalid);
|
||||
attr = new Attribute (Color.Red, (Color)(-1));
|
||||
Assert.False (attr.HasValidColors);
|
||||
|
||||
attr = new Attribute (Color.Invalid, Color.Green);
|
||||
attr = new Attribute ((Color)(-1), Color.Green);
|
||||
Assert.False (attr.HasValidColors);
|
||||
|
||||
attr = new Attribute (Color.Invalid, Color.Invalid);
|
||||
attr = new Attribute ((Color)(-1), (Color)(-1));
|
||||
Assert.False (attr.HasValidColors);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -44,5 +44,34 @@ namespace Terminal.Gui.DriverTests {
|
||||
lbl.Redraw (lbl.Bounds);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void TestAllColors ()
|
||||
{
|
||||
var colors = System.Enum.GetValues (typeof (Color));
|
||||
Attribute [] attrs = new Attribute [colors.Length];
|
||||
|
||||
int idx = 0;
|
||||
foreach (Color bg in colors) {
|
||||
attrs [idx] = new Attribute (bg, colors.Length - 1 - bg);
|
||||
idx++;
|
||||
}
|
||||
Assert.Equal (16, attrs.Length);
|
||||
Assert.Equal (new Attribute (Color.Black, Color.White), attrs [0]);
|
||||
Assert.Equal (new Attribute (Color.Blue, Color.BrightYellow), attrs [1]);
|
||||
Assert.Equal (new Attribute (Color.Green, Color.BrightMagenta), attrs [2]);
|
||||
Assert.Equal (new Attribute (Color.Cyan, Color.BrightRed), attrs [3]);
|
||||
Assert.Equal (new Attribute (Color.Red, Color.BrightCyan), attrs [4]);
|
||||
Assert.Equal (new Attribute (Color.Magenta, Color.BrightGreen), attrs [5]);
|
||||
Assert.Equal (new Attribute (Color.Brown, Color.BrightBlue), attrs [6]);
|
||||
Assert.Equal (new Attribute (Color.Gray, Color.DarkGray), attrs [7]);
|
||||
Assert.Equal (new Attribute (Color.DarkGray, Color.Gray), attrs [8]);
|
||||
Assert.Equal (new Attribute (Color.BrightBlue, Color.Brown), attrs [9]);
|
||||
Assert.Equal (new Attribute (Color.BrightGreen, Color.Magenta), attrs [10]);
|
||||
Assert.Equal (new Attribute (Color.BrightCyan, Color.Red), attrs [11]);
|
||||
Assert.Equal (new Attribute (Color.BrightRed, Color.Cyan), attrs [12]);
|
||||
Assert.Equal (new Attribute (Color.BrightMagenta, Color.Green), attrs [13]);
|
||||
Assert.Equal (new Attribute (Color.BrightYellow, Color.Blue), attrs [14]);
|
||||
Assert.Equal (new Attribute (Color.White, Color.Black), attrs [^1]);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,8 +1,4 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using NStack;
|
||||
using Xunit;
|
||||
using Xunit.Abstractions;
|
||||
|
||||
@@ -280,5 +276,227 @@ namespace Terminal.Gui.ViewTests {
|
||||
◄░░░├─┤░►
|
||||
", output);
|
||||
}
|
||||
|
||||
[Fact, AutoInitShutdown]
|
||||
public void Frame_And_Labels_Does_Not_Overspill_ScrollView ()
|
||||
{
|
||||
var sv = new ScrollView {
|
||||
X = 3,
|
||||
Y = 3,
|
||||
Width = 10,
|
||||
Height = 10,
|
||||
ContentSize = new Size (50, 50)
|
||||
};
|
||||
for (int i = 0; i < 8; i++) {
|
||||
sv.Add (new CustomButton ("█", $"Button {i}", 20, 3) { Y = i * 3 });
|
||||
}
|
||||
Application.Top.Add (sv);
|
||||
Application.Begin (Application.Top);
|
||||
|
||||
TestHelpers.AssertDriverContentsWithFrameAre (@"
|
||||
█████████▲
|
||||
██████But┬
|
||||
█████████┴
|
||||
┌────────░
|
||||
│ But░
|
||||
└────────░
|
||||
┌────────░
|
||||
│ But░
|
||||
└────────▼
|
||||
◄├┤░░░░░► ", output);
|
||||
|
||||
sv.ContentOffset = new Point (5, 5);
|
||||
Application.Refresh ();
|
||||
TestHelpers.AssertDriverContentsWithFrameAre (@"
|
||||
─────────▲
|
||||
─────────┬
|
||||
Button 2│
|
||||
─────────┴
|
||||
─────────░
|
||||
Button 3░
|
||||
─────────░
|
||||
─────────░
|
||||
Button 4▼
|
||||
◄├─┤░░░░► ", output);
|
||||
}
|
||||
|
||||
private class CustomButton : FrameView {
|
||||
private Label labelFill;
|
||||
private Label labelText;
|
||||
|
||||
public CustomButton (string fill, ustring text, int width, int height)
|
||||
{
|
||||
Width = width;
|
||||
Height = height;
|
||||
labelFill = new Label () { AutoSize = false, Width = Dim.Fill (), Height = Dim.Fill (), Visible = false };
|
||||
var fillText = new System.Text.StringBuilder ();
|
||||
for (int i = 0; i < Bounds.Height; i++) {
|
||||
if (i > 0) {
|
||||
fillText.AppendLine ("");
|
||||
}
|
||||
for (int j = 0; j < Bounds.Width; j++) {
|
||||
fillText.Append (fill);
|
||||
}
|
||||
}
|
||||
labelFill.Text = fillText.ToString ();
|
||||
labelText = new Label (text) { X = Pos.Center (), Y = Pos.Center () };
|
||||
Add (labelFill, labelText);
|
||||
CanFocus = true;
|
||||
}
|
||||
|
||||
public override bool OnEnter (View view)
|
||||
{
|
||||
Border.BorderStyle = BorderStyle.None;
|
||||
Border.DrawMarginFrame = false;
|
||||
labelFill.Visible = true;
|
||||
view = this;
|
||||
return base.OnEnter (view);
|
||||
}
|
||||
|
||||
public override bool OnLeave (View view)
|
||||
{
|
||||
Border.BorderStyle = BorderStyle.Single;
|
||||
Border.DrawMarginFrame = true;
|
||||
labelFill.Visible = false;
|
||||
if (view == null)
|
||||
view = this;
|
||||
return base.OnLeave (view);
|
||||
}
|
||||
}
|
||||
|
||||
[Fact, AutoInitShutdown]
|
||||
public void Clear_Window_Inside_ScrollView ()
|
||||
{
|
||||
var topLabel = new Label ("At 15,0") { X = 15 };
|
||||
var sv = new ScrollView {
|
||||
X = 3,
|
||||
Y = 3,
|
||||
Width = 10,
|
||||
Height = 10,
|
||||
ContentSize = new Size (23, 23),
|
||||
KeepContentAlwaysInViewport = false
|
||||
};
|
||||
var bottomLabel = new Label ("At 15,15") { X = 15, Y = 15 };
|
||||
Application.Top.Add (topLabel, sv, bottomLabel);
|
||||
Application.Begin (Application.Top);
|
||||
|
||||
TestHelpers.AssertDriverContentsWithFrameAre (@"
|
||||
At 15,0
|
||||
|
||||
|
||||
▲
|
||||
┬
|
||||
┴
|
||||
░
|
||||
░
|
||||
░
|
||||
░
|
||||
░
|
||||
▼
|
||||
◄├┤░░░░░►
|
||||
|
||||
|
||||
At 15,15", output);
|
||||
|
||||
var attributes = new Attribute [] {
|
||||
Colors.TopLevel.Normal,
|
||||
Colors.TopLevel.Focus,
|
||||
Colors.Base.Normal
|
||||
};
|
||||
|
||||
TestHelpers.AssertDriverColorsAre (@"
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00011111111110000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000", attributes);
|
||||
|
||||
sv.Add (new Window ("1") { X = 3, Y = 3, Width = 20, Height = 20 });
|
||||
Application.Refresh ();
|
||||
TestHelpers.AssertDriverContentsWithFrameAre (@"
|
||||
At 15,0
|
||||
|
||||
|
||||
▲
|
||||
┬
|
||||
┴
|
||||
┌ 1 ──░
|
||||
│ ░
|
||||
│ ░
|
||||
│ ░
|
||||
│ ░
|
||||
│ ▼
|
||||
◄├┤░░░░░►
|
||||
|
||||
|
||||
At 15,15", output);
|
||||
|
||||
TestHelpers.AssertDriverColorsAre (@"
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000022222210000000000
|
||||
00000022222210000000000
|
||||
00000022222210000000000
|
||||
00000022222210000000000
|
||||
00000022222210000000000
|
||||
00000022222210000000000
|
||||
00011111111110000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000", attributes);
|
||||
|
||||
sv.ContentOffset = new Point (20, 20);
|
||||
Application.Refresh ();
|
||||
TestHelpers.AssertDriverContentsWithFrameAre (@"
|
||||
At 15,0
|
||||
|
||||
|
||||
│ ▲
|
||||
│ ░
|
||||
──┘ ░
|
||||
░
|
||||
░
|
||||
┬
|
||||
│
|
||||
┴
|
||||
▼
|
||||
◄░░░░├─┤►
|
||||
|
||||
|
||||
At 15,15", output);
|
||||
|
||||
TestHelpers.AssertDriverColorsAre (@"
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00022200000010000000000
|
||||
00022200000010000000000
|
||||
00022200000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00000000000010000000000
|
||||
00011111111110000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000
|
||||
00000000000000000000000", attributes);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
using System;
|
||||
using System.ComponentModel;
|
||||
using System.Linq;
|
||||
using Terminal.Gui;
|
||||
using Terminal.Gui.Graphs;
|
||||
using Xunit;
|
||||
using Xunit.Abstractions;
|
||||
@@ -60,7 +60,7 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_Vertical_Focused ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line);
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
|
||||
tileView.Redraw (tileView.Bounds);
|
||||
|
||||
@@ -100,7 +100,7 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_Vertical_Focused_WithBorder ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line, true);
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
|
||||
tileView.Redraw (tileView.Bounds);
|
||||
|
||||
@@ -141,9 +141,10 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_Vertical_Focused_50PercentSplit ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line);
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.SetSplitterPos (0, Pos.Percent (50));
|
||||
Assert.IsType<Pos.PosFactor> (tileView.SplitterDistances.ElementAt (0));
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
|
||||
tileView.Redraw (tileView.Bounds);
|
||||
|
||||
string looksLike =
|
||||
@@ -209,7 +210,7 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_Vertical_View1MinSize_Absolute ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line);
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
tileView.Tiles.ElementAt (0).MinSize = 6;
|
||||
|
||||
// distance is too small (below 6)
|
||||
@@ -254,7 +255,7 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_Vertical_View1MinSize_Absolute_WithBorder ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line, true);
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
tileView.Tiles.ElementAt (0).MinSize = 5;
|
||||
|
||||
// distance is too small (below 5)
|
||||
@@ -298,7 +299,7 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_Vertical_View2MinSize_Absolute ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line);
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
tileView.Tiles.ElementAt (1).MinSize = 6;
|
||||
|
||||
// distance leaves too little space for view2 (less than 6 would remain)
|
||||
@@ -342,7 +343,7 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_Vertical_View2MinSize_Absolute_WithBorder ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line, true);
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
tileView.Tiles.ElementAt (1).MinSize = 5;
|
||||
|
||||
// distance leaves too little space for view2 (less than 5 would remain)
|
||||
@@ -386,8 +387,6 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_InsertPanelAtStart ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line, true);
|
||||
SetInputFocusLine (tileView);
|
||||
|
||||
tileView.InsertTile (0);
|
||||
|
||||
tileView.Redraw (tileView.Bounds);
|
||||
@@ -405,8 +404,6 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_InsertPanelMiddle ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line, true);
|
||||
SetInputFocusLine (tileView);
|
||||
|
||||
tileView.InsertTile (1);
|
||||
|
||||
tileView.Redraw (tileView.Bounds);
|
||||
@@ -424,8 +421,6 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_InsertPanelAtEnd ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line, true);
|
||||
SetInputFocusLine (tileView);
|
||||
|
||||
tileView.InsertTile (2);
|
||||
|
||||
tileView.Redraw (tileView.Bounds);
|
||||
@@ -445,7 +440,9 @@ namespace Terminal.Gui.ViewTests {
|
||||
var tileView = Get11By3TileView (out var line);
|
||||
|
||||
tileView.Orientation = Terminal.Gui.Graphs.Orientation.Horizontal;
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
|
||||
Assert.True (line.HasFocus);
|
||||
|
||||
tileView.Redraw (tileView.Bounds);
|
||||
|
||||
@@ -485,9 +482,9 @@ namespace Terminal.Gui.ViewTests {
|
||||
public void TestTileView_Horizontal_View1MinSize_Absolute ()
|
||||
{
|
||||
var tileView = Get11By3TileView (out var line);
|
||||
tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
|
||||
|
||||
tileView.Orientation = Terminal.Gui.Graphs.Orientation.Horizontal;
|
||||
SetInputFocusLine (tileView);
|
||||
tileView.Tiles.ElementAt (0).MinSize = 1;
|
||||
|
||||
// 0 should not be allowed because it brings us below minimum size of View1
|
||||
@@ -2045,6 +2042,45 @@ namespace Terminal.Gui.ViewTests {
|
||||
|
||||
}
|
||||
|
||||
[Fact, AutoInitShutdown]
|
||||
public void Test_SplitTop_WholeBottom()
|
||||
{
|
||||
var tileView = new TileView (2) {
|
||||
Width = 20,
|
||||
Height = 10,
|
||||
Orientation = Orientation.Horizontal,
|
||||
};
|
||||
tileView.Border.BorderStyle = BorderStyle.Single;
|
||||
|
||||
Assert.True (tileView.TrySplitTile (0,2,out TileView top));
|
||||
|
||||
top.Tiles.ElementAt (0).ContentView.Add (new Label ("bleh"));
|
||||
top.Tiles.ElementAt (1).ContentView.Add (new Label ("blah"));
|
||||
|
||||
tileView.Tiles.ElementAt (1).ContentView.Add (new Label ("Hello"));
|
||||
tileView.ColorScheme = new ColorScheme ();
|
||||
top.ColorScheme = new ColorScheme ();
|
||||
tileView.LayoutSubviews ();
|
||||
|
||||
tileView.Redraw (tileView.Bounds);
|
||||
|
||||
string looksLike =
|
||||
@"
|
||||
┌─────────┬────────┐
|
||||
│bleh │blah │
|
||||
│ │ │
|
||||
│ │ │
|
||||
│ │ │
|
||||
├─────────┴────────┤
|
||||
│Hello │
|
||||
│ │
|
||||
│ │
|
||||
└──────────────────┘";
|
||||
|
||||
TestHelpers.AssertDriverContentsAre (looksLike, output);
|
||||
|
||||
}
|
||||
|
||||
[Fact, AutoInitShutdown]
|
||||
public void TestNestedContainer3RightAnd1Down_TitleDoesNotOverspill()
|
||||
{
|
||||
@@ -2094,7 +2130,86 @@ namespace Terminal.Gui.ViewTests {
|
||||
|
||||
TestHelpers.AssertDriverContentsAre (looksLike, output);
|
||||
}
|
||||
[Fact, AutoInitShutdown]
|
||||
public void TestDisposal_NoEarlyDisposalsOfUsersViews_DuringRebuildForTileCount ()
|
||||
{
|
||||
var tv = GetTileView (20, 10);
|
||||
|
||||
var myReusableView = new DisposeCounter ();
|
||||
|
||||
// I want my view in the first tile
|
||||
tv.Tiles.ElementAt (0).ContentView.Add (myReusableView);
|
||||
Assert.Equal (0, myReusableView.DisposalCount);
|
||||
|
||||
// I've changed my mind, I want 3 tiles now
|
||||
tv.RebuildForTileCount (3);
|
||||
|
||||
// but I still want my view in the first tile
|
||||
tv.Tiles.ElementAt (0).ContentView.Add (myReusableView);
|
||||
Assert.Multiple (
|
||||
() => Assert.Equal (0, myReusableView.DisposalCount)
|
||||
, () => {
|
||||
tv.Dispose ();
|
||||
Assert.Equal (1, myReusableView.DisposalCount);
|
||||
});
|
||||
}
|
||||
[Fact, AutoInitShutdown]
|
||||
public void TestDisposal_NoEarlyDisposalsOfUsersViews_DuringInsertTile ()
|
||||
{
|
||||
var tv = GetTileView (20, 10);
|
||||
|
||||
var myReusableView = new DisposeCounter ();
|
||||
|
||||
// I want my view in the first tile
|
||||
tv.Tiles.ElementAt (0).ContentView.Add (myReusableView);
|
||||
Assert.Equal (0, myReusableView.DisposalCount);
|
||||
|
||||
// I've changed my mind, I want 3 tiles now
|
||||
tv.InsertTile (0);
|
||||
tv.InsertTile (2);
|
||||
|
||||
// but I still want my view in the first tile
|
||||
tv.Tiles.ElementAt (0).ContentView.Add (myReusableView);
|
||||
Assert.Multiple (
|
||||
() => Assert.Equal (0, myReusableView.DisposalCount)
|
||||
, () => {
|
||||
tv.Dispose ();
|
||||
Assert.True (myReusableView.DisposalCount>=1);
|
||||
});
|
||||
}
|
||||
[Theory, AutoInitShutdown]
|
||||
[InlineData (0)]
|
||||
[InlineData (1)]
|
||||
public void TestDisposal_NoEarlyDisposalsOfUsersViews_DuringRemoveTile (int idx)
|
||||
{
|
||||
var tv = GetTileView (20, 10);
|
||||
|
||||
var myReusableView = new DisposeCounter ();
|
||||
|
||||
// I want my view in the first tile
|
||||
tv.Tiles.ElementAt (0).ContentView.Add (myReusableView);
|
||||
Assert.Equal (0, myReusableView.DisposalCount);
|
||||
|
||||
tv.RemoveTile (idx);
|
||||
|
||||
// but I still want my view in the first tile
|
||||
tv.Tiles.ElementAt (0).ContentView.Add (myReusableView);
|
||||
Assert.Multiple (
|
||||
() => Assert.Equal (0, myReusableView.DisposalCount)
|
||||
, () => {
|
||||
tv.Dispose ();
|
||||
Assert.True (myReusableView.DisposalCount >= 1);
|
||||
});
|
||||
}
|
||||
private class DisposeCounter : View {
|
||||
public int DisposalCount;
|
||||
protected override void Dispose (bool disposing)
|
||||
{
|
||||
DisposalCount++;
|
||||
base.Dispose (disposing);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates a vertical orientation root container with left pane split into
|
||||
@@ -2168,13 +2283,6 @@ namespace Terminal.Gui.ViewTests {
|
||||
return tileView.Subviews.OfType<LineView> ().Single ();
|
||||
}
|
||||
|
||||
private void SetInputFocusLine (TileView tileView)
|
||||
{
|
||||
var line = GetLine (tileView);
|
||||
line.SetFocus ();
|
||||
Assert.True (line.HasFocus);
|
||||
}
|
||||
|
||||
|
||||
private TileView Get5x1TilesView (bool border = true)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user