Files
Terminal.Gui/Tests/UnitTestsParallelizable/Drawing/Region/DifferenceTests.cs
Tig b0f32811eb Fixes #3930 - Splits tests to Tests/UnitTests, Tests/IntegrationTests, Tests/StressTests (#3954)
* Tons of API doc updates

* Removed stale test

* Removed stale tests

* Fixed Skipped Shadow test 1

* Fixed Skipped Shadow test 2

* Fixed Skipped Shadow test 3

* Removed stale test

* Removed stale test2

* Explicit unregister of event handler on Application.Driver!.ClearedContents

* Added Toplevels to dict

* code cleanup

* spelling error

* Removed stale test3

* Removed stale test4

* Removed stale test5

* added script

* tweaked script

* tweaked script

* Created StressTests project; moved some tests

* Created IntegrationTests project; moved some tests

* New yml

* made old yml just unit tests

* Tweaked Button_IsDefault_Raises_Accepted_Correctly

* tweaked script

* cleaned up ymls

* tweakled up ymls

* stress tests...

* stress tests on ubuntu only

* Fixed WindowsDriver in InvokeLeakTest

* Fixed WindowsDriver in InvokeLeakTest2

* Added Directory.Packages.props.
Added Directory.Build.props

* Shortened StressTest time

* Removed dupe file.

* DemoFiles

* Moved all tests to ./Tests dir.

* Fixed release build issue

* Fixed .sln file

* Fixed .sl* files

* Fixing ymls

* Fixing interation tests

* Create link to the file TestHelpers.

* Created Tests/UnitTestsParallelizable.
Moved all obviously parallelizable tests.
Updated yml.

* fixing logs

* fixing logs2

* fixing logs3

* don't require stress to pass for PRs

* Fix a failure?

* tweaked script

* Coudl this be it?

* Moved tons of tests to parallelizable

* Fixed some stuff

* Script to find duplicate tests

* Testing workflows

* Updated to v4

* Fix RelativeBasePath issue

* Replace powershell to pwsh

* Add ignore projects.

* Removed dupe unit tests

* Code cleanup of tests

* Cleaned up test warnings

* yml tweak

* Moved setter

* tweak ymls

* just randomly throwing spaghetti at a wall

* Enable runing 5 test runners in par

* Turned off DEBUG_DISPOSABLE for par tests

* RunningUnitTests=true

* code cleanup (forcing more Action runs)

* DISABLE_DEBUG_IDISPOSABLE

* Added View.DebugIDisposable. False by default.

* Remobed bogus tareet

* Remobed bogus tareet2

* fixed warning

* added api doc

* fixed warning

* fixed warning

* fixed warning2

* fixed warning3

* fixed warning4

---------

Co-authored-by: BDisp <bd.bdisp@gmail.com>
2025-03-05 23:44:27 -07:00

166 lines
4.4 KiB
C#

using Xunit.Sdk;
namespace Terminal.Gui.DrawingTests;
public class DifferenceTests
{
[Fact]
public void Difference_Rectangle_ExcludesFromRegion ()
{
var region = new Region (new (10, 10, 50, 50));
region.Combine (new Rectangle (20, 20, 20, 20), RegionOp.Difference);
Assert.False (region.Contains (25, 25));
Assert.True (region.Contains (15, 15));
}
[Fact]
public void Difference_Region_ExcludesRegions ()
{
var region1 = new Region (new (10, 10, 50, 50));
var region2 = new Region (new (20, 20, 20, 20));
region1.Combine (region2, RegionOp.Difference);
Assert.False (region1.Contains (25, 25));
Assert.True (region1.Contains (15, 15));
}
[Fact]
public void Difference_WithRectangle_ExcludesRectangle ()
{
var region = new Region (new (10, 10, 50, 50));
var rect = new Rectangle (30, 30, 50, 50);
region.Combine (rect, RegionOp.Difference);
Assert.True (region.Contains (20, 20));
Assert.False (region.Contains (35, 35));
}
[Fact]
public void Difference_WithRegion_ExcludesRegion ()
{
var region1 = new Region (new (10, 10, 50, 50));
var region2 = new Region (new (30, 30, 50, 50));
region1.Combine (region2, RegionOp.Difference);
Assert.True (region1.Contains (20, 20));
Assert.False (region1.Contains (35, 35));
}
[Fact]
public void Difference_ContainedRectangle_ExcludesRectangle ()
{
/*
INPUT: (top-left origin, x→, y↓):
x=0 1 2 3 4 5
y=0 A A A A A A
y=1 A A A A A A
y=2 A A B B A A
y=3 A A B B A A
y=4 A A A A A A
y=5 A A A A A A
*/
var regionA = new Region (new (0, 0, 6, 6));
var rectangleB = new Rectangle (2, 2, 2, 2);
regionA.Combine (rectangleB, RegionOp.Difference);
Assert.True (regionA.Contains (0, 0));
Assert.True (regionA.Contains (1, 1));
Assert.True (regionA.Contains (4, 4));
Assert.True (regionA.Contains (5, 5));
Assert.False (regionA.Contains (2, 2));
Assert.False (regionA.Contains (3, 3));
}
[Fact]
public void Difference_ContainedRegion_ExcludesRegion ()
{
/*
INPUT: (top-left origin, x→, y↓):
x=0 1 2 3 4 5
y=0 A A A A A A
y=1 A A A A A A
y=2 A A B B A A
y=3 A A B B A A
y=4 A A A A A A
y=5 A A A A A A
*/
var regionA = new Region (new (0, 0, 6, 6));
var regionB = new Region (new (2, 2, 2, 2));
regionA.Combine (regionB, RegionOp.Difference);
Assert.True (regionA.Contains (0, 0));
Assert.True (regionA.Contains (1, 1));
Assert.True (regionA.Contains (4, 4));
Assert.True (regionA.Contains (5, 5));
Assert.False (regionA.Contains (2, 2));
Assert.False (regionA.Contains (3, 3));
}
[Fact]
public void Difference_NonRectangularRegion_ExcludesRegion ()
{
/*
INPUT: (top-left origin, x→, y↓):
x=0 1 2 3 4 5
y=0 A A A A A A
y=1 A A A A A A
y=2 A A B B A A
y=3 A A B A A A
y=4 A A A A A A
y=5 A A A A A A
*/
var regionA = new Region (new (0, 0, 6, 6));
var regionB = new Region ();
regionB.Combine (new Rectangle (2, 2, 2, 1), RegionOp.MinimalUnion);
regionB.Combine (new Rectangle (2, 3, 1, 1), RegionOp.MinimalUnion);
// regionB is a non-rectangular region that looks like this:
// x= 0 1 2 3 4 5
// y=0 . . . . . .
// y=1 . . . . . .
// y=2 . . B B . .
// y=3 . . B . . .
// y=4 . . . . . .
// y=5 . . . . . .
Assert.True (regionB.Contains (2, 2));
Assert.True (regionB.Contains (3, 2));
Assert.True (regionB.Contains (2, 3));
Assert.False (regionB.Contains (3, 3));
regionA.Combine (regionB, RegionOp.Difference);
Assert.True (regionA.Contains (0, 0));
Assert.True (regionA.Contains (1, 1));
Assert.True (regionA.Contains (3, 3));
Assert.True (regionA.Contains (4, 4));
Assert.True (regionA.Contains (5, 5));
Assert.False (regionA.Contains (2, 2));
Assert.False (regionA.Contains (3, 2));
Assert.False (regionA.Contains (2, 3));
}
}