123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313 |
- using System;
- using System.ComponentModel;
- using System.Linq;
- using Xunit;
- using Xunit.Abstractions;
- namespace Terminal.Gui.ViewsTests {
- public class TileViewTests {
- readonly ITestOutputHelper output;
- public TileViewTests (ITestOutputHelper output)
- {
- this.output = output;
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical ()
- {
- var tileView = Get11By3TileView (out var line);
- tileView.Draw ();
- string looksLike =
- @"
- 11111│22222
- 11111│22222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Keyboard movement on splitter should have no effect if it is not focused
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical_WithBorder ()
- {
- var tileView = Get11By3TileView (out var line, true);
- tileView.Draw ();
- string looksLike =
- @"
- ┌────┬────┐
- │1111│2222│
- └────┴────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Keyboard movement on splitter should have no effect if it is not focused
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical_Focused ()
- {
- var tileView = Get11By3TileView (out var line);
- tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
- tileView.Draw ();
- string looksLike =
- @"
- 11111│22222
- 11111◊22222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Now while focused move the splitter 1 unit right
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.Draw ();
- looksLike =
- @"
- 111111│2222
- 111111◊2222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // and 2 to the left
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- tileView.Draw ();
- looksLike =
- @"
- 1111│222222
- 1111◊222222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical_Focused_WithBorder ()
- {
- var tileView = Get11By3TileView (out var line, true);
- tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
- tileView.Draw ();
- string looksLike =
- @"
- ┌────┬────┐
- │1111◊2222│
- └────┴────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Now while focused move the splitter 1 unit right
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.Draw ();
- looksLike =
- @"
- ┌─────┬───┐
- │11111◊222│
- └─────┴───┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // and 2 to the left
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- tileView.Draw ();
- looksLike =
- @"
- ┌───┬─────┐
- │111◊22222│
- └───┴─────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical_Focused_50PercentSplit ()
- {
- var tileView = Get11By3TileView (out var line);
- tileView.SetSplitterPos (0, Pos.Percent (50));
- Assert.IsType<Pos.PosFactor> (tileView.SplitterDistances.ElementAt (0));
- tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
- tileView.Draw ();
- string looksLike =
- @"
- 11111│22222
- 11111◊22222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Now while focused move the splitter 1 unit right
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.Draw ();
- looksLike =
- @"
- 111111│2222
- 111111◊2222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Even when moving the splitter location it should stay a Percentage based one
- Assert.IsType<Pos.PosFactor> (tileView.SplitterDistances.ElementAt (0));
- // and 2 to the left
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- tileView.Draw ();
- looksLike =
- @"
- 1111│222222
- 1111◊222222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Even when moving the splitter location it should stay a Percentage based one
- Assert.IsType<Pos.PosFactor> (tileView.SplitterDistances.ElementAt (0));
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Horizontal ()
- {
- var tileView = Get11By3TileView (out var line);
- tileView.Orientation = Orientation.Horizontal;
- tileView.Draw ();
- string looksLike =
- @"
- 11111111111
- ───────────
- 22222222222";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Keyboard movement on splitter should have no effect if it is not focused
- line.ProcessKey (new KeyEvent (Key.CursorDown, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical_View1MinSize_Absolute ()
- {
- var tileView = Get11By3TileView (out var line);
- tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
- tileView.Tiles.ElementAt (0).MinSize = 6;
- // distance is too small (below 6)
- Assert.False (tileView.SetSplitterPos (0, 2));
- // Should stay where it was originally at (50%)
- Assert.Equal (Pos.Percent (50), tileView.SplitterDistances.ElementAt (0));
- tileView.Draw ();
- // so should ignore the 2 distance and stick to 6
- string looksLike =
- @"
- 11111│22222
- 11111◊22222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Keyboard movement on splitter should have no effect because it
- // would take us below the minimum splitter size
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // but we can continue to move the splitter right if we want
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- looksLike =
- @"
- 111111│2222
- 111111◊2222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical_View1MinSize_Absolute_WithBorder ()
- {
- var tileView = Get11By3TileView (out var line, true);
- tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
- tileView.Tiles.ElementAt (0).MinSize = 5;
- // distance is too small (below 5)
- Assert.False (tileView.SetSplitterPos (0, 2));
- // Should stay where it was originally at (50%)
- Assert.Equal (Pos.Percent (50), tileView.SplitterDistances.ElementAt (0));
- tileView.Draw ();
- // so should ignore the 2 distance and stick to 5
- string looksLike =
- @"
- ┌────┬────┐
- │1111◊2222│
- └────┴────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Keyboard movement on splitter should have no effect because it
- // would take us below the minimum splitter size
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // but we can continue to move the splitter right if we want
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- looksLike =
- @"
- ┌─────┬───┐
- │11111◊222│
- └─────┴───┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical_View2MinSize_Absolute ()
- {
- var tileView = Get11By3TileView (out var line);
- 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)
- Assert.False (tileView.SetSplitterPos (0, 8));
- // Should stay where it was originally at (50%)
- Assert.Equal (Pos.Percent (50), tileView.SplitterDistances.ElementAt (0));
- tileView.Draw ();
- // so should ignore the 2 distance and stick to 6
- string looksLike =
- @"
- 11111│22222
- 11111◊22222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Keyboard movement on splitter should have no effect because it
- // would take us below the minimum splitter size
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // but we can continue to move the splitter left if we want
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- looksLike =
- @"
- 1111│222222
- 1111◊222222
- │ ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Vertical_View2MinSize_Absolute_WithBorder ()
- {
- var tileView = Get11By3TileView (out var line, true);
- 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)
- Assert.False (tileView.SetSplitterPos (0, 8));
- // Should stay where it was originally at (50%)
- Assert.Equal (Pos.Percent (50), tileView.SplitterDistances.ElementAt (0));
- tileView.Draw ();
- // so should ignore the 2 distance and stick to 6
- string looksLike =
- @"
- ┌────┬────┐
- │1111◊2222│
- └────┴────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Keyboard movement on splitter should have no effect because it
- // would take us below the minimum splitter size
- line.ProcessKey (new KeyEvent (Key.CursorRight, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // but we can continue to move the splitter left if we want
- line.ProcessKey (new KeyEvent (Key.CursorLeft, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- looksLike =
- @"
- ┌───┬─────┐
- │111◊22222│
- └───┴─────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_InsertPanelAtStart ()
- {
- var tileView = Get11By3TileView (out var line, true);
- tileView.InsertTile (0);
- tileView.Draw ();
- // so should ignore the 2 distance and stick to 6
- string looksLike =
- @"
- ┌──┬───┬──┐
- │ │111│22│
- └──┴───┴──┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_InsertPanelMiddle ()
- {
- var tileView = Get11By3TileView (out var line, true);
- tileView.InsertTile (1);
- tileView.Draw ();
- // so should ignore the 2 distance and stick to 6
- string looksLike =
- @"
- ┌──┬───┬──┐
- │11│ │22│
- └──┴───┴──┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_InsertPanelAtEnd ()
- {
- var tileView = Get11By3TileView (out var line, true);
- tileView.InsertTile (2);
- tileView.Draw ();
- // so should ignore the 2 distance and stick to 6
- string looksLike =
- @"
- ┌──┬───┬──┐
- │11│222│ │
- └──┴───┴──┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Horizontal_Focused ()
- {
- var tileView = Get11By3TileView (out var line);
- tileView.Orientation = Orientation.Horizontal;
- tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
- Assert.True (line.HasFocus);
- tileView.Draw ();
- string looksLike =
- @"
- 11111111111
- ─────◊─────
- 22222222222";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Now move splitter line down
- line.ProcessKey (new KeyEvent (Key.CursorDown, new KeyModifiers ()));
- tileView.Draw ();
- looksLike =
- @"
- 11111111111
- 11111111111
- ─────◊─────";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // And 2 up
- line.ProcessKey (new KeyEvent (Key.CursorUp, new KeyModifiers ()));
- line.ProcessKey (new KeyEvent (Key.CursorUp, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- looksLike =
- @"
- ─────◊─────
- 22222222222
- 22222222222";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_Horizontal_View1MinSize_Absolute ()
- {
- var tileView = Get11By3TileView (out var line);
- tileView.ProcessHotKey (new KeyEvent (tileView.ToggleResizable, new KeyModifiers ()));
- tileView.Orientation = Orientation.Horizontal;
- tileView.Tiles.ElementAt (0).MinSize = 1;
- // 0 should not be allowed because it brings us below minimum size of View1
- Assert.False (tileView.SetSplitterPos (0, 0));
- // position should remain where it was, at 50%
- Assert.Equal (Pos.Percent (50f), tileView.SplitterDistances.ElementAt (0));
- tileView.Draw ();
- string looksLike =
- @"
- 11111111111
- ─────◊─────
- 22222222222";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // Now move splitter line down (allowed
- line.ProcessKey (new KeyEvent (Key.CursorDown, new KeyModifiers ()));
- tileView.Draw ();
- looksLike =
- @"
- 11111111111
- 11111111111
- ─────◊─────";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // And up 2 (only 1 is allowed because of minimum size of 1 on view1)
- line.ProcessKey (new KeyEvent (Key.CursorUp, new KeyModifiers ()));
- line.ProcessKey (new KeyEvent (Key.CursorUp, new KeyModifiers ()));
- tileView.SetNeedsDisplay ();
- tileView.Draw ();
- looksLike =
- @"
- 11111111111
- ─────◊─────
- 22222222222";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTileView_CannotSetSplitterPosToFuncEtc ()
- {
- var tileView = Get11By3TileView ();
- var ex = Assert.Throws<ArgumentException> (() => tileView.SetSplitterPos (0, Pos.Right (tileView)));
- Assert.Equal ("Only Percent and Absolute values are supported. Passed value was PosCombine", ex.Message);
- ex = Assert.Throws<ArgumentException> (() => tileView.SetSplitterPos (0, Pos.Function (() => 1)));
- Assert.Equal ("Only Percent and Absolute values are supported. Passed value was PosFunc", ex.Message);
- // Also not allowed because this results in a PosCombine
- ex = Assert.Throws<ArgumentException> (() => tileView.SetSplitterPos (0, Pos.Percent (50) - 1));
- Assert.Equal ("Only Percent and Absolute values are supported. Passed value was PosCombine", ex.Message);
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer2LeftAnd1Right_RendersNicely ()
- {
- var tileView = GetNestedContainer2Left1Right (false);
- Assert.Equal (20, tileView.Frame.Width);
- Assert.Equal (10, tileView.Tiles.ElementAt (0).ContentView.Frame.Width);
- Assert.Equal (9, tileView.Tiles.ElementAt (1).ContentView.Frame.Width);
- Assert.IsType<TileView> (tileView.Tiles.ElementAt (0).ContentView);
- var left = (TileView)tileView.Tiles.ElementAt (0).ContentView;
- Assert.Same (left.SuperView, tileView);
- Assert.Equal (2, left.Tiles.ElementAt (0).ContentView.Subviews.Count);
- Assert.IsType<Label> (left.Tiles.ElementAt (0).ContentView.Subviews [0]);
- Assert.IsType<Label> (left.Tiles.ElementAt (0).ContentView.Subviews [1]);
- var onesTop = (Label)left.Tiles.ElementAt (0).ContentView.Subviews [0];
- var onesBottom = (Label)left.Tiles.ElementAt (0).ContentView.Subviews [1];
- Assert.Same (left.Tiles.ElementAt (0).ContentView, onesTop.SuperView);
- Assert.Same (left.Tiles.ElementAt (0).ContentView, onesBottom.SuperView);
- Assert.Equal (10, onesTop.Frame.Width);
- Assert.Equal (10, onesBottom.Frame.Width);
- tileView.Draw ();
- string looksLike =
- @"
- 1111111111│222222222
- 1111111111│222222222
- │
- │
- │
- ──────────┤
- │
- │
- │
- │";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer3RightAnd1Down_RendersNicely ()
- {
- var tileView = GetNestedContainer3Right1Down (false);
- tileView.Draw ();
- string looksLike =
- @"
- 111111│222222│333333
- 111111│222222│333333
- 111111│222222│333333
- 111111│222222│333333
- 111111│222222│333333
- 111111│222222├──────
- 111111│222222│444444
- 111111│222222│444444
- 111111│222222│444444
- 111111│222222│444444
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // It looks good but lets double check the measurements incase
- // anything is sticking out but drawn over
- // 3 panels + 2 splitters
- Assert.Equal (5, tileView.Subviews.Count);
- // Check X and Widths of Tiles
- Assert.Equal (0, tileView.Tiles.ElementAt (0).ContentView.Frame.X);
- Assert.Equal (6, tileView.Tiles.ElementAt (0).ContentView.Frame.Width);
- Assert.Equal (7, tileView.Tiles.ElementAt (1).ContentView.Frame.X);
- Assert.Equal (6, tileView.Tiles.ElementAt (1).ContentView.Frame.Width);
- Assert.Equal (14, tileView.Tiles.ElementAt (2).ContentView.Frame.X);
- Assert.Equal (6, tileView.Tiles.ElementAt (2).ContentView.Frame.Width);
- // Check Y and Heights of Tiles
- Assert.Equal (0, tileView.Tiles.ElementAt (0).ContentView.Frame.Y);
- Assert.Equal (10, tileView.Tiles.ElementAt (0).ContentView.Frame.Height);
- Assert.Equal (0, tileView.Tiles.ElementAt (1).ContentView.Frame.Y);
- Assert.Equal (10, tileView.Tiles.ElementAt (1).ContentView.Frame.Height);
- Assert.Equal (0, tileView.Tiles.ElementAt (2).ContentView.Frame.Y);
- Assert.Equal (10, tileView.Tiles.ElementAt (2).ContentView.Frame.Height);
- // Check Sub containers in last panel
- var subSplit = (TileView)tileView.Tiles.ElementAt (2).ContentView;
- Assert.Equal (0, subSplit.Tiles.ElementAt (0).ContentView.Frame.X);
- Assert.Equal (6, subSplit.Tiles.ElementAt (0).ContentView.Frame.Width);
- Assert.Equal (0, subSplit.Tiles.ElementAt (0).ContentView.Frame.Y);
- Assert.Equal (5, subSplit.Tiles.ElementAt (0).ContentView.Frame.Height);
- Assert.IsType<TextView> (subSplit.Tiles.ElementAt (0).ContentView.Subviews.Single ());
- Assert.Equal (0, subSplit.Tiles.ElementAt (1).ContentView.Frame.X);
- Assert.Equal (6, subSplit.Tiles.ElementAt (1).ContentView.Frame.Width);
- Assert.Equal (6, subSplit.Tiles.ElementAt (1).ContentView.Frame.Y);
- Assert.Equal (4, subSplit.Tiles.ElementAt (1).ContentView.Frame.Height);
- Assert.IsType<TextView> (subSplit.Tiles.ElementAt (1).ContentView.Subviews.Single ());
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer3RightAnd1Down_WithBorder_RendersNicely ()
- {
- var tileView = GetNestedContainer3Right1Down (true);
- tileView.Draw ();
- string looksLike =
- @"
- ┌─────┬──────┬─────┐
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222├─────┤
- │11111│222222│44444│
- │11111│222222│44444│
- │11111│222222│44444│
- └─────┴──────┴─────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // It looks good but lets double check the measurements incase
- // anything is sticking out but drawn over
- // 3 panels + 2 splitters
- Assert.Equal (5, tileView.Subviews.Count);
- // Check X and Widths of Tiles
- Assert.Equal (1, tileView.Tiles.ElementAt (0).ContentView.Frame.X);
- Assert.Equal (5, tileView.Tiles.ElementAt (0).ContentView.Frame.Width);
- Assert.Equal (7, tileView.Tiles.ElementAt (1).ContentView.Frame.X);
- Assert.Equal (6, tileView.Tiles.ElementAt (1).ContentView.Frame.Width);
- Assert.Equal (14, tileView.Tiles.ElementAt (2).ContentView.Frame.X);
- Assert.Equal (5, tileView.Tiles.ElementAt (2).ContentView.Frame.Width);
- // Check Y and Heights of Tiles
- Assert.Equal (1, tileView.Tiles.ElementAt (0).ContentView.Frame.Y);
- Assert.Equal (8, tileView.Tiles.ElementAt (0).ContentView.Frame.Height);
- Assert.Equal (1, tileView.Tiles.ElementAt (1).ContentView.Frame.Y);
- Assert.Equal (8, tileView.Tiles.ElementAt (1).ContentView.Frame.Height);
- Assert.Equal (1, tileView.Tiles.ElementAt (2).ContentView.Frame.Y);
- Assert.Equal (8, tileView.Tiles.ElementAt (2).ContentView.Frame.Height);
- // Check Sub containers in last panel
- var subSplit = (TileView)tileView.Tiles.ElementAt (2).ContentView;
- Assert.Equal (0, subSplit.Tiles.ElementAt (0).ContentView.Frame.X);
- Assert.Equal (5, subSplit.Tiles.ElementAt (0).ContentView.Frame.Width);
- Assert.Equal (0, subSplit.Tiles.ElementAt (0).ContentView.Frame.Y);
- Assert.Equal (4, subSplit.Tiles.ElementAt (0).ContentView.Frame.Height);
- Assert.IsType<TextView> (subSplit.Tiles.ElementAt (0).ContentView.Subviews.Single ());
- Assert.Equal (0, subSplit.Tiles.ElementAt (1).ContentView.Frame.X);
- Assert.Equal (5, subSplit.Tiles.ElementAt (1).ContentView.Frame.Width);
- Assert.Equal (5, subSplit.Tiles.ElementAt (1).ContentView.Frame.Y);
- Assert.Equal (3, subSplit.Tiles.ElementAt (1).ContentView.Frame.Height);
- Assert.IsType<TextView> (subSplit.Tiles.ElementAt (1).ContentView.Subviews.Single ());
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer3RightAnd1Down_WithTitledBorder_RendersNicely ()
- {
- var tileView = GetNestedContainer3Right1Down (true, true);
- tileView.Draw ();
- string looksLike =
- @"
- ┌ T1 ─┬ T2 ──┬ T3 ─┐
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222├ T4 ─┤
- │11111│222222│44444│
- │11111│222222│44444│
- │11111│222222│44444│
- └─────┴──────┴─────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer3RightAnd1Down_WithBorder_RemovingTiles ()
- {
- var tileView = GetNestedContainer3Right1Down (true);
- tileView.Draw ();
- string looksLike =
- @"
- ┌─────┬──────┬─────┐
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222├─────┤
- │11111│222222│44444│
- │11111│222222│44444│
- │11111│222222│44444│
- └─────┴──────┴─────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- var toRemove = tileView.Tiles.ElementAt (1);
- var removed = tileView.RemoveTile (1);
- Assert.Same (toRemove, removed);
- Assert.DoesNotContain (removed, tileView.Tiles);
- tileView.Draw ();
- looksLike =
- @"
- ┌─────────┬────────┐
- │111111111│33333333│
- │111111111│33333333│
- │111111111│33333333│
- │111111111│33333333│
- │111111111├────────┤
- │111111111│44444444│
- │111111111│44444444│
- │111111111│44444444│
- └─────────┴────────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // cannot remove at this index because there is only one horizontal tile left
- Assert.Null (tileView.RemoveTile (2));
- tileView.RemoveTile (0);
- tileView.Draw ();
- looksLike =
- @"
- ┌──────────────────┐
- │333333333333333333│
- │333333333333333333│
- │333333333333333333│
- │333333333333333333│
- ├──────────────────┤
- │444444444444444444│
- │444444444444444444│
- │444444444444444444│
- └──────────────────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- Assert.NotNull (tileView.RemoveTile (0));
- tileView.Draw ();
- looksLike =
- @"
- ┌──────────────────┐
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- └──────────────────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // cannot remove
- Assert.Null (tileView.RemoveTile (0));
- }
- [Theory, AutoInitShutdown]
- [InlineData (true)]
- [InlineData (false)]
- public void TestTileView_IndexOf (bool recursive)
- {
- var tv = new TileView ();
- var lbl1 = new Label ();
- var lbl2 = new Label ();
- var frame = new FrameView ();
- var sub = new Label ();
- frame.Add (sub);
- // IndexOf returns -1 when view not found
- Assert.Equal (-1, tv.IndexOf (lbl1, recursive));
- Assert.Equal (-1, tv.IndexOf (lbl2, recursive));
- // IndexOf supports looking for Tile.View
- Assert.Equal (0, tv.IndexOf (tv.Tiles.ElementAt (0).ContentView, recursive));
- Assert.Equal (1, tv.IndexOf (tv.Tiles.ElementAt (1).ContentView, recursive));
- // IndexOf supports looking for Tile.View.Subviews
- tv.Tiles.ElementAt (0).ContentView.Add (lbl1);
- Assert.Equal (0, tv.IndexOf (lbl1, recursive));
- tv.Tiles.ElementAt (1).ContentView.Add (lbl2);
- Assert.Equal (1, tv.IndexOf (lbl2, recursive));
- // IndexOf supports looking deep into subviews only when
- // the recursive true value is passed
- tv.Tiles.ElementAt (1).ContentView.Add (frame);
- if (recursive) {
- Assert.Equal (1, tv.IndexOf (sub, recursive));
- } else {
- Assert.Equal (-1, tv.IndexOf (sub, recursive));
- }
- }
- [Fact, AutoInitShutdown]
- public void TestNestedRoots_BothRoots_BothCanHaveBorders ()
- {
- var tv = new TileView {
- Width = 10,
- Height = 5,
- ColorScheme = new ColorScheme (),
- LineStyle = LineStyle.Single,
- };
- var tv2 = new TileView {
- Width = Dim.Fill (),
- Height = Dim.Fill (),
- ColorScheme = new ColorScheme (),
- LineStyle = LineStyle.Single,
- Orientation = Orientation.Horizontal
- };
- Assert.True (tv.IsRootTileView ());
- tv.Tiles.ElementAt (1).ContentView.Add (tv2);
- Application.Top.Add (tv);
- tv.BeginInit ();
- tv.EndInit ();
- tv.LayoutSubviews ();
- tv.LayoutSubviews ();
- tv.Tiles.ElementAt (1).ContentView.LayoutSubviews ();
- tv2.LayoutSubviews ();
- // tv2 is still considered a root because
- // it was manually created by API user. That
- // means it will not have its lines joined to
- // parents and it is permitted to have a border
- Assert.True (tv2.IsRootTileView ());
- tv.Draw ();
- var looksLike =
- @"
- ┌────┬───┐
- │ │┌─┐│
- │ │├─┤│
- │ │└─┘│
- └────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_MinSizes_VerticalSplitters_ResizeSplitter1 ()
- {
- var tv = Get5x1TilesView ();
- tv.Tiles.ElementAt (0).MinSize = int.MaxValue;
- tv.Draw ();
- var looksLike =
- @"
- ┌────┬────┬────┬────┬───┐
- │1111│2222│3333│4444│555│
- │ │ │ │ │ │
- └────┴────┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 0; x <= 5; x++) {
- // All these values would result in tile 0 getting smaller
- // so are not allowed (tile[0] has a min size of Int.Max)
- Assert.False (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- for (int x = 6; x < 10; x++) {
- // All these values would result in tile 0 getting bigger
- // so are allowed
- Assert.True (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- for (int x = 10; x < 100; x++) {
- // These values would result in the first splitter moving past
- // the second splitter so are not allowed
- Assert.False (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────────┬┬────┬────┬───┐
- │11111111││3333│4444│555│
- │ ││ │ │ │
- └────────┴┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_MinSizes_VerticalSplitters_ResizeSplitter1_NoBorder ()
- {
- var tv = Get5x1TilesView (false);
- tv.Tiles.ElementAt (0).MinSize = int.MaxValue;
- tv.Draw ();
- var looksLike =
- @"
- 11111│2222│3333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 0; x <= 5; x++) {
- // All these values would result in tile 0 getting smaller
- // so are not allowed (tile[0] has a min size of Int.Max)
- Assert.False (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- for (int x = 6; x < 10; x++) {
- // All these values would result in tile 0 getting bigger
- // so are allowed
- Assert.True (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- for (int x = 10; x < 100; x++) {
- // These values would result in the first splitter moving past
- // the second splitter so are not allowed
- Assert.False (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 111111111││3333│4444│5555
- ││ │ │
- ││ │ │
- ││ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_NoMinSizes_VerticalSplitters_ResizeSplitter1_CannotCrossBorder ()
- {
- var tv = Get5x1TilesView ();
- tv.Draw ();
- var looksLike =
- @"
- ┌────┬────┬────┬────┬───┐
- │1111│2222│3333│4444│555│
- │ │ │ │ │ │
- └────┴────┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 5; x > 0; x--) {
- Assert.True (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- Assert.False (tv.SetSplitterPos (0, 0));
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌┬────────┬────┬────┬───┐
- ││22222222│3333│4444│555│
- ││ │ │ │ │
- └┴────────┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 6; x < 10; x++) {
- Assert.True (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- for (int x = 10; x < 100; x++) {
- // These values would result in the first splitter moving past
- // the second splitter so are not allowed
- Assert.False (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────────┬┬────┬────┬───┐
- │11111111││3333│4444│555│
- │ ││ │ │ │
- └────────┴┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_NoMinSizes_VerticalSplitters_ResizeSplitter1_CannotCrossBorder_NoBorder ()
- {
- var tv = Get5x1TilesView (false);
- tv.Draw ();
- var looksLike =
- @"
- 11111│2222│3333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 5; x >= 0; x--) {
- Assert.True (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- │222222222│3333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 6; x < 10; x++) {
- Assert.True (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- for (int x = 10; x < 100; x++) {
- // These values would result in the first splitter moving past
- // the second splitter so are not allowed
- Assert.False (tv.SetSplitterPos (0, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 111111111││3333│4444│5555
- ││ │ │
- ││ │ │
- ││ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_NoMinSizes_VerticalSplitters_ResizeSplitter2_CannotMoveOverNeighbours ()
- {
- var tv = Get5x1TilesView ();
- tv.Draw ();
- var looksLike =
- @"
- ┌────┬────┬────┬────┬───┐
- │1111│2222│3333│4444│555│
- │ │ │ │ │ │
- └────┴────┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 10; x > 5; x--) {
- Assert.True (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- for (int x = 5; x > 0; x--) {
- Assert.False (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────┬┬────────┬────┬───┐
- │1111││33333333│4444│555│
- │ ││ │ │ │
- └────┴┴────────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 10; x < 15; x++) {
- Assert.True (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- for (int x = 15; x < 25; x++) {
- Assert.False (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────┬────────┬┬────┬───┐
- │1111│22222222││4444│555│
- │ │ ││ │ │
- └────┴────────┴┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_NoMinSizes_VerticalSplitters_ResizeSplitter2_CannotMoveOverNeighbours_NoBorder ()
- {
- var tv = Get5x1TilesView (false);
- tv.Draw ();
- var looksLike =
- @"
- 11111│2222│3333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 10; x > 5; x--) {
- Assert.True (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- for (int x = 5; x > 0; x--) {
- Assert.False (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 11111││33333333│4444│5555
- ││ │ │
- ││ │ │
- ││ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 10; x < 15; x++) {
- Assert.True (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- for (int x = 15; x < 25; x++) {
- Assert.False (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 11111│22222222││4444│5555
- │ ││ │
- │ ││ │
- │ ││ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_MinSizes_VerticalSplitters_ResizeSplitter2 ()
- {
- var tv = Get5x1TilesView ();
- tv.Tiles.ElementAt (1).MinSize = 2;
- tv.Tiles.ElementAt (2).MinSize = 3;
- tv.Draw ();
- var looksLike =
- @"
- ┌────┬────┬────┬────┬───┐
- │1111│2222│3333│4444│555│
- │ │ │ │ │ │
- └────┴────┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 10; x > 7; x--) {
- Assert.True (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- for (int x = 7; x > 0; x--) {
- Assert.False (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────┬──┬──────┬────┬───┐
- │1111│22│333333│4444│555│
- │ │ │ │ │ │
- └────┴──┴──────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 10; x < 12; x++) {
- Assert.True (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- for (int x = 12; x < 25; x++) {
- Assert.False (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────┬─────┬───┬────┬───┐
- │1111│22222│333│4444│555│
- │ │ │ │ │ │
- └────┴─────┴───┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_MinSizes_VerticalSplitters_ResizeSplitter2_NoBorder ()
- {
- var tv = Get5x1TilesView (false);
- tv.Tiles.ElementAt (1).MinSize = 2;
- tv.Tiles.ElementAt (2).MinSize = 3;
- tv.Draw ();
- var looksLike =
- @"
- 11111│2222│3333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 10; x > 7; x--) {
- Assert.True (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- for (int x = 7; x > 0; x--) {
- Assert.False (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 11111│22│333333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 10; x < 12; x++) {
- Assert.True (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- for (int x = 12; x < 25; x++) {
- Assert.False (tv.SetSplitterPos (1, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 11111│22222│333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_NoMinSizes_VerticalSplitters_ResizeSplitter4_CannotMoveOverNeighbours ()
- {
- var tv = Get5x1TilesView ();
- tv.Draw ();
- var looksLike =
- @"
- ┌────┬────┬────┬────┬───┐
- │1111│2222│3333│4444│555│
- │ │ │ │ │ │
- └────┴────┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 20; x > 15; x--) {
- Assert.True (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- for (int x = 15; x > 0; x--) {
- Assert.False (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────┬────┬────┬┬───────┐
- │1111│2222│3333││5555555│
- │ │ │ ││ │
- └────┴────┴────┴┴───────┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 20; x < 24; x++) {
- Assert.True (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- for (int x = 24; x < 100; x++) {
- Assert.False (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────┬────┬────┬───────┬┐
- │1111│2222│3333│4444444││
- │ │ │ │ ││
- └────┴────┴────┴───────┴┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_NoMinSizes_VerticalSplitters_ResizeSplitter4_CannotMoveOverNeighbours_NoBorder ()
- {
- var tv = Get5x1TilesView (false);
- tv.Draw ();
- var looksLike =
- @"
- 11111│2222│3333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 20; x > 15; x--) {
- Assert.True (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- for (int x = 15; x > 0; x--) {
- Assert.False (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 11111│2222│3333││55555555
- │ │ ││
- │ │ ││
- │ │ ││
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 20; x < 25; x++) {
- Assert.True (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- for (int x = 25; x < 100; x++) {
- Assert.False (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 11111│2222│3333│44444444│
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_MinSizes_VerticalSplitters_ResizeSplitter4 ()
- {
- var tv = Get5x1TilesView ();
- tv.Tiles.ElementAt (3).MinSize = 2;
- tv.Tiles.ElementAt (4).MinSize = 1;
- tv.Draw ();
- var looksLike =
- @"
- ┌────┬────┬────┬────┬───┐
- │1111│2222│3333│4444│555│
- │ │ │ │ │ │
- └────┴────┴────┴────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 20; x > 17; x--) {
- Assert.True (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- for (int x = 17; x > 0; x--) {
- Assert.False (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────┬────┬────┬──┬─────┐
- │1111│2222│3333│44│55555│
- │ │ │ │ │ │
- └────┴────┴────┴──┴─────┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 20; x < 23; x++) {
- Assert.True (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- for (int x = 23; x < 100; x++) {
- Assert.False (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- ┌────┬────┬────┬──────┬─┐
- │1111│2222│3333│444444│5│
- │ │ │ │ │ │
- └────┴────┴────┴──────┴─┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test5Panel_MinSizes_VerticalSplitters_ResizeSplitter4_NoBorder ()
- {
- var tv = Get5x1TilesView (false);
- tv.Tiles.ElementAt (3).MinSize = 2;
- tv.Tiles.ElementAt (4).MinSize = 1;
- tv.Draw ();
- var looksLike =
- @"
- 11111│2222│3333│4444│5555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 20; x > 17; x--) {
- Assert.True (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- for (int x = 17; x > 0; x--) {
- Assert.False (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 11111│2222│3333│44│555555
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- for (int x = 20; x < 24; x++) {
- Assert.True (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- for (int x = 24; x < 100; x++) {
- Assert.False (tv.SetSplitterPos (3, x), $"Assert failed for x={x}");
- }
- tv.SetNeedsDisplay ();
- tv.Draw ();
- looksLike =
- @"
- 11111│2222│3333│4444444│5
- │ │ │ │
- │ │ │ │
- │ │ │ │
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestNestedNonRoots_OnlyOneRoot_OnlyRootCanHaveBorders ()
- {
- var tv = new TileView {
- Width = 10,
- Height = 5,
- ColorScheme = new ColorScheme (),
- LineStyle = LineStyle.Single,
- };
- tv.TrySplitTile (1, 2, out var tv2);
- tv2.ColorScheme = new ColorScheme ();
- tv2.LineStyle = LineStyle.Single;
- tv2.Orientation = Orientation.Horizontal;
- Assert.True (tv.IsRootTileView ());
- Application.Top.Add (tv);
- tv.BeginInit ();
- tv.EndInit ();
- tv.LayoutSubviews ();
- tv.LayoutSubviews ();
- tv.Tiles.ElementAt (1).ContentView.LayoutSubviews ();
- tv2.LayoutSubviews ();
- // tv2 is not considered a root because
- // it was created via TrySplitTile so it
- // will have its lines joined to
- // parent and cannot have its own border
- Assert.False (tv2.IsRootTileView ());
- tv.Draw ();
- var looksLike =
- @"
- ┌────┬───┐
- │ │ │
- │ ├───┤
- │ │ │
- └────┴───┘
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestTrySplit_ShouldRetainTitle ()
- {
- var tv = new TileView ();
- tv.Tiles.ElementAt (0).Title = "flibble";
- tv.TrySplitTile (0, 2, out var subTileView);
- // We moved the content so the title should also have been moved
- Assert.Equal ("flibble", subTileView.Tiles.ElementAt (0).Title);
- // Secondly we should have cleared the old title (it should have been moved not copied)
- Assert.Empty (tv.Tiles.ElementAt (0).Title);
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer3RightAnd1Down_TileVisibility_WithBorder ()
- {
- var tileView = GetNestedContainer3Right1Down (true);
- tileView.Draw ();
- string looksLike =
- @"
- ┌─────┬──────┬─────┐
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222│33333│
- │11111│222222├─────┤
- │11111│222222│44444│
- │11111│222222│44444│
- │11111│222222│44444│
- └─────┴──────┴─────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- tileView.Tiles.ElementAt (0).ContentView.Visible = false;
- tileView.Tiles.ElementAt (1).ContentView.Visible = true;
- tileView.Tiles.ElementAt (2).ContentView.Visible = true;
- tileView.LayoutSubviews ();
- tileView.Draw ();
- looksLike =
- @"
- ┌────────────┬─────┐
- │222222222222│33333│
- │222222222222│33333│
- │222222222222│33333│
- │222222222222│33333│
- │222222222222├─────┤
- │222222222222│44444│
- │222222222222│44444│
- │222222222222│44444│
- └────────────┴─────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // BUGBUG: v2 - Something broke and I can't figure it out. Disabling for now.
- // tileView.Tiles.ElementAt (0).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = true;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //┌────────────┬─────┐
- //│111111111111│33333│
- //│111111111111│33333│
- //│111111111111│33333│
- //│111111111111│33333│
- //│111111111111├─────┤
- //│111111111111│44444│
- //│111111111111│44444│
- //│111111111111│44444│
- //└────────────┴─────┘";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // tileView.Tiles.ElementAt (0).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = false;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //┌─────┬────────────┐
- //│11111│222222222222│
- //│11111│222222222222│
- //│11111│222222222222│
- //│11111│222222222222│
- //│11111│222222222222│
- //│11111│222222222222│
- //│11111│222222222222│
- //│11111│222222222222│
- //└─────┴────────────┘";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // tileView.Tiles.ElementAt (0).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = false;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //┌──────────────────┐
- //│111111111111111111│
- //│111111111111111111│
- //│111111111111111111│
- //│111111111111111111│
- //│111111111111111111│
- //│111111111111111111│
- //│111111111111111111│
- //│111111111111111111│
- //└──────────────────┘";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // tileView.Tiles.ElementAt (0).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = false;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //┌──────────────────┐
- //│222222222222222222│
- //│222222222222222222│
- //│222222222222222222│
- //│222222222222222222│
- //│222222222222222222│
- //│222222222222222222│
- //│222222222222222222│
- //│222222222222222222│
- //└──────────────────┘";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- tileView.Tiles.ElementAt (0).ContentView.Visible = false;
- tileView.Tiles.ElementAt (1).ContentView.Visible = false;
- tileView.Tiles.ElementAt (2).ContentView.Visible = true;
- tileView.LayoutSubviews ();
- tileView.Draw ();
- looksLike =
- @"
- ┌──────────────────┐
- │333333333333333333│
- │333333333333333333│
- │333333333333333333│
- │333333333333333333│
- ├──────────────────┤
- │444444444444444444│
- │444444444444444444│
- │444444444444444444│
- └──────────────────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- tileView.Tiles.ElementAt (0).ContentView.Visible = false;
- tileView.Tiles.ElementAt (1).ContentView.Visible = false;
- tileView.Tiles.ElementAt (2).ContentView.Visible = false;
- tileView.LayoutSubviews ();
- tileView.Draw ();
- looksLike =
- @"
- ┌──────────────────┐
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- └──────────────────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer3RightAnd1Down_TileVisibility_WithoutBorder ()
- {
- var tileView = GetNestedContainer3Right1Down (false);
- tileView.Draw ();
- string looksLike =
- @"
- 111111│222222│333333
- 111111│222222│333333
- 111111│222222│333333
- 111111│222222│333333
- 111111│222222│333333
- 111111│222222├──────
- 111111│222222│444444
- 111111│222222│444444
- 111111│222222│444444
- 111111│222222│444444";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- tileView.Tiles.ElementAt (0).ContentView.Visible = false;
- tileView.Tiles.ElementAt (1).ContentView.Visible = true;
- tileView.Tiles.ElementAt (2).ContentView.Visible = true;
- tileView.LayoutSubviews ();
- tileView.Draw ();
- looksLike =
- @"
- 2222222222222│333333
- 2222222222222│333333
- 2222222222222│333333
- 2222222222222│333333
- 2222222222222│333333
- 2222222222222├──────
- 2222222222222│444444
- 2222222222222│444444
- 2222222222222│444444
- 2222222222222│444444";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- // BUGBUG: v2 - Something broke and I can't figure it out. Disabling for now.
- // tileView.Tiles.ElementAt (0).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = true;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //1111111111111│333333
- //1111111111111│333333
- //1111111111111│333333
- //1111111111111│333333
- //1111111111111│333333
- //1111111111111├──────
- //1111111111111│444444
- //1111111111111│444444
- //1111111111111│444444
- //1111111111111│444444";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // tileView.Tiles.ElementAt (0).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = false;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //111111│2222222222222
- //111111│2222222222222
- //111111│2222222222222
- //111111│2222222222222
- //111111│2222222222222
- //111111│2222222222222
- //111111│2222222222222
- //111111│2222222222222
- //111111│2222222222222
- //111111│2222222222222";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // tileView.Tiles.ElementAt (0).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = false;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //11111111111111111111
- //11111111111111111111
- //11111111111111111111
- //11111111111111111111
- //11111111111111111111
- //11111111111111111111
- //11111111111111111111
- //11111111111111111111
- //11111111111111111111
- //11111111111111111111";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // tileView.Tiles.ElementAt (0).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = true;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = false;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //22222222222222222222
- //22222222222222222222
- //22222222222222222222
- //22222222222222222222
- //22222222222222222222
- //22222222222222222222
- //22222222222222222222
- //22222222222222222222
- //22222222222222222222
- //22222222222222222222";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // tileView.Tiles.ElementAt (0).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = true;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- //33333333333333333333
- //33333333333333333333
- //33333333333333333333
- //33333333333333333333
- //33333333333333333333
- //────────────────────
- //44444444444444444444
- //44444444444444444444
- //44444444444444444444
- //44444444444444444444";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- // tileView.Tiles.ElementAt (0).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (1).ContentView.Visible = false;
- // tileView.Tiles.ElementAt (2).ContentView.Visible = false;
- // tileView.LayoutSubviews ();
- // tileView.Draw ();
- // looksLike =
- //@"
- // ";
- // TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void Test_SplitTop_WholeBottom ()
- {
- var tileView = new TileView (2) {
- Width = 20,
- Height = 10,
- Orientation = Orientation.Horizontal,
- LineStyle = LineStyle.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"));
- top.BeginInit ();
- top.EndInit ();
- top.LayoutSubviews ();
- tileView.Tiles.ElementAt (1).ContentView.Add (new Label ("Hello"));
- tileView.ColorScheme = new ColorScheme ();
- top.ColorScheme = new ColorScheme ();
- tileView.BeginInit ();
- tileView.EndInit ();
- tileView.LayoutSubviews ();
- tileView.Draw ();
- string looksLike =
- @"
- ┌─────────┬────────┐
- │bleh │blah │
- │ │ │
- │ │ │
- │ │ │
- ├─────────┴────────┤
- │Hello │
- │ │
- │ │
- └──────────────────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer3RightAnd1Down_TitleDoesNotOverspill ()
- {
- var tileView = GetNestedContainer3Right1Down (true, true, 1);
- tileView.Draw ();
- string looksLike =
- @"
- ┌ T1 ─┬ T3 ──┬ T2 ─┐
- │11111│333333│22222│
- │11111│333333│22222│
- │11111│333333│22222│
- │11111│333333│22222│
- │11111├ T4 ──┤22222│
- │11111│444444│22222│
- │11111│444444│22222│
- │11111│444444│22222│
- └─────┴──────┴─────┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestNestedContainer3RightAnd1Down_TitleTriesToOverspill ()
- {
- var tileView = GetNestedContainer3Right1Down (true, true, 1);
- tileView.Tiles.ElementAt (0).Title = new string ('x', 100);
- ((TileView)tileView.Tiles.ElementAt (1).ContentView)
- .Tiles.ElementAt (1).Title = new string ('y', 100);
- tileView.Draw ();
- string looksLike =
- @"
- ┌ xxxx┬ T3 ──┬ T2 ─┐
- │11111│333333│22222│
- │11111│333333│22222│
- │11111│333333│22222│
- │11111│333333│22222│
- │11111├ yyyyy┤22222│
- │11111│444444│22222│
- │11111│444444│22222│
- │11111│444444│22222│
- └─────┴──────┴─────┘";
- 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
- /// two (with horizontal splitter line).
- /// </summary>
- /// <param name="withBorder"></param>
- /// <returns></returns>
- private TileView GetNestedContainer2Left1Right (bool withBorder)
- {
- var container = GetTileView (20, 10, withBorder);
- Assert.True (container.TrySplitTile (0, 2, out var newContainer));
- newContainer.Orientation = Orientation.Horizontal;
- newContainer.ColorScheme = new ColorScheme ();
- container.ColorScheme = new ColorScheme ();
- container.LayoutSubviews ();
- return container;
- }
- /// <summary>
- /// Creates a vertical orientation root container with 3 tiles.
- /// The rightmost is split horizontally
- /// </summary>
- /// <param name="withBorder"></param>
- /// <returns></returns>
- private TileView GetNestedContainer3Right1Down (bool withBorder, bool withTitles = false, int split = 2)
- {
- var container = new TileView (3) {
- Width = 20,
- Height = 10
- };
- container.LineStyle = withBorder ? LineStyle.Single : LineStyle.None;
- Assert.True (container.TrySplitTile (split, 2, out var newContainer));
- newContainer.Orientation = Orientation.Horizontal;
- int i = 0;
- foreach (var tile in container.Tiles.Union (newContainer.Tiles)) {
- if (tile.ContentView is TileView) {
- continue;
- }
- i++;
- if (withTitles) {
- tile.Title = "T" + i;
- }
- tile.ContentView.Add (new TextView {
- Width = Dim.Fill (),
- Height = Dim.Fill (),
- Text =
- string.Join ('\n',
- Enumerable.Repeat (
- new string (i.ToString () [0], 100)
- , 10).ToArray ()),
- WordWrap = false
- });
- }
- newContainer.ColorScheme = new ColorScheme ();
- container.ColorScheme = new ColorScheme ();
- container.BeginInit ();
- container.EndInit ();
- container.LayoutSubviews ();
- return container;
- }
- private LineView GetLine (TileView tileView)
- {
- return tileView.Subviews.OfType<LineView> ().Single ();
- }
- private TileView Get5x1TilesView (bool border = true)
- {
- var tv = new TileView (5) {
- Width = 25,
- Height = 4,
- ColorScheme = new ColorScheme (),
- LineStyle = LineStyle.Single,
- };
- if (!border) {
- tv.LineStyle = LineStyle.None;
- }
- tv.Tiles.ElementAt (0).ContentView.Add (new Label (new string ('1', 100)) { AutoSize = false, Width = Dim.Fill (), Height = 1 });
- tv.Tiles.ElementAt (1).ContentView.Add (new Label (new string ('2', 100)) { AutoSize = false, Width = Dim.Fill (), Height = 1 });
- tv.Tiles.ElementAt (2).ContentView.Add (new Label (new string ('3', 100)) { AutoSize = false, Width = Dim.Fill (), Height = 1 });
- tv.Tiles.ElementAt (3).ContentView.Add (new Label (new string ('4', 100)) { AutoSize = false, Width = Dim.Fill (), Height = 1 });
- tv.Tiles.ElementAt (4).ContentView.Add (new Label (new string ('5', 100)) { AutoSize = false, Width = Dim.Fill (), Height = 1 });
- Application.Top.Add (tv);
- tv.BeginInit ();
- tv.EndInit ();
- tv.LayoutSubviews ();
- return tv;
- }
- private TileView Get11By3TileView (out LineView line, bool withBorder = false)
- {
- var split = Get11By3TileView (withBorder);
- line = GetLine (split);
- return split;
- }
- private TileView Get11By3TileView (bool withBorder = false)
- {
- return GetTileView (11, 3, withBorder);
- }
- private TileView GetTileView (int width, int height, bool withBorder = false)
- {
- var container = new TileView () {
- Width = width,
- Height = height,
- };
- container.LineStyle = withBorder ? LineStyle.Single : LineStyle.None;
- container.Tiles.ElementAt (0).ContentView.Add (new Label (new string ('1', 100)) { Width = Dim.Fill (), Height = 1, AutoSize = false });
- container.Tiles.ElementAt (0).ContentView.Add (new Label (new string ('1', 100)) { Width = Dim.Fill (), Height = 1, AutoSize = false, Y = 1 });
- container.Tiles.ElementAt (1).ContentView.Add (new Label (new string ('2', 100)) { Width = Dim.Fill (), Height = 1, AutoSize = false });
- container.Tiles.ElementAt (1).ContentView.Add (new Label (new string ('2', 100)) { Width = Dim.Fill (), Height = 1, AutoSize = false, Y = 1 });
- container.Tiles.ElementAt (0).MinSize = 0;
- container.Tiles.ElementAt (1).MinSize = 0;
- Application.Top.Add (container);
- container.ColorScheme = new ColorScheme ();
- container.BeginInit ();
- container.EndInit ();
- container.LayoutSubviews ();
- return container;
- }
- }
- }
|