mirror of
https://github.com/gui-cs/Terminal.Gui.git
synced 2025-12-29 01:07:58 +01:00
* Added ClipRegion; cleaned up driver code * clip region unit tests * api docs * Moved color stuff from ConsoleDriver to Color.cs * Removes unused ConsoleDriver APIs * Code cleanup and Removes unused ConsoleDriver APIs * Code cleanup and Removes unused ConsoleDriver APIs * Work around https://github.com/gui-cs/Terminal.Gui/issues/2610 * adjusted unit tests * initial commit * Made Rows, Cols, Top, Left virtual * Made Clipboard non-virtual * Made EnableConsoleScrolling non-virtual * Made Contents non-virtual * Pulled Row/Col up * Made MoveTo virtual; fixed stupid FakeDriver cursor issue * Made CurrentAttribute non-virtual * Made SetAttribute non-virtual * Moved clipboard code out * Code cleanup * Removes dependecy on NStack from ConsoleDrivers - WIP * Fixed unit tests * Fixed unit tests * Added list of unit tests needed * Did some perf testing; tweaked code and charmap to address * Brough in code from PR #2264 (but commented) * Tons of code cleanup * Fighting with ScrollView * Fixing bugs * Fixed TabView tests * Fixed View.Visible test that was not really working * Fixed unit tests * Cleaned up clipboard APIs in attempt to track down unit test failure * Add Cut_Preserves_Selection test * Removed invalid code * Removed invalid test code; unit tests now pass * EscSeq* - Adjusted naming, added more sequences, made code more consistent, simplified, etc... * Added CSI_SetGraphicsRendition * NetDriver code cleanup * code cleanup * Cleaned up color handling in NetDriver * refixed tabview unit test * WindowsDriver color code cleanup * WindowsDriver color code cleanup * CursesDriver color code cleanup * CursesDriver - Adding _BOLD has no effect. Further up the stack we cast the return of ColorToCursesColor from int to short and the _BOLD values don't fit in a short. * CursesDriver color code - make code more accurate * CursesDriver color code - make code more accurate * Simplified ConsoleDriver.GetColors API * Simplified ConsoleDriver.GetColors API further * Improved encapslation of Attribute; prep for TrueColor & other attributes like blink * Fixes #2249. CharacterMap isn't refreshing well non-BMP code points on scroll. * Use GetRange to take some of the runes before convert to string. * Attempting to fix unit tests not being cleaned up * Fixes #2658 - ConsoleDriver.IsRuneSupported * Fixes #2658 - ConsoleDriver.IsRuneSupported (for WindowsDriver) * Check all the range values and not only the max value. * Reducing code. * Fixes #2674 - Unit test process doesn't exit * Changed Cell to support IsDirty and list of Runes * add support for rendering TrueColor output on Windows merging veeman & tznind code * add colorconverter changes * fixed merged v2_develop * Fixing merge bugs * Fixed merge bugs * Fixed merge bugs - all unit tests pass * Debugging netdriver * More netdriver diag * API docs for escutils * Update unicode scenario to stress more stuff * Contents: Now a 2D array of Cells; WIP * AddRune and ClearContents no longer virtual/abstract * WindowsDriver renders correctly again * Progress on Curses * Progress on Curses * broke windowsdriver * Cleaned up FakeMainLoop * Cleaned up some build warnings * Removed _init from AutoInitShutdown as it's not needed anymore * Removed unused var * Removed unused var * Fixed nullabiltiy warning in LineCanvas * Fixed charmap crash * Fixes #2758 in v2 * Port testonfail fix to v2 * Remove EnableConsoleScrolling * Backport #2764 from develop (clear last line) * Remove uneeded usings * Progress on unicode * Merged in changes from PR #2786, Fixes #2784 * revamp charmap rendering * Charmap option to show glyph widths * Fixed issue with wide glpyhs being overwritten * Fixed charmap startcodepoint change issue * Added abiltiy to see ncurses verison/lib * Fought with CursesDriver; giving up for now. See notes. * Leverage Wcwidth nuget library instaed of our own tables * enhanced charmap Details dialog * Final attempt at fixing curses --------- Co-authored-by: BDisp <bd.bdisp@gmail.com> Co-authored-by: adstep <stephensonadamj@gmail.com>
288 lines
9.3 KiB
C#
288 lines
9.3 KiB
C#
using System;
|
|
using Xunit;
|
|
using Xunit.Abstractions;
|
|
|
|
namespace Terminal.Gui.ClipboardTests {
|
|
public class ClipboardTests {
|
|
readonly ITestOutputHelper output;
|
|
|
|
public ClipboardTests (ITestOutputHelper output)
|
|
{
|
|
this.output = output;
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: true, fakeClipboardAlwaysThrowsNotSupportedException: true)]
|
|
public void IClipboard_GetClipBoardData_Throws_NotSupportedException ()
|
|
{
|
|
IClipboard iclip = Application.Driver.Clipboard;
|
|
Assert.Throws<NotSupportedException> (() => iclip.GetClipboardData ());
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: true, fakeClipboardAlwaysThrowsNotSupportedException: true)]
|
|
public void IClipboard_SetClipBoardData_Throws_NotSupportedException ()
|
|
{
|
|
IClipboard iclip = Application.Driver.Clipboard;
|
|
Assert.Throws<NotSupportedException> (() => iclip.SetClipboardData ("foo"));
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: true)]
|
|
public void Contents_Fake_Gets_Sets ()
|
|
{
|
|
if (!Clipboard.IsSupported) {
|
|
output.WriteLine ($"The Clipboard not supported on this platform.");
|
|
return;
|
|
}
|
|
|
|
var clipText = "The Contents_Gets_Sets unit test pasted this to the OS clipboard.";
|
|
Clipboard.Contents = clipText;
|
|
|
|
Application.Iteration += () => Application.RequestStop ();
|
|
Application.Run ();
|
|
|
|
Assert.Equal (clipText, Clipboard.Contents);
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: false)]
|
|
public void Contents_Gets_Sets ()
|
|
{
|
|
if (!Clipboard.IsSupported) {
|
|
output.WriteLine ($"The Clipboard not supported on this platform.");
|
|
return;
|
|
}
|
|
|
|
var clipText = "The Contents_Gets_Sets unit test pasted this to the OS clipboard.";
|
|
Clipboard.Contents = clipText;
|
|
|
|
Application.Iteration += () => Application.RequestStop ();
|
|
Application.Run ();
|
|
|
|
Assert.Equal (clipText, Clipboard.Contents);
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: false)]
|
|
public void Contents_Gets_Sets_When_IsSupportedFalse ()
|
|
{
|
|
|
|
if (!Clipboard.IsSupported) {
|
|
output.WriteLine ($"The Clipboard not supported on this platform.");
|
|
return;
|
|
}
|
|
|
|
var clipText = "The Contents_Gets_Sets unit test pasted this to the OS clipboard.";
|
|
Clipboard.Contents = clipText;
|
|
|
|
Application.Iteration += () => Application.RequestStop ();
|
|
Application.Run ();
|
|
|
|
Assert.Equal (clipText, Clipboard.Contents);
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: true)]
|
|
public void Contents_Fake_Gets_Sets_When_IsSupportedFalse ()
|
|
{
|
|
|
|
if (!Clipboard.IsSupported) {
|
|
output.WriteLine ($"The Clipboard not supported on this platform.");
|
|
return;
|
|
}
|
|
|
|
var clipText = "The Contents_Gets_Sets unit test pasted this to the OS clipboard.";
|
|
Clipboard.Contents = clipText;
|
|
|
|
Application.Iteration += () => Application.RequestStop ();
|
|
Application.Run ();
|
|
|
|
Assert.Equal (clipText, Clipboard.Contents);
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: false)]
|
|
public void IsSupported_Get ()
|
|
{
|
|
if (Clipboard.IsSupported) Assert.True (Clipboard.IsSupported);
|
|
else Assert.False (Clipboard.IsSupported);
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: false)]
|
|
public void TryGetClipboardData_Gets_From_OS_Clipboard ()
|
|
{
|
|
var clipText = "The TryGetClipboardData_Gets_From_OS_Clipboard unit test pasted this to the OS clipboard.";
|
|
Clipboard.Contents = clipText;
|
|
|
|
Application.Iteration += () => Application.RequestStop ();
|
|
|
|
Application.Run ();
|
|
|
|
if (Clipboard.IsSupported) {
|
|
Assert.True (Clipboard.TryGetClipboardData (out string result));
|
|
Assert.Equal (clipText, result);
|
|
} else {
|
|
Assert.False (Clipboard.TryGetClipboardData (out string result));
|
|
Assert.NotEqual (clipText, result);
|
|
}
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: false)]
|
|
public void TrySetClipboardData_Sets_The_OS_Clipboard ()
|
|
{
|
|
var clipText = "The TrySetClipboardData_Sets_The_OS_Clipboard unit test pasted this to the OS clipboard.";
|
|
if (Clipboard.IsSupported) Assert.True (Clipboard.TrySetClipboardData (clipText));
|
|
else Assert.False (Clipboard.TrySetClipboardData (clipText));
|
|
|
|
Application.Iteration += () => Application.RequestStop ();
|
|
|
|
Application.Run ();
|
|
|
|
if (Clipboard.IsSupported) Assert.Equal (clipText, Clipboard.Contents);
|
|
else Assert.NotEqual (clipText, Clipboard.Contents);
|
|
}
|
|
|
|
// Disabling this test for now because it is not reliable
|
|
#if false
|
|
[Fact, AutoInitShutdown (useFakeClipboard: false)]
|
|
public void Contents_Copies_From_OS_Clipboard ()
|
|
{
|
|
if (!Clipboard.IsSupported) {
|
|
output.WriteLine ($"The Clipboard not supported on this platform.");
|
|
return;
|
|
}
|
|
|
|
var clipText = "The Contents_Copies_From_OS_Clipboard unit test pasted this to the OS clipboard.";
|
|
var failed = false;
|
|
var getClipText = "";
|
|
|
|
Application.Iteration += () => {
|
|
int exitCode = 0;
|
|
string result = "";
|
|
output.WriteLine ($"Pasting to OS clipboard: {clipText}...");
|
|
|
|
if (RuntimeInformation.IsOSPlatform (OSPlatform.Windows)) {
|
|
(exitCode, result) = ClipboardProcessRunner.Process ("powershell.exe", $"-command \"Set-Clipboard -Value \\\"{clipText}\\\"\"");
|
|
output.WriteLine ($" Windows: powershell.exe Set-Clipboard: exitCode = {exitCode}, result = {result}");
|
|
getClipText = Clipboard.Contents;
|
|
|
|
} else if (RuntimeInformation.IsOSPlatform (OSPlatform.OSX)) {
|
|
(exitCode, result) = ClipboardProcessRunner.Process ("pbcopy", string.Empty, clipText);
|
|
output.WriteLine ($" OSX: pbcopy: exitCode = {exitCode}, result = {result}");
|
|
getClipText = Clipboard.Contents;
|
|
|
|
} else if (RuntimeInformation.IsOSPlatform (OSPlatform.Linux)) {
|
|
if (Is_WSL_Platform ()) {
|
|
try {
|
|
// This runs the WINDOWS version of powershell.exe via WSL.
|
|
(exitCode, result) = ClipboardProcessRunner.Process ("powershell.exe", $"-noprofile -command \"Set-Clipboard -Value \\\"{clipText}\\\"\"");
|
|
output.WriteLine ($" WSL: powershell.exe Set-Clipboard: exitCode = {exitCode}, result = {result}");
|
|
} catch {
|
|
failed = true;
|
|
}
|
|
|
|
if (!failed) {
|
|
// If we set the OS clipboard via Powershell, then getting Contents should return the same text.
|
|
getClipText = Clipboard.Contents;
|
|
output.WriteLine ($" WSL: Clipboard.Contents: {getClipText}");
|
|
}
|
|
Application.RequestStop ();
|
|
return;
|
|
}
|
|
|
|
if (failed = xclipExists () == false) {
|
|
// if xclip doesn't exist then exit.
|
|
output.WriteLine ($" WSL: no xclip found.");
|
|
Application.RequestStop ();
|
|
return;
|
|
}
|
|
|
|
// If we get here, powershell didn't work and xclip exists...
|
|
(exitCode, result) = ClipboardProcessRunner.Process ("bash", $"-c \"xclip -sel clip -i\"", clipText);
|
|
output.WriteLine ($" Linux: bash xclip -sel clip -i: exitCode = {exitCode}, result = {result}");
|
|
|
|
if (!failed) {
|
|
getClipText = Clipboard.Contents;
|
|
output.WriteLine ($" Linux via xclip: Clipboard.Contents: {getClipText}");
|
|
}
|
|
}
|
|
|
|
Application.RequestStop ();
|
|
};
|
|
|
|
Application.Run ();
|
|
|
|
if (!failed) Assert.Equal (clipText, getClipText);
|
|
}
|
|
|
|
[Fact, AutoInitShutdown (useFakeClipboard: false)]
|
|
public void Contents_Pastes_To_OS_Clipboard ()
|
|
{
|
|
if (!Clipboard.IsSupported) {
|
|
output.WriteLine ($"The Clipboard not supported on this platform.");
|
|
return;
|
|
}
|
|
|
|
var clipText = "The Contents_Pastes_To_OS_Clipboard unit test pasted this via Clipboard.Contents.";
|
|
var clipReadText = "";
|
|
var failed = false;
|
|
|
|
Application.Iteration += () => {
|
|
Clipboard.Contents = clipText;
|
|
|
|
int exitCode = 0;
|
|
output.WriteLine ($"Getting OS clipboard...");
|
|
|
|
if (RuntimeInformation.IsOSPlatform (OSPlatform.Windows)) {
|
|
(exitCode, clipReadText) = ClipboardProcessRunner.Process ("powershell.exe", "-noprofile -command \"Get-Clipboard\"");
|
|
output.WriteLine ($" Windows: powershell.exe Get-Clipboard: exitCode = {exitCode}, result = {clipReadText}");
|
|
|
|
} else if (RuntimeInformation.IsOSPlatform (OSPlatform.OSX)) {
|
|
(exitCode, clipReadText) = ClipboardProcessRunner.Process ("pbpaste", "");
|
|
output.WriteLine ($" OSX: pbpaste: exitCode = {exitCode}, result = {clipReadText}");
|
|
|
|
} else if (RuntimeInformation.IsOSPlatform (OSPlatform.Linux)) {
|
|
if (Is_WSL_Platform ()) {
|
|
(exitCode, clipReadText) = ClipboardProcessRunner.Process ("powershell.exe", "-noprofile -command \"Get-Clipboard\"");
|
|
output.WriteLine ($" WSL: powershell.exe Get-Clipboard: exitCode = {exitCode}, result = {clipReadText}");
|
|
if (exitCode == 0) {
|
|
Application.RequestStop ();
|
|
return;
|
|
}
|
|
failed = true;
|
|
}
|
|
|
|
if (failed = xclipExists () == false) {
|
|
// xclip doesn't exist then exit.
|
|
Application.RequestStop ();
|
|
return;
|
|
}
|
|
|
|
(exitCode, clipReadText) = ClipboardProcessRunner.Process ("bash", $"-c \"xclip -sel clip -o\"");
|
|
output.WriteLine ($" Linux: bash xclip -sel clip -o: exitCode = {exitCode}, result = {clipReadText}");
|
|
Assert.Equal (0, exitCode);
|
|
}
|
|
|
|
Application.RequestStop ();
|
|
};
|
|
|
|
Application.Run ();
|
|
|
|
if (!failed) Assert.Equal (clipText, clipReadText.TrimEnd ());
|
|
|
|
}
|
|
#endif
|
|
|
|
bool Is_WSL_Platform ()
|
|
{
|
|
var (_, result) = ClipboardProcessRunner.Process ("bash", $"-c \"uname -a\"");
|
|
return result.Contains ("microsoft") && result.Contains ("WSL");
|
|
}
|
|
|
|
bool xclipExists ()
|
|
{
|
|
try {
|
|
var (_, result) = ClipboardProcessRunner.Process ("bash", $"-c \"which xclip\"");
|
|
return result.TrimEnd () != "";
|
|
} catch (Exception) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|