123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635 |
- using System;
- using System.Reflection.Emit;
- using Xunit;
- using Xunit.Abstractions;
- using Rune = System.Rune;
- namespace Terminal.Gui.ViewTests {
- public class BorderTests {
- readonly ITestOutputHelper output;
- public BorderTests (ITestOutputHelper output)
- {
- this.output = output;
- }
- [Fact, AutoInitShutdown]
- public void Constructor_Defaults ()
- {
- var b = new Border ();
- Assert.Equal (BorderStyle.None, b.BorderStyle);
- Assert.False (b.DrawMarginFrame);
- Assert.Equal (Thickness.Empty, b.BorderThickness);
- Assert.Equal (Color.Black, b.ForgroundColor);
- Assert.Equal (Color.Black, b.BackgroundColor);
- Assert.Equal (Thickness.Empty, b.PaddingThickness);
- Assert.False (b.Effect3D);
- Assert.Equal (new Point (1, 1), b.Effect3DOffset);
- Assert.Null (b.Effect3DBrush);
- }
- //[Fact]
- //public void BorderStyle_Different_None_Ensures_DrawMarginFrame_To_True ()
- //{
- // var b = new Border () {
- // BorderStyle = BorderStyle.Single,
- // DrawMarginFrame = false
- // };
- // Assert.True (b.DrawMarginFrame);
- // b.BorderStyle = BorderStyle.None;
- // Assert.True (b.DrawMarginFrame);
- // b.DrawMarginFrame = false;
- // Assert.False (b.DrawMarginFrame);
- //}
- //[Fact, AutoInitShutdown]
- // public void ActualWidth_ActualHeight ()
- // {
- // var v = new View (new Rect (5, 10, 60, 20), "", new Border ());
- //[Fact]
- //public void ToplevelContainer_LayoutStyle_Computed_Constuctor_ ()
- //{
- // var tc = new Border.ToplevelContainer (new Border ());
- // Assert.Equal (LayoutStyle.Computed, tc.LayoutStyle);
- //}
- //[Fact]
- //public void ToplevelContainer_LayoutStyle_Absolute_Constuctor_ ()
- //{
- // var tc = new Border.ToplevelContainer (new Rect (1, 2, 3, 4), new Border ());
- // Assert.Equal (LayoutStyle.Absolute, tc.LayoutStyle);
- //}
- //[Fact]
- //public void GetSumThickness_Test ()
- //{
- // var b = new Border () {
- // BorderThickness = new Thickness (1, 2, 3, 4),
- // Padding = new Thickness (4, 3, 2, 1)
- // };
- // Assert.Equal (new Thickness (5, 5, 5, 5), b.GetSumThickness ());
- //}
- //[Fact]
- //[AutoInitShutdown]
- //public void DrawContent_With_Child_Border ()
- //{
- // var top = Application.Top;
- // var driver = (FakeDriver)Application.Driver;
- // [Fact]
- // [AutoInitShutdown]
- // public void DrawContent_With_Child_Border ()
- // {
- // var top = Application.Top;
- // var driver = (FakeDriver)Application.Driver;
- // top.LayoutSubviews ();
- // label.Redraw (label.Bounds);
- // var frame = label.Frame;
- // var drawMarginFrame = label.Border.DrawMarginFrame ? 1 : 0;
- // var sumThickness = label.Border.GetSumThickness ();
- // var padding = label.Border.Padding;
- // var effect3DOffset = label.Border.Effect3DOffset;
- // var borderStyle = label.Border.BorderStyle;
- // // Check the upper BorderThickness
- // for (int r = frame.Y - drawMarginFrame - sumThickness.Top;
- // r < frame.Y - drawMarginFrame - padding.Top; r++) {
- // for (int c = frame.X - drawMarginFrame - sumThickness.Left;
- // c < frame.Right + drawMarginFrame + sumThickness.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.Red, color.Background);
- // }
- // }
- // // Check the left BorderThickness
- // for (int r = frame.Y - drawMarginFrame - padding.Top;
- // r < frame.Bottom + drawMarginFrame + padding.Bottom; r++) {
- // for (int c = frame.X - drawMarginFrame - sumThickness.Left;
- // c < frame.X - drawMarginFrame - padding.Left; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.Red, color.Background);
- // }
- // }
- // // Check the right BorderThickness
- // for (int r = frame.Y - drawMarginFrame - padding.Top;
- // r < frame.Bottom + drawMarginFrame + padding.Bottom; r++) {
- // for (int c = frame.Right + drawMarginFrame + padding.Right;
- // c < frame.Right + drawMarginFrame - sumThickness.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.Red, color.Background);
- // }
- // }
- // // Check the lower BorderThickness
- // for (int r = frame.Bottom + drawMarginFrame + padding.Bottom;
- // r < frame.Bottom + drawMarginFrame + sumThickness.Bottom; r++) {
- // for (int c = frame.X - drawMarginFrame - sumThickness.Left;
- // c < frame.Right + drawMarginFrame + sumThickness.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.Red, color.Background);
- // }
- // }
- // // Check the upper Padding
- // for (int r = frame.Y - drawMarginFrame - padding.Top;
- // r < frame.Y - drawMarginFrame; r++) {
- // for (int c = frame.X - drawMarginFrame - padding.Left;
- // c < frame.Right + drawMarginFrame + padding.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.BrightGreen, color.Background);
- // }
- // }
- // // Check the left Padding
- // for (int r = frame.Y - drawMarginFrame;
- // r < frame.Bottom + drawMarginFrame; r++) {
- // for (int c = frame.X - drawMarginFrame - padding.Left;
- // c < frame.X - drawMarginFrame; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.BrightGreen, color.Background);
- // }
- // }
- // // Check the right Padding
- // for (int r = frame.Y - drawMarginFrame;
- // r < frame.Bottom + drawMarginFrame; r++) {
- // for (int c = frame.Right + drawMarginFrame;
- // c < frame.Right + drawMarginFrame - padding.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.BrightGreen, color.Background);
- // }
- // }
- // // Check the lower Padding
- // for (int r = frame.Bottom + drawMarginFrame;
- // r < frame.Bottom + drawMarginFrame + padding.Bottom; r++) {
- // for (int c = frame.X - drawMarginFrame - padding.Left;
- // c < frame.Right + drawMarginFrame + padding.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.BrightGreen, color.Background);
- // }
- // }
- // Rune hLine = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.HLine : (borderStyle == BorderStyle.Double ? driver.HDLine : ' ')) : ' ';
- // Rune vLine = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.VLine : (borderStyle == BorderStyle.Double ? driver.VDLine : ' ')) : ' ';
- // Rune uRCorner = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.URCorner : (borderStyle == BorderStyle.Double ? driver.URDCorner : ' ')) : ' ';
- // Rune uLCorner = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.ULCorner : (borderStyle == BorderStyle.Double ? driver.ULDCorner : ' ')) : ' ';
- // Rune lLCorner = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.LLCorner : (borderStyle == BorderStyle.Double ? driver.LLDCorner : ' ')) : ' ';
- // Rune lRCorner = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.LRCorner : (borderStyle == BorderStyle.Double ? driver.LRDCorner : ' ')) : ' ';
- // var text = "";
- // // Check the MarginFrame
- // for (int r = frame.Y - drawMarginFrame;
- // r < frame.Bottom + drawMarginFrame; r++) {
- // for (int c = frame.X - drawMarginFrame;
- // c <= frame.Right + drawMarginFrame - 1; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // var rune = (Rune)driver.Contents [r, c, 0];
- // Assert.Equal (Color.Black, color.Background);
- // if (c == frame.X - drawMarginFrame && r == frame.Y - drawMarginFrame) {
- // Assert.Equal (uLCorner, rune);
- // } else if (c == frame.Right && r == frame.Y - drawMarginFrame) {
- // Assert.Equal (uRCorner, rune);
- // } else if (c == frame.X - drawMarginFrame && r == frame.Bottom) {
- // Assert.Equal (lLCorner, rune);
- // } else if (c == frame.Right && r == frame.Bottom) {
- // Assert.Equal (lRCorner, rune);
- // } else if (c >= frame.X && (r == frame.Y - drawMarginFrame
- // || r == frame.Bottom)) {
- // Assert.Equal (hLine, rune);
- // } else if ((c == frame.X - drawMarginFrame || c == frame.Right)
- // && r >= frame.Y && r <= frame.Bottom - drawMarginFrame) {
- // Assert.Equal (vLine, rune);
- // } else {
- // text += rune.ToString ();
- // }
- // }
- // }
- // Assert.Equal ("This is a test", text.Trim ());
- // var color = (Attribute)driver.Contents [r, c, 1];
- // var rune = (Rune)driver.Contents [r, c, 0];
- // if (r == frame.Y - drawMarginFrame || r == frame.Bottom + drawMarginFrame - 1
- // || c == frame.X - drawMarginFrame || c == frame.Right + drawMarginFrame - 1) {
- // Assert.Equal (Color.BrightGreen, color.Background);
- // } else {
- // Assert.Equal (Color.Black, color.Background);
- // }
- // if (c == frame.X - drawMarginFrame && r == frame.Y - drawMarginFrame) {
- // Assert.Equal (uLCorner, rune);
- // } else if (c == frame.Right && r == frame.Y - drawMarginFrame) {
- // Assert.Equal (uRCorner, rune);
- // } else if (c == frame.X - drawMarginFrame && r == frame.Bottom) {
- // Assert.Equal (lLCorner, rune);
- // } else if (c == frame.Right && r == frame.Bottom) {
- // Assert.Equal (lRCorner, rune);
- // } else if (c >= frame.X && (r == frame.Y - drawMarginFrame
- // || r == frame.Bottom)) {
- // Assert.Equal (hLine, rune);
- // } else if ((c == frame.X - drawMarginFrame || c == frame.Right)
- // && r >= frame.Y && r <= frame.Bottom - drawMarginFrame) {
- // Assert.Equal (vLine, rune);
- // } else {
- // text += rune.ToString ();
- // }
- // }
- // }
- // Assert.Equal ("This is a test", text.Trim ());
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.DarkGray, color.Background);
- // }
- // }
- // // Check the left Effect3D
- // for (int r = frame.Y - drawMarginFrame - sumThickness.Top + effect3DOffset.Y;
- // r < frame.Bottom + drawMarginFrame + sumThickness.Bottom + effect3DOffset.Y; r++) {
- // for (int c = frame.X - drawMarginFrame - sumThickness.Left + effect3DOffset.X;
- // c < frame.X - drawMarginFrame - sumThickness.Left; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.DarkGray, color.Background);
- // }
- // }
- // // Check the right Effect3D
- // for (int r = frame.Y - drawMarginFrame - sumThickness.Top + effect3DOffset.Y;
- // r < frame.Bottom + drawMarginFrame + sumThickness.Bottom + effect3DOffset.Y; r++) {
- // for (int c = frame.Right + drawMarginFrame + sumThickness.Right;
- // c < frame.Right + drawMarginFrame + sumThickness.Right + effect3DOffset.X; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.DarkGray, color.Background);
- // }
- // }
- // // Check the lower Effect3D
- // for (int r = frame.Bottom + drawMarginFrame + sumThickness.Bottom;
- // r < frame.Bottom + drawMarginFrame + sumThickness.Bottom + effect3DOffset.Y; r++) {
- // for (int c = frame.X - drawMarginFrame - sumThickness.Left + effect3DOffset.X;
- // c < frame.Right + drawMarginFrame + sumThickness.Right + effect3DOffset.X; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.DarkGray, color.Background);
- // }
- // }
- // // Check the Child frame
- // for (int r = frame.Y; r < frame.Y + frame.Height; r++) {
- // for (int c = frame.X; c < frame.X + frame.Width; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.BrightGreen, color.Foreground);
- // Assert.Equal (Color.Black, color.Background);
- // }
- // }
- //}
- //[Fact]
- //[AutoInitShutdown]
- //public void DrawContent_With_Parent_Border ()
- //{
- // var top = Application.Top;
- // var driver = (FakeDriver)Application.Driver;
- // [Fact]
- // [AutoInitShutdown]
- // public void DrawContent_With_Parent_Border ()
- // {
- // var top = Application.Top;
- // var driver = (FakeDriver)Application.Driver;
- // top.LayoutSubviews ();
- // frameView.Redraw (frameView.Bounds);
- // var frame = frameView.Frame;
- // var drawMarginFrame = frameView.Border.DrawMarginFrame ? 1 : 0;
- // var borderThickness = frameView.Border.BorderThickness;
- // var padding = frameView.Border.Padding;
- // var effect3DOffset = frameView.Border.Effect3DOffset;
- // var borderStyle = frameView.Border.BorderStyle;
- // // Check the upper BorderThickness
- // for (int r = frame.Y;
- // r < Math.Min (frame.Y + borderThickness.Top, frame.Bottom); r++) {
- // for (int c = frame.X;
- // c < frame.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.Red, color.Background);
- // }
- // }
- // // Check the left BorderThickness
- // for (int r = Math.Min (frame.Y + borderThickness.Top, frame.Bottom);
- // r < frame.Bottom - borderThickness.Bottom; r++) {
- // for (int c = frame.X;
- // c < Math.Min (frame.X + borderThickness.Left, frame.Right); c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.Red, color.Background);
- // }
- // }
- // // Check the right BorderThickness
- // for (int r = Math.Min (frame.Y + borderThickness.Top, frame.Bottom);
- // r < frame.Bottom - borderThickness.Bottom; r++) {
- // for (int c = Math.Max (frame.Right - borderThickness.Right, frame.X);
- // c < frame.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.Red, color.Background);
- // }
- // }
- // // Check the lower BorderThickness
- // for (int r = Math.Max (frame.Bottom - borderThickness.Bottom, frame.Y);
- // r < frame.Bottom; r++) {
- // for (int c = frame.X;
- // c < frame.Right; c++) {
- // var color = (Attribute)driver.Contents [r, c, 1];
- // Assert.Equal (Color.Red, color.Background);
- // }
- // }
- // //TODO: Re-do padding tests
- // //// Check the upper Padding
- // //for (int r = frame.Y + borderThickness.Top;
- // // r < Math.Min (frame.Y + sumThickness.Top, frame.Bottom - borderThickness.Bottom); r++) {
- // // for (int c = frame.X + borderThickness.Left;
- // // c < frame.Right - borderThickness.Right; c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.BrightGreen, color.Background);
- // // }
- // //}
- // //// Check the left Padding
- // //for (int r = frame.Y + sumThickness.Top;
- // // r < frame.Bottom - sumThickness.Bottom; r++) {
- // // for (int c = frame.X + borderThickness.Left;
- // // c < Math.Min (frame.X + sumThickness.Left, frame.Right - borderThickness.Right); c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.BrightGreen, color.Background);
- // // }
- // //}
- // //// Check the right Padding
- // //// Draw the right Padding
- // //for (int r = frame.Y + sumThickness.Top;
- // // r < frame.Bottom - sumThickness.Bottom; r++) {
- // // for (int c = Math.Max (frame.Right - sumThickness.Right, frame.X + sumThickness.Left);
- // // c < Math.Max (frame.Right - borderThickness.Right, frame.X + sumThickness.Left); c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.BrightGreen, color.Background);
- // // }
- // //}
- // //// Check the lower Padding
- // //for (int r = Math.Max (frame.Bottom - sumThickness.Bottom, frame.Y + borderThickness.Top);
- // // r < frame.Bottom - borderThickness.Bottom; r++) {
- // // for (int c = frame.X + borderThickness.Left;
- // // c < frame.Right - borderThickness.Right; c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.BrightGreen, color.Background);
- // // }
- // //}
- // Rune hLine = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.HLine : (borderStyle == BorderStyle.Double ? driver.HDLine : ' ')) : ' ';
- // Rune vLine = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.VLine : (borderStyle == BorderStyle.Double ? driver.VDLine : ' ')) : ' ';
- // Rune uRCorner = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.URCorner : (borderStyle == BorderStyle.Double ? driver.URDCorner : ' ')) : ' ';
- // Rune uLCorner = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.ULCorner : (borderStyle == BorderStyle.Double ? driver.ULDCorner : ' ')) : ' ';
- // Rune lLCorner = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.LLCorner : (borderStyle == BorderStyle.Double ? driver.LLDCorner : ' ')) : ' ';
- // Rune lRCorner = drawMarginFrame > 0 ? (borderStyle == BorderStyle.Single
- // ? driver.LRCorner : (borderStyle == BorderStyle.Double ? driver.LRDCorner : ' ')) : ' ';
- // // TODO: redo margin tests
-
- // //var text = "";
- // //// Check the MarginFrame
- // //for (int r = frame.Y + sumThickness.Top;
- // // r < frame.Bottom - sumThickness.Bottom; r++) {
- // // for (int c = frame.X + sumThickness.Left;
- // // c <= frame.Right - sumThickness.Right - 1; c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // var rune = (Rune)driver.Contents [r, c, 0];
- // // Assert.Equal (Color.Black, color.Background);
- // // if (c == frame.X + sumThickness.Left && r == frame.Y + sumThickness.Top) {
- // // Assert.Equal (uLCorner, rune);
- // // } else if (c == frame.Right - drawMarginFrame - sumThickness.Right
- // // && r == frame.Y + sumThickness.Top) {
- // // Assert.Equal (uRCorner, rune);
- // // } else if (c == frame.X + sumThickness.Left
- // // && r == frame.Bottom - drawMarginFrame - sumThickness.Bottom) {
- // // Assert.Equal (lLCorner, rune);
- // // } else if (c == frame.Right - drawMarginFrame - sumThickness.Right
- // // && r == frame.Bottom - drawMarginFrame - sumThickness.Bottom) {
- // // Assert.Equal (lRCorner, rune);
- // // } else if (c > frame.X + sumThickness.Left
- // // && (r == frame.Y + sumThickness.Top
- // // || r == frame.Bottom - drawMarginFrame - sumThickness.Bottom)) {
- // // Assert.Equal (hLine, rune);
- // // } else if ((c == frame.X + sumThickness.Left
- // // || c == frame.Right - drawMarginFrame - sumThickness.Right)
- // // && r >= frame.Y + drawMarginFrame + sumThickness.Top) {
- // // Assert.Equal (vLine, rune);
- // // } else {
- // // text += rune.ToString ();
- // // }
- // // }
- // //}
- // //Assert.Equal ("This is a test", text.Trim ());
- // var color = (Attribute)driver.Contents [r, c, 1];
- // var rune = (Rune)driver.Contents [r, c, 0];
- // Assert.Equal (Color.Black, color.Background);
- // if (c == frame.X + sumThickness.Left && r == frame.Y + sumThickness.Top) {
- // Assert.Equal (uLCorner, rune);
- // } else if (c == frame.Right - drawMarginFrame - sumThickness.Right
- // && r == frame.Y + sumThickness.Top) {
- // Assert.Equal (uRCorner, rune);
- // } else if (c == frame.X + sumThickness.Left
- // && r == frame.Bottom - drawMarginFrame - sumThickness.Bottom) {
- // Assert.Equal (lLCorner, rune);
- // } else if (c == frame.Right - drawMarginFrame - sumThickness.Right
- // && r == frame.Bottom - drawMarginFrame - sumThickness.Bottom) {
- // Assert.Equal (lRCorner, rune);
- // } else if (c > frame.X + sumThickness.Left
- // && (r == frame.Y + sumThickness.Top
- // || r == frame.Bottom - drawMarginFrame - sumThickness.Bottom)) {
- // Assert.Equal (hLine, rune);
- // } else if ((c == frame.X + sumThickness.Left
- // || c == frame.Right - drawMarginFrame - sumThickness.Right)
- // && r >= frame.Y + drawMarginFrame + sumThickness.Top) {
- // Assert.Equal (vLine, rune);
- // } else {
- // text += rune.ToString ();
- // }
- // }
- // }
- // Assert.Equal ("This is a test", text.Trim ());
- // // Check the upper Effect3D
- // for (int r = frame.Y + effect3DOffset.Y;
- // r < frame.Y; r++) {
- // for (int c = frame.X + effect3DOffset.X;
- // c < frame.Right + effect3DOffset.X; c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.DarkGray, color.Background);
- // // }
- // //}
- // //// Check the left Effect3D
- // //for (int r = frame.Y + effect3DOffset.Y;
- // // r < frame.Bottom + effect3DOffset.Y; r++) {
- // // for (int c = frame.X + effect3DOffset.X;
- // // c < frame.X; c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.DarkGray, color.Background);
- // // }
- // //}
- // //// Check the right Effect3D
- // //for (int r = frame.Y + effect3DOffset.Y;
- // // r < frame.Bottom + effect3DOffset.Y; r++) {
- // // for (int c = frame.Right;
- // // c < frame.Right + effect3DOffset.X; c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.DarkGray, color.Background);
- // // }
- // //}
- // //// Check the lower Effect3D
- // //for (int r = frame.Bottom;
- // // r < frame.Bottom + effect3DOffset.Y; r++) {
- // // for (int c = frame.X + effect3DOffset.X;
- // // c < frame.Right + effect3DOffset.X; c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.DarkGray, color.Background);
- // // }
- // //}
- // //// Check the Child frame
- // //for (int r = frame.Y + drawMarginFrame + sumThickness.Top;
- // // r < frame.Bottom - drawMarginFrame - sumThickness.Bottom; r++) {
- // // for (int c = frame.X + drawMarginFrame + sumThickness.Left;
- // // c < frame.Right - drawMarginFrame - sumThickness.Right; c++) {
- // // var color = (Attribute)driver.Contents [r, c, 1];
- // // Assert.Equal (Color.BrightGreen, color.Foreground);
- // // Assert.Equal (Color.Black, color.Background);
- // // }
- // //}
- //}
- [Fact, AutoInitShutdown]
- public void BorderOnControlWithNoChildren ()
- {
- var label = new TextField ("Loading...") {
- Border = new Border () {
- BorderStyle = BorderStyle.Single,
- DrawMarginFrame = true,
- PaddingThickness = new Thickness (1),
- ForgroundColor = Color.White
- }
- };
- Application.Top.Add (label);
- 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);
- //}
- }
- }
|