Add install tool command (#8132)
* compose all the parts * Fix on obtain and shim maker for better end to end experience * Fix error when there is space in the middle of path of nuget config * Fix path in profile.d is the tmp home path during install * better handle of ~home * remove profile.d file in uninstall script * Fix test since it looks up current directory * folder structure inside nupkg to tools/TFM/RID/mytool.dll * Add check for config file existence * Rename name space to Microsoft.DotNet.ShellShim * Rename name space to Microsoft.DotNet.ToolPackage
This commit is contained in:
parent
ea74bf1614
commit
55f62d9d64
55 changed files with 587 additions and 204 deletions
|
@ -230,9 +230,9 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.TestFramew
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Msbuild.Tests.Utilities", "test\Msbuild.Tests.Utilities\Msbuild.Tests.Utilities.csproj", "{E7C72EF2-8480-48B4-AAE8-A596F1A6048E}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Msbuild.Tests.Utilities", "test\Msbuild.Tests.Utilities\Msbuild.Tests.Utilities.csproj", "{E7C72EF2-8480-48B4-AAE8-A596F1A6048E}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.ToolPackageObtainer.Tests", "test\Microsoft.DotNet.ToolPackageObtainer.Tests\Microsoft.DotNet.ToolPackageObtainer.Tests.csproj", "{F0D50831-9468-4ACB-8FD8-E9883DD553FB}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.ShellShim.Tests", "test\Microsoft.DotNet.ShellShim.Tests\Microsoft.DotNet.ShellShim.Tests.csproj", "{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.ShellShimMaker.Tests", "test\Microsoft.DotNet.ShellShimMaker.Tests\Microsoft.DotNet.ShellShimMaker.Tests.csproj", "{20376E28-68EB-4BE5-81A5-51500F1235E2}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.ToolPackage.Tests", "test\Microsoft.DotNet.ToolPackage.Tests\Microsoft.DotNet.ToolPackage.Tests.csproj", "{91BFE800-1624-4A58-A1CE-339705A8FFD0}"
|
||||||
EndProject
|
EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
@ -1618,54 +1618,54 @@ Global
|
||||||
{E7C72EF2-8480-48B4-AAE8-A596F1A6048E}.RelWithDebInfo|x64.Build.0 = Release|Any CPU
|
{E7C72EF2-8480-48B4-AAE8-A596F1A6048E}.RelWithDebInfo|x64.Build.0 = Release|Any CPU
|
||||||
{E7C72EF2-8480-48B4-AAE8-A596F1A6048E}.RelWithDebInfo|x86.ActiveCfg = Release|Any CPU
|
{E7C72EF2-8480-48B4-AAE8-A596F1A6048E}.RelWithDebInfo|x86.ActiveCfg = Release|Any CPU
|
||||||
{E7C72EF2-8480-48B4-AAE8-A596F1A6048E}.RelWithDebInfo|x86.Build.0 = Release|Any CPU
|
{E7C72EF2-8480-48B4-AAE8-A596F1A6048E}.RelWithDebInfo|x86.Build.0 = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Debug|x64.ActiveCfg = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Debug|x64.ActiveCfg = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Debug|x64.Build.0 = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Debug|x64.Build.0 = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Debug|x86.ActiveCfg = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Debug|x86.ActiveCfg = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Debug|x86.Build.0 = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Debug|x86.Build.0 = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.MinSizeRel|Any CPU.ActiveCfg = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.MinSizeRel|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.MinSizeRel|Any CPU.Build.0 = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.MinSizeRel|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.MinSizeRel|x64.ActiveCfg = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.MinSizeRel|x64.ActiveCfg = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.MinSizeRel|x64.Build.0 = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.MinSizeRel|x64.Build.0 = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.MinSizeRel|x86.ActiveCfg = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.MinSizeRel|x86.ActiveCfg = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.MinSizeRel|x86.Build.0 = Debug|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.MinSizeRel|x86.Build.0 = Debug|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Release|Any CPU.Build.0 = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Release|x64.ActiveCfg = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Release|x64.ActiveCfg = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Release|x64.Build.0 = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Release|x64.Build.0 = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Release|x86.ActiveCfg = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Release|x86.ActiveCfg = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.Release|x86.Build.0 = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.Release|x86.Build.0 = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.RelWithDebInfo|Any CPU.ActiveCfg = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.RelWithDebInfo|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.RelWithDebInfo|Any CPU.Build.0 = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.RelWithDebInfo|Any CPU.Build.0 = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.RelWithDebInfo|x64.ActiveCfg = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.RelWithDebInfo|x64.ActiveCfg = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.RelWithDebInfo|x64.Build.0 = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.RelWithDebInfo|x64.Build.0 = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.RelWithDebInfo|x86.ActiveCfg = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.RelWithDebInfo|x86.ActiveCfg = Release|Any CPU
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB}.RelWithDebInfo|x86.Build.0 = Release|Any CPU
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C}.RelWithDebInfo|x86.Build.0 = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Debug|x64.ActiveCfg = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Debug|x64.ActiveCfg = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Debug|x64.Build.0 = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Debug|x64.Build.0 = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Debug|x86.ActiveCfg = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Debug|x86.ActiveCfg = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Debug|x86.Build.0 = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Debug|x86.Build.0 = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.MinSizeRel|Any CPU.ActiveCfg = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.MinSizeRel|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.MinSizeRel|Any CPU.Build.0 = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.MinSizeRel|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.MinSizeRel|x64.ActiveCfg = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.MinSizeRel|x64.ActiveCfg = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.MinSizeRel|x64.Build.0 = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.MinSizeRel|x64.Build.0 = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.MinSizeRel|x86.ActiveCfg = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.MinSizeRel|x86.ActiveCfg = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.MinSizeRel|x86.Build.0 = Debug|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.MinSizeRel|x86.Build.0 = Debug|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Release|Any CPU.Build.0 = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Release|x64.ActiveCfg = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Release|x64.ActiveCfg = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Release|x64.Build.0 = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Release|x64.Build.0 = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Release|x86.ActiveCfg = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Release|x86.ActiveCfg = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.Release|x86.Build.0 = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.Release|x86.Build.0 = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.RelWithDebInfo|Any CPU.ActiveCfg = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.RelWithDebInfo|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.RelWithDebInfo|Any CPU.Build.0 = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.RelWithDebInfo|Any CPU.Build.0 = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.RelWithDebInfo|x64.ActiveCfg = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.RelWithDebInfo|x64.ActiveCfg = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.RelWithDebInfo|x64.Build.0 = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.RelWithDebInfo|x64.Build.0 = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.RelWithDebInfo|x86.ActiveCfg = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.RelWithDebInfo|x86.ActiveCfg = Release|Any CPU
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2}.RelWithDebInfo|x86.Build.0 = Release|Any CPU
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0}.RelWithDebInfo|x86.Build.0 = Release|Any CPU
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
||||||
|
@ -1738,8 +1738,8 @@ Global
|
||||||
{B4EE3671-C103-4A37-8DEB-C74E0134104E} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
{B4EE3671-C103-4A37-8DEB-C74E0134104E} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
||||||
{44759218-B558-4AF0-8991-515F1100DCF5} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
{44759218-B558-4AF0-8991-515F1100DCF5} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
||||||
{E7C72EF2-8480-48B4-AAE8-A596F1A6048E} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
{E7C72EF2-8480-48B4-AAE8-A596F1A6048E} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
||||||
{F0D50831-9468-4ACB-8FD8-E9883DD553FB} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
{E84C08C9-70D7-48B0-9507-ADB8B9A2694C} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
||||||
{20376E28-68EB-4BE5-81A5-51500F1235E2} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
{91BFE800-1624-4A58-A1CE-339705A8FFD0} = {17735A9D-BFD9-4585-A7CB-3208CA6EA8A7}
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||||
SolutionGuid = {B526D2CE-EE2D-4AD4-93EF-1867D90FF1F5}
|
SolutionGuid = {B526D2CE-EE2D-4AD4-93EF-1867D90FF1F5}
|
||||||
|
|
|
@ -25,6 +25,9 @@ is_dotnet_host_installed(){
|
||||||
[ -z "$out" ]
|
[ -z "$out" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dotnet_tool_path_file="/etc/profile.d/dotnet-cli-tools-bin-path.sh"
|
||||||
|
rm -f "$dotnet_tool_path_file"
|
||||||
|
|
||||||
is_dotnet_host_installed
|
is_dotnet_host_installed
|
||||||
[ "$?" -eq 0 ] && echo "Unable to find dotnet installation to remove." >&2 \
|
[ "$?" -eq 0 ] && echo "Unable to find dotnet installation to remove." >&2 \
|
||||||
&& exit 0
|
&& exit 0
|
||||||
|
|
|
@ -16,6 +16,7 @@ fi
|
||||||
dotnet_pkg_name_suffix="com.microsoft.dotnet"
|
dotnet_pkg_name_suffix="com.microsoft.dotnet"
|
||||||
dotnet_install_root="/usr/local/share/dotnet"
|
dotnet_install_root="/usr/local/share/dotnet"
|
||||||
dotnet_path_file="/etc/paths.d/dotnet"
|
dotnet_path_file="/etc/paths.d/dotnet"
|
||||||
|
dotnet_tool_path_file="/etc/paths.d/dotnet-cli-tools"
|
||||||
|
|
||||||
remove_dotnet_pkgs(){
|
remove_dotnet_pkgs(){
|
||||||
installed_pkgs=($(pkgutil --pkgs | grep $dotnet_pkg_name_suffix))
|
installed_pkgs=($(pkgutil --pkgs | grep $dotnet_pkg_name_suffix))
|
||||||
|
@ -33,6 +34,7 @@ remove_dotnet_pkgs
|
||||||
echo "Deleting install root - $dotnet_install_root" >&2
|
echo "Deleting install root - $dotnet_install_root" >&2
|
||||||
rm -rf "$dotnet_install_root"
|
rm -rf "$dotnet_install_root"
|
||||||
rm -f "$dotnet_path_file"
|
rm -f "$dotnet_path_file"
|
||||||
|
rm -f "$dotnet_tool_path_file"
|
||||||
|
|
||||||
echo "dotnet packages removal succeeded." >&2
|
echo "dotnet packages removal succeeded." >&2
|
||||||
exit 0
|
exit 0
|
||||||
|
|
|
@ -25,6 +25,9 @@ is_dotnet_host_installed(){
|
||||||
[ -z "$out" ]
|
[ -z "$out" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dotnet_tool_path_file="/etc/profile.d/dotnet-cli-tools-bin-path.sh"
|
||||||
|
rm -f "$dotnet_tool_path_file"
|
||||||
|
|
||||||
is_dotnet_host_installed
|
is_dotnet_host_installed
|
||||||
[ "$?" -eq 0 ] && echo "Unable to find dotnet installation to remove." >&2 \
|
[ "$?" -eq 0 ] && echo "Unable to find dotnet installation to remove." >&2 \
|
||||||
&& exit 0
|
&& exit 0
|
||||||
|
|
|
@ -12,4 +12,4 @@ using System.Runtime.CompilerServices;
|
||||||
[assembly: InternalsVisibleTo("Microsoft.DotNet.TestFramework, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("Microsoft.DotNet.TestFramework, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
[assembly: InternalsVisibleTo("Microsoft.DotNet.Tools.Tests.Utilities, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("Microsoft.DotNet.Tools.Tests.Utilities, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
[assembly: InternalsVisibleTo("Microsoft.DotNet.ProjectJsonMigration, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("Microsoft.DotNet.ProjectJsonMigration, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
[assembly: InternalsVisibleTo("Microsoft.DotNet.ShellShimMaker.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("Microsoft.DotNet.ShellShim.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
using System;
|
||||||
|
|
||||||
|
namespace Microsoft.DotNet.Configurer
|
||||||
|
{
|
||||||
|
public struct BashPathUnderHomeDirectory
|
||||||
|
{
|
||||||
|
private readonly string _fullHomeDirectoryPath;
|
||||||
|
private readonly string _pathRelativeToHome;
|
||||||
|
|
||||||
|
public BashPathUnderHomeDirectory(string fullHomeDirectoryPath, string pathRelativeToHome)
|
||||||
|
{
|
||||||
|
_fullHomeDirectoryPath =
|
||||||
|
fullHomeDirectoryPath ?? throw new ArgumentNullException(nameof(fullHomeDirectoryPath));
|
||||||
|
_pathRelativeToHome = pathRelativeToHome ?? throw new ArgumentNullException(nameof(pathRelativeToHome));
|
||||||
|
}
|
||||||
|
|
||||||
|
public string PathWithTilde => $"~/{_pathRelativeToHome}";
|
||||||
|
|
||||||
|
public string PathWithDollar => $"$HOME/{_pathRelativeToHome}";
|
||||||
|
|
||||||
|
public string Path => $"{_fullHomeDirectoryPath}/{_pathRelativeToHome}";
|
||||||
|
}
|
||||||
|
}
|
|
@ -19,7 +19,15 @@ namespace Microsoft.DotNet.Configurer
|
||||||
Path.Combine(new DirectoryInfo(AppContext.BaseDirectory).Parent.FullName, "NuGetFallbackFolder");
|
Path.Combine(new DirectoryInfo(AppContext.BaseDirectory).Parent.FullName, "NuGetFallbackFolder");
|
||||||
|
|
||||||
public string ExecutablePackagesPath => Path.Combine(DotnetUserProfileFolderPath, ToolsFolderName);
|
public string ExecutablePackagesPath => Path.Combine(DotnetUserProfileFolderPath, ToolsFolderName);
|
||||||
public readonly string ExecutablePackagesPathOnMacEnvPath = $"~/{DotnetProfileDirectoryName}/{ToolsFolderName}";
|
|
||||||
|
public BashPathUnderHomeDirectory ExecutablePackagesPathInUnix
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return new BashPathUnderHomeDirectory(Environment.GetEnvironmentVariable("HOME"),
|
||||||
|
Path.Combine(DotnetProfileDirectoryName, ToolsFolderName));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static string DotnetUserProfileFolderPath
|
public static string DotnetUserProfileFolderPath
|
||||||
{
|
{
|
||||||
|
|
|
@ -14,4 +14,4 @@ using System.Runtime.CompilerServices;
|
||||||
[assembly: InternalsVisibleTo("DynamicProxyGenAssembly2, PublicKey=0024000004800000940000000602000000240000525341310004000001000100c547cac37abd99c8db225ef2f6c8a3602f3b3606cc9891605d02baa56104f4cfc0734aa39b93bf7852f7d9266654753cc297e7d2edfe0bac1cdcf9f717241550e0a7b191195b7667bb4f64bcb8e2121380fd1d9d46ad2d92d2d15605093924cceaf74c4861eff62abf69b9291ed0a340e113be11e6a7d3113e92484cf7045cc7")]
|
[assembly: InternalsVisibleTo("DynamicProxyGenAssembly2, PublicKey=0024000004800000940000000602000000240000525341310004000001000100c547cac37abd99c8db225ef2f6c8a3602f3b3606cc9891605d02baa56104f4cfc0734aa39b93bf7852f7d9266654753cc297e7d2edfe0bac1cdcf9f717241550e0a7b191195b7667bb4f64bcb8e2121380fd1d9d46ad2d92d2d15605093924cceaf74c4861eff62abf69b9291ed0a340e113be11e6a7d3113e92484cf7045cc7")]
|
||||||
[assembly: InternalsVisibleTo("dotnet-test.UnitTests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100039ac461fa5c82c7dd2557400c4fd4e9dcdf7ac47e3d572548c04cd4673e004916610f4ea5cbf86f2b1ca1cb824f2a7b3976afecfcf4eb72d9a899aa6786effa10c30399e6580ed848231fec48374e41b3acf8811931343fc2f73acf72dae745adbcb7063cc4b50550618383202875223fc75401351cd89c44bf9b50e7fa3796")]
|
[assembly: InternalsVisibleTo("dotnet-test.UnitTests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100039ac461fa5c82c7dd2557400c4fd4e9dcdf7ac47e3d572548c04cd4673e004916610f4ea5cbf86f2b1ca1cb824f2a7b3976afecfcf4eb72d9a899aa6786effa10c30399e6580ed848231fec48374e41b3acf8811931343fc2f73acf72dae745adbcb7063cc4b50550618383202875223fc75401351cd89c44bf9b50e7fa3796")]
|
||||||
[assembly: InternalsVisibleTo("Microsoft.DotNet.Tools.Test, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("Microsoft.DotNet.Tools.Test, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
[assembly: InternalsVisibleTo("Microsoft.DotNet.ShellShimMaker.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("Microsoft.DotNet.ShellShim.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
|
|
|
@ -20,6 +20,7 @@ using Microsoft.DotNet.Tools.Store;
|
||||||
using Microsoft.DotNet.Tools.Test;
|
using Microsoft.DotNet.Tools.Test;
|
||||||
using Microsoft.DotNet.Tools.VSTest;
|
using Microsoft.DotNet.Tools.VSTest;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using Microsoft.DotNet.Tools.Install;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.Cli
|
namespace Microsoft.DotNet.Cli
|
||||||
{
|
{
|
||||||
|
@ -144,6 +145,10 @@ namespace Microsoft.DotNet.Cli
|
||||||
{
|
{
|
||||||
Command = ParseCommand.Run
|
Command = ParseCommand.Run
|
||||||
},
|
},
|
||||||
|
["install"] = new BuiltInCommandMetadata
|
||||||
|
{
|
||||||
|
Command = InstallCommand.Run
|
||||||
|
},
|
||||||
["internal-reportinstallsuccess"] = new BuiltInCommandMetadata
|
["internal-reportinstallsuccess"] = new BuiltInCommandMetadata
|
||||||
{
|
{
|
||||||
Command = InternalReportinstallsuccess.Run
|
Command = InternalReportinstallsuccess.Run
|
||||||
|
|
|
@ -55,6 +55,7 @@ namespace Microsoft.DotNet.Cli
|
||||||
Create.Command("vstest", ""),
|
Create.Command("vstest", ""),
|
||||||
CompleteCommandParser.Complete(),
|
CompleteCommandParser.Complete(),
|
||||||
InternalReportinstallsuccessCommandParser.InternalReportinstallsuccess(),
|
InternalReportinstallsuccessCommandParser.InternalReportinstallsuccess(),
|
||||||
|
InstallCommandParser.Install(),
|
||||||
CommonOptions.HelpOption(),
|
CommonOptions.HelpOption(),
|
||||||
Create.Option("--info", ""),
|
Create.Option("--info", ""),
|
||||||
Create.Option("-d", ""),
|
Create.Option("-d", ""),
|
||||||
|
|
|
@ -11,7 +11,7 @@ using Microsoft.DotNet.Cli.Telemetry;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
using Microsoft.DotNet.Configurer;
|
using Microsoft.DotNet.Configurer;
|
||||||
using Microsoft.DotNet.PlatformAbstractions;
|
using Microsoft.DotNet.PlatformAbstractions;
|
||||||
using Microsoft.DotNet.ShellShimMaker;
|
using Microsoft.DotNet.ShellShim;
|
||||||
using Microsoft.DotNet.Tools.Help;
|
using Microsoft.DotNet.Tools.Help;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
using NuGet.Frameworks;
|
using NuGet.Frameworks;
|
||||||
|
|
|
@ -17,5 +17,5 @@ using System.Runtime.CompilerServices;
|
||||||
[assembly: InternalsVisibleTo("dotnet-sln-remove.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("dotnet-sln-remove.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
[assembly: InternalsVisibleTo("dotnet-msbuild.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("dotnet-msbuild.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
[assembly: InternalsVisibleTo("dotnet-run.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("dotnet-run.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
[assembly: InternalsVisibleTo("Microsoft.DotNet.ToolPackageObtainer.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("Microsoft.DotNet.ToolPackage.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
[assembly: InternalsVisibleTo("Microsoft.DotNet.ShellShimMaker.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
[assembly: InternalsVisibleTo("Microsoft.DotNet.ShellShim.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f33a29044fa9d740c9b3213a93e57c84b472c84e0b8a0e1ae48e67a9f8f6de9d5f7f3d52ac23e48ac51801f1dc950abe901da34d2a9e3baadb141a17c77ef3c565dd5ee5054b91cf63bb3c6ab83f72ab3aafe93d0fc3c2348b764fafb0b1c0733de51459aeab46580384bf9d74c4e28164b7cde247f891ba07891c9d872ad2bb")]
|
||||||
|
|
|
@ -7,7 +7,7 @@ using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker
|
namespace Microsoft.DotNet.ShellShim
|
||||||
{
|
{
|
||||||
public class DoNothingEnvironmentPath : IEnvironmentPath
|
public class DoNothingEnvironmentPath : IEnvironmentPath
|
||||||
{
|
{
|
|
@ -9,7 +9,7 @@ using Microsoft.DotNet.Cli.Utils;
|
||||||
using Microsoft.DotNet.Configurer;
|
using Microsoft.DotNet.Configurer;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker
|
namespace Microsoft.DotNet.ShellShim
|
||||||
{
|
{
|
||||||
internal static class EnvironmentPathFactory
|
internal static class EnvironmentPathFactory
|
||||||
{
|
{
|
||||||
|
@ -39,15 +39,14 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux) && hasSuperUserAccess)
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux) && hasSuperUserAccess)
|
||||||
{
|
{
|
||||||
environmentPath = new LinuxEnvironmentPath(
|
environmentPath = new LinuxEnvironmentPath(
|
||||||
cliFolderPathCalculator.ExecutablePackagesPath,
|
cliFolderPathCalculator.ExecutablePackagesPathInUnix,
|
||||||
Reporter.Output,
|
Reporter.Output,
|
||||||
environmentProvider, new FileWrapper());
|
environmentProvider, new FileWrapper());
|
||||||
}
|
}
|
||||||
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX) && hasSuperUserAccess)
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX) && hasSuperUserAccess)
|
||||||
{
|
{
|
||||||
environmentPath = new OSXEnvironmentPath(
|
environmentPath = new OSXEnvironmentPath(
|
||||||
packageExecutablePathWithTilde: cliFolderPathCalculator.ExecutablePackagesPathOnMacEnvPath,
|
executablePath: cliFolderPathCalculator.ExecutablePackagesPathInUnix,
|
||||||
fullPackageExecutablePath: cliFolderPathCalculator.ExecutablePackagesPath,
|
|
||||||
reporter: Reporter.Output,
|
reporter: Reporter.Output,
|
||||||
environmentProvider: environmentProvider,
|
environmentProvider: environmentProvider,
|
||||||
fileSystem: new FileWrapper());
|
fileSystem: new FileWrapper());
|
|
@ -4,9 +4,10 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
|
using Microsoft.DotNet.Configurer;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker
|
namespace Microsoft.DotNet.ShellShim
|
||||||
{
|
{
|
||||||
internal class LinuxEnvironmentPath : IEnvironmentPath
|
internal class LinuxEnvironmentPath : IEnvironmentPath
|
||||||
{
|
{
|
||||||
|
@ -14,14 +15,14 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
private readonly IEnvironmentProvider _environmentProvider;
|
private readonly IEnvironmentProvider _environmentProvider;
|
||||||
private readonly IReporter _reporter;
|
private readonly IReporter _reporter;
|
||||||
private const string PathName = "PATH";
|
private const string PathName = "PATH";
|
||||||
private readonly string _packageExecutablePath;
|
private readonly BashPathUnderHomeDirectory _packageExecutablePath;
|
||||||
|
|
||||||
private readonly string _profiledDotnetCliToolsPath
|
private readonly string _profiledDotnetCliToolsPath
|
||||||
= Environment.GetEnvironmentVariable("DOTNET_CLI_TEST_LINUX_PROFILED_PATH")
|
= Environment.GetEnvironmentVariable("DOTNET_CLI_TEST_LINUX_PROFILED_PATH")
|
||||||
?? @"/etc/profile.d/dotnet-cli-tools-bin-path.sh";
|
?? @"/etc/profile.d/dotnet-cli-tools-bin-path.sh";
|
||||||
|
|
||||||
internal LinuxEnvironmentPath(
|
internal LinuxEnvironmentPath(
|
||||||
string packageExecutablePath,
|
BashPathUnderHomeDirectory packageExecutablePath,
|
||||||
IReporter reporter,
|
IReporter reporter,
|
||||||
IEnvironmentProvider environmentProvider,
|
IEnvironmentProvider environmentProvider,
|
||||||
IFile fileSystem)
|
IFile fileSystem)
|
||||||
|
@ -31,8 +32,7 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
= environmentProvider ?? throw new ArgumentNullException(nameof(environmentProvider));
|
= environmentProvider ?? throw new ArgumentNullException(nameof(environmentProvider));
|
||||||
_reporter
|
_reporter
|
||||||
= reporter ?? throw new ArgumentNullException(nameof(reporter));
|
= reporter ?? throw new ArgumentNullException(nameof(reporter));
|
||||||
_packageExecutablePath
|
_packageExecutablePath = packageExecutablePath;
|
||||||
= packageExecutablePath ?? throw new ArgumentNullException(nameof(packageExecutablePath));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void AddPackageExecutablePathToUserPath()
|
public void AddPackageExecutablePathToUserPath()
|
||||||
|
@ -42,7 +42,7 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var script = $"export PATH=\"$PATH:{_packageExecutablePath}\"";
|
var script = $"export PATH=\"$PATH:{_packageExecutablePath.PathWithDollar}\"";
|
||||||
_fileSystem.WriteAllText(_profiledDotnetCliToolsPath, script);
|
_fileSystem.WriteAllText(_profiledDotnetCliToolsPath, script);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
{
|
{
|
||||||
return _environmentProvider
|
return _environmentProvider
|
||||||
.GetEnvironmentVariable(PathName)
|
.GetEnvironmentVariable(PathName)
|
||||||
.Split(':').Contains(_packageExecutablePath);
|
.Split(':').Contains(_packageExecutablePath.Path);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void PrintAddPathInstructionIfPathDoesNotExist()
|
public void PrintAddPathInstructionIfPathDoesNotExist()
|
||||||
|
@ -59,17 +59,18 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
{
|
{
|
||||||
if (_fileSystem.Exists(_profiledDotnetCliToolsPath))
|
if (_fileSystem.Exists(_profiledDotnetCliToolsPath))
|
||||||
{
|
{
|
||||||
_reporter.WriteLine("Since you just installed the .NET Core SDK, you will need to logout or restart your session before running the tool you installed.");
|
_reporter.WriteLine(
|
||||||
|
"Since you just installed the .NET Core SDK, you will need to logout or restart your session before running the tool you installed.");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// similar to https://code.visualstudio.com/docs/setup/mac
|
// similar to https://code.visualstudio.com/docs/setup/mac
|
||||||
_reporter.WriteLine(
|
_reporter.WriteLine(
|
||||||
$"Cannot find the tools executable path. Please ensure {_packageExecutablePath} is added to your PATH.{Environment.NewLine}" +
|
$"Cannot find the tools executable path. Please ensure {_packageExecutablePath.Path} is added to your PATH.{Environment.NewLine}" +
|
||||||
$"If you are using bash. You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
$"If you are using bash. You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
||||||
$"cat << EOF >> ~/.bash_profile{Environment.NewLine}" +
|
$"cat << EOF >> ~/.bash_profile{Environment.NewLine}" +
|
||||||
$"# Add .NET Core SDK tools{Environment.NewLine}" +
|
$"# Add .NET Core SDK tools{Environment.NewLine}" +
|
||||||
$"export PATH=\"$PATH:{_packageExecutablePath}\"{Environment.NewLine}" +
|
$"export PATH=\"$PATH:{_packageExecutablePath.Path}\"{Environment.NewLine}" +
|
||||||
$"EOF");
|
$"EOF");
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -4,15 +4,15 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
|
using Microsoft.DotNet.Configurer;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker
|
namespace Microsoft.DotNet.ShellShim
|
||||||
{
|
{
|
||||||
internal class OSXEnvironmentPath : IEnvironmentPath
|
internal class OSXEnvironmentPath : IEnvironmentPath
|
||||||
{
|
{
|
||||||
private const string PathName = "PATH";
|
private const string PathName = "PATH";
|
||||||
private readonly string _packageExecutablePathWithTilde;
|
private readonly BashPathUnderHomeDirectory _packageExecutablePath;
|
||||||
private readonly string _fullPackageExecutablePath;
|
|
||||||
private readonly IFile _fileSystem;
|
private readonly IFile _fileSystem;
|
||||||
private readonly IEnvironmentProvider _environmentProvider;
|
private readonly IEnvironmentProvider _environmentProvider;
|
||||||
private readonly IReporter _reporter;
|
private readonly IReporter _reporter;
|
||||||
|
@ -22,17 +22,13 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
?? @"/etc/paths.d/dotnet-cli-tools";
|
?? @"/etc/paths.d/dotnet-cli-tools";
|
||||||
|
|
||||||
public OSXEnvironmentPath(
|
public OSXEnvironmentPath(
|
||||||
string packageExecutablePathWithTilde,
|
BashPathUnderHomeDirectory executablePath,
|
||||||
string fullPackageExecutablePath,
|
|
||||||
IReporter reporter,
|
IReporter reporter,
|
||||||
IEnvironmentProvider environmentProvider,
|
IEnvironmentProvider environmentProvider,
|
||||||
IFile fileSystem
|
IFile fileSystem
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
_fullPackageExecutablePath = fullPackageExecutablePath ??
|
_packageExecutablePath = executablePath;
|
||||||
throw new ArgumentNullException(nameof(fullPackageExecutablePath));
|
|
||||||
_packageExecutablePathWithTilde = packageExecutablePathWithTilde ??
|
|
||||||
throw new ArgumentNullException(nameof(packageExecutablePathWithTilde));
|
|
||||||
_fileSystem = fileSystem ?? throw new ArgumentNullException(nameof(fileSystem));
|
_fileSystem = fileSystem ?? throw new ArgumentNullException(nameof(fileSystem));
|
||||||
_environmentProvider
|
_environmentProvider
|
||||||
= environmentProvider ?? throw new ArgumentNullException(nameof(environmentProvider));
|
= environmentProvider ?? throw new ArgumentNullException(nameof(environmentProvider));
|
||||||
|
@ -47,16 +43,16 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var script = $"{_packageExecutablePathWithTilde}";
|
var script = $"{_packageExecutablePath.PathWithTilde}";
|
||||||
_fileSystem.WriteAllText(PathDDotnetCliToolsPath, script);
|
_fileSystem.WriteAllText(PathDDotnetCliToolsPath, script);
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool PackageExecutablePathExists()
|
private bool PackageExecutablePathExists()
|
||||||
{
|
{
|
||||||
return _environmentProvider.GetEnvironmentVariable(PathName).Split(':')
|
return _environmentProvider.GetEnvironmentVariable(PathName).Split(':')
|
||||||
.Contains(_packageExecutablePathWithTilde) ||
|
.Contains(_packageExecutablePath.PathWithTilde) ||
|
||||||
_environmentProvider.GetEnvironmentVariable(PathName).Split(':')
|
_environmentProvider.GetEnvironmentVariable(PathName).Split(':')
|
||||||
.Contains(_fullPackageExecutablePath);
|
.Contains(_packageExecutablePath.Path);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void PrintAddPathInstructionIfPathDoesNotExist()
|
public void PrintAddPathInstructionIfPathDoesNotExist()
|
||||||
|
@ -72,11 +68,11 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
{
|
{
|
||||||
// similar to https://code.visualstudio.com/docs/setup/mac
|
// similar to https://code.visualstudio.com/docs/setup/mac
|
||||||
_reporter.WriteLine(
|
_reporter.WriteLine(
|
||||||
$"Cannot find the tools executable path. Please ensure {_fullPackageExecutablePath} is added to your PATH.{Environment.NewLine}" +
|
$"Cannot find the tools executable path. Please ensure {_packageExecutablePath.Path} is added to your PATH.{Environment.NewLine}" +
|
||||||
$"If you are using bash, You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
$"If you are using bash, You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
||||||
$"cat << EOF >> ~/.bash_profile{Environment.NewLine}" +
|
$"cat << EOF >> ~/.bash_profile{Environment.NewLine}" +
|
||||||
$"# Add .NET Core SDK tools{Environment.NewLine}" +
|
$"# Add .NET Core SDK tools{Environment.NewLine}" +
|
||||||
$"export PATH=\"$PATH:{_fullPackageExecutablePath}\"{Environment.NewLine}" +
|
$"export PATH=\"$PATH:{_packageExecutablePath.Path}\"{Environment.NewLine}" +
|
||||||
$"EOF");
|
$"EOF");
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -8,7 +8,7 @@ using System.Text;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker
|
namespace Microsoft.DotNet.ShellShim
|
||||||
{
|
{
|
||||||
public class ShellShimMaker
|
public class ShellShimMaker
|
||||||
{
|
{
|
|
@ -6,7 +6,7 @@ using System.Linq;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker
|
namespace Microsoft.DotNet.ShellShim
|
||||||
{
|
{
|
||||||
internal class WindowsEnvironmentPath : IEnvironmentPath
|
internal class WindowsEnvironmentPath : IEnvironmentPath
|
||||||
{
|
{
|
||||||
|
@ -62,7 +62,7 @@ namespace Microsoft.DotNet.ShellShimMaker
|
||||||
_reporter.WriteLine(
|
_reporter.WriteLine(
|
||||||
$"Cannot find the tools executable path. Please ensure {_packageExecutablePath} is added to your PATH.{Environment.NewLine}" +
|
$"Cannot find the tools executable path. Please ensure {_packageExecutablePath} is added to your PATH.{Environment.NewLine}" +
|
||||||
$"You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
$"You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
||||||
$"setx PATH \\\"%PATH%;{_packageExecutablePath}\"{Environment.NewLine}");
|
$"setx PATH \"%PATH%;{_packageExecutablePath}\"{Environment.NewLine}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal interface IPackageToProjectFileAdder
|
internal interface IPackageToProjectFileAdder
|
||||||
{
|
{
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal interface IProjectRestorer
|
internal interface IProjectRestorer
|
||||||
{
|
{
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal class PackageObtainException : Exception
|
internal class PackageObtainException : Exception
|
||||||
{
|
{
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal class PackageVersion
|
internal class PackageVersion
|
||||||
{
|
{
|
|
@ -2,8 +2,9 @@
|
||||||
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal class ToolConfiguration
|
internal class ToolConfiguration
|
||||||
{
|
{
|
||||||
|
@ -29,13 +30,12 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
|
|
||||||
private void EnsureNoInvalidFilenameCharacters(string commandName, string nameOfParam)
|
private void EnsureNoInvalidFilenameCharacters(string commandName, string nameOfParam)
|
||||||
{
|
{
|
||||||
// https://stackoverflow.com/questions/1976007/what-characters-are-forbidden-in-windows-and-linux-directory-names
|
char[] invalidCharactors = Path.GetInvalidFileNameChars();
|
||||||
char[] invalidCharactors = {'/', '<', '>', ':', '"', '/', '\\', '|', '?', '*'};
|
|
||||||
if (commandName.IndexOfAny(invalidCharactors) != -1)
|
if (commandName.IndexOfAny(invalidCharactors) != -1)
|
||||||
{
|
{
|
||||||
throw new ArgumentException(
|
throw new ArgumentException(
|
||||||
paramName: nameof(nameOfParam),
|
paramName: nameof(nameOfParam),
|
||||||
message: "Cannot contain following character " + new string(invalidCharactors));
|
message: "Contains one or more invalid characters: " + new string(invalidCharactors));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal class ToolConfigurationAndExecutableDirectory
|
internal class ToolConfigurationAndExecutableDirectory
|
||||||
{
|
{
|
|
@ -1,7 +1,7 @@
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Xml.Serialization;
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer.ToolConfigurationDeserialization
|
namespace Microsoft.DotNet.ToolPackage.ToolConfigurationDeserialization
|
||||||
{
|
{
|
||||||
[DebuggerStepThrough]
|
[DebuggerStepThrough]
|
||||||
[XmlRoot(Namespace = "", IsNullable = false)]
|
[XmlRoot(Namespace = "", IsNullable = false)]
|
|
@ -2,7 +2,7 @@
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Xml.Serialization;
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer.ToolConfigurationDeserialization
|
namespace Microsoft.DotNet.ToolPackage.ToolConfigurationDeserialization
|
||||||
{
|
{
|
||||||
[Serializable]
|
[Serializable]
|
||||||
[DebuggerStepThrough]
|
[DebuggerStepThrough]
|
|
@ -5,9 +5,9 @@ using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Xml;
|
using System.Xml;
|
||||||
using System.Xml.Serialization;
|
using System.Xml.Serialization;
|
||||||
using Microsoft.DotNet.ToolPackageObtainer.ToolConfigurationDeserialization;
|
using Microsoft.DotNet.ToolPackage.ToolConfigurationDeserialization;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal static class ToolConfigurationDeserializer
|
internal static class ToolConfigurationDeserializer
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,7 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
catch (InvalidOperationException e) when (e.InnerException is XmlException)
|
catch (InvalidOperationException e) when (e.InnerException is XmlException)
|
||||||
{
|
{
|
||||||
throw new ToolConfigurationException(
|
throw new ToolConfigurationException(
|
||||||
"Failed to retrive tool configuration exception, configuration is malformed xml. " +
|
$"The tool's settings file is invalid xml. {Environment.NewLine}" +
|
||||||
e.InnerException.Message);
|
e.InnerException.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -36,13 +36,13 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
if (dotNetCliTool.Commands.Length != 1)
|
if (dotNetCliTool.Commands.Length != 1)
|
||||||
{
|
{
|
||||||
throw new ToolConfigurationException(
|
throw new ToolConfigurationException(
|
||||||
"Failed to retrive tool configuration exception, one and only one command is supported.");
|
"The tool's settings file has more than one command defined.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dotNetCliTool.Commands[0].Runner != "dotnet")
|
if (dotNetCliTool.Commands[0].Runner != "dotnet")
|
||||||
{
|
{
|
||||||
throw new ToolConfigurationException(
|
throw new ToolConfigurationException(
|
||||||
"Failed to retrive tool configuration exception, only dotnet as runner is supported.");
|
"The tool's settings file has non \"dotnet\" as runner.");
|
||||||
}
|
}
|
||||||
|
|
||||||
var commandName = dotNetCliTool.Commands[0].Name;
|
var commandName = dotNetCliTool.Commands[0].Name;
|
||||||
|
@ -54,7 +54,7 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
}
|
}
|
||||||
catch (ArgumentException e)
|
catch (ArgumentException e)
|
||||||
{
|
{
|
||||||
throw new ToolConfigurationException("Configuration content error. " + e.Message);
|
throw new ToolConfigurationException($"The tool's settings file contains error {Environment.NewLine}" + e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal class ToolConfigurationException : ArgumentException
|
internal class ToolConfigurationException : ArgumentException
|
||||||
{
|
{
|
|
@ -1,10 +1,11 @@
|
||||||
using System;
|
using System;
|
||||||
|
using System.Diagnostics;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Xml.Linq;
|
using System.Xml.Linq;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer
|
namespace Microsoft.DotNet.ToolPackage
|
||||||
{
|
{
|
||||||
internal class ToolPackageObtainer
|
internal class ToolPackageObtainer
|
||||||
{
|
{
|
||||||
|
@ -41,6 +42,14 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
throw new ArgumentNullException(nameof(packageId));
|
throw new ArgumentNullException(nameof(packageId));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (nugetconfig != null)
|
||||||
|
{
|
||||||
|
if (!File.Exists(nugetconfig.Value.Value))
|
||||||
|
{
|
||||||
|
throw new PackageObtainException($"NuGet configuration file {Path.GetFullPath(nugetconfig.Value.Value)} does not exist.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (targetframework == null)
|
if (targetframework == null)
|
||||||
{
|
{
|
||||||
targetframework = _bundledTargetFrameworkMoniker.Value;
|
targetframework = _bundledTargetFrameworkMoniker.Value;
|
||||||
|
@ -48,14 +57,14 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
|
|
||||||
var packageVersionOrPlaceHolder = new PackageVersion(packageVersion);
|
var packageVersionOrPlaceHolder = new PackageVersion(packageVersion);
|
||||||
|
|
||||||
DirectoryPath individualToolVersion =
|
DirectoryPath toolDirectory =
|
||||||
CreateIndividualToolVersionDirectory(packageId, packageVersionOrPlaceHolder);
|
CreateIndividualToolVersionDirectory(packageId, packageVersionOrPlaceHolder);
|
||||||
|
|
||||||
FilePath tempProjectPath = CreateTempProject(
|
FilePath tempProjectPath = CreateTempProject(
|
||||||
packageId,
|
packageId,
|
||||||
packageVersionOrPlaceHolder,
|
packageVersionOrPlaceHolder,
|
||||||
targetframework,
|
targetframework,
|
||||||
individualToolVersion);
|
toolDirectory);
|
||||||
|
|
||||||
if (packageVersionOrPlaceHolder.IsPlaceholder)
|
if (packageVersionOrPlaceHolder.IsPlaceholder)
|
||||||
{
|
{
|
||||||
|
@ -65,31 +74,45 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
packageId);
|
packageId);
|
||||||
}
|
}
|
||||||
|
|
||||||
InvokeRestore(nugetconfig, tempProjectPath, individualToolVersion);
|
InvokeRestore(nugetconfig: nugetconfig, tempProjectPath: tempProjectPath, individualToolVersion: toolDirectory);
|
||||||
|
|
||||||
if (packageVersionOrPlaceHolder.IsPlaceholder)
|
if (packageVersionOrPlaceHolder.IsPlaceholder)
|
||||||
{
|
{
|
||||||
var concreteVersion =
|
var concreteVersion =
|
||||||
new DirectoryInfo(
|
new DirectoryInfo(
|
||||||
Directory.GetDirectories(
|
Directory.GetDirectories(
|
||||||
individualToolVersion.WithSubDirectories(packageId).Value).Single()).Name;
|
toolDirectory.WithSubDirectories(packageId).Value).Single()).Name;
|
||||||
DirectoryPath concreteVersionIndividualToolVersion =
|
DirectoryPath versioned =
|
||||||
individualToolVersion.GetParentPath().WithSubDirectories(concreteVersion);
|
toolDirectory.GetParentPath().WithSubDirectories(concreteVersion);
|
||||||
Directory.Move(individualToolVersion.Value, concreteVersionIndividualToolVersion.Value);
|
|
||||||
|
|
||||||
individualToolVersion = concreteVersionIndividualToolVersion;
|
MoveToVersionedDirectory(versioned, toolDirectory);
|
||||||
|
|
||||||
|
toolDirectory = versioned;
|
||||||
packageVersion = concreteVersion;
|
packageVersion = concreteVersion;
|
||||||
}
|
}
|
||||||
|
|
||||||
ToolConfiguration toolConfiguration = GetConfiguration(packageId, packageVersion, individualToolVersion);
|
ToolConfiguration toolConfiguration = GetConfiguration(packageId: packageId, packageVersion: packageVersion, individualToolVersion: toolDirectory);
|
||||||
|
|
||||||
return new ToolConfigurationAndExecutableDirectory(
|
return new ToolConfigurationAndExecutableDirectory(
|
||||||
toolConfiguration,
|
toolConfiguration,
|
||||||
individualToolVersion.WithSubDirectories(
|
toolDirectory.WithSubDirectories(
|
||||||
packageId,
|
packageId,
|
||||||
packageVersion,
|
packageVersion,
|
||||||
"tools",
|
"tools",
|
||||||
targetframework));
|
targetframework,
|
||||||
|
"any"));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void MoveToVersionedDirectory(
|
||||||
|
DirectoryPath versioned,
|
||||||
|
DirectoryPath temporary)
|
||||||
|
{
|
||||||
|
if (Directory.Exists(versioned.Value))
|
||||||
|
{
|
||||||
|
Directory.Delete(versioned.Value, recursive: true);
|
||||||
|
}
|
||||||
|
|
||||||
|
Directory.Move(temporary.Value, versioned.Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static ToolConfiguration GetConfiguration(
|
private static ToolConfiguration GetConfiguration(
|
||||||
|
@ -100,7 +123,7 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
FilePath toolConfigurationPath =
|
FilePath toolConfigurationPath =
|
||||||
individualToolVersion
|
individualToolVersion
|
||||||
.WithSubDirectories(packageId, packageVersion, "tools")
|
.WithSubDirectories(packageId, packageVersion, "tools")
|
||||||
.WithFile("DotnetToolsConfig.xml");
|
.WithFile("DotnetToolSettings.xml");
|
||||||
|
|
||||||
ToolConfiguration toolConfiguration =
|
ToolConfiguration toolConfiguration =
|
||||||
ToolConfigurationDeserializer.Deserialize(toolConfigurationPath.Value);
|
ToolConfigurationDeserializer.Deserialize(toolConfigurationPath.Value);
|
||||||
|
@ -135,6 +158,7 @@ namespace Microsoft.DotNet.ToolPackageObtainer
|
||||||
new XElement("PropertyGroup",
|
new XElement("PropertyGroup",
|
||||||
new XElement("TargetFramework", targetframework),
|
new XElement("TargetFramework", targetframework),
|
||||||
new XElement("RestorePackagesPath", individualToolVersion.Value),
|
new XElement("RestorePackagesPath", individualToolVersion.Value),
|
||||||
|
new XElement("RestoreSolutionDirectory", Directory.GetCurrentDirectory()), // https://github.com/NuGet/Home/issues/6199
|
||||||
new XElement("DisableImplicitFrameworkReferences", "true")
|
new XElement("DisableImplicitFrameworkReferences", "true")
|
||||||
),
|
),
|
||||||
packageVersion.IsConcreteValue
|
packageVersion.IsConcreteValue
|
36
src/dotnet/commands/dotnet-install/InstallCommand.cs
Normal file
36
src/dotnet/commands/dotnet-install/InstallCommand.cs
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
// Copyright (c) .NET Foundation and contributors. All rights reserved.
|
||||||
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using Microsoft.DotNet.Cli;
|
||||||
|
using Microsoft.DotNet.Cli.CommandLine;
|
||||||
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
|
using Microsoft.DotNet.Tools.Add;
|
||||||
|
using Microsoft.DotNet.Tools.Install.Tool;
|
||||||
|
|
||||||
|
namespace Microsoft.DotNet.Tools.Install
|
||||||
|
{
|
||||||
|
public class InstallCommand : DotNetTopLevelCommandBase
|
||||||
|
{
|
||||||
|
protected override string CommandName => "install";
|
||||||
|
protected override string FullCommandNameLocalized => "NetInstallCommand";
|
||||||
|
protected override string ArgumentName => Constants.ProjectArgumentName;
|
||||||
|
protected override string ArgumentDescriptionLocalized => CommonLocalizableStrings.ArgumentsProjectDescription;
|
||||||
|
|
||||||
|
internal override Dictionary<string, Func<AppliedOption, CommandBase>> SubCommands =>
|
||||||
|
new Dictionary<string, Func<AppliedOption, CommandBase>>
|
||||||
|
{
|
||||||
|
["tool"] =
|
||||||
|
appliedOption => new InstallToolCommand(
|
||||||
|
appliedOption["tool"],
|
||||||
|
ParseResult)
|
||||||
|
};
|
||||||
|
|
||||||
|
public static int Run(string[] args)
|
||||||
|
{
|
||||||
|
var command = new InstallCommand();
|
||||||
|
return command.RunCommand(args);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
19
src/dotnet/commands/dotnet-install/InstallCommandParser.cs
Normal file
19
src/dotnet/commands/dotnet-install/InstallCommandParser.cs
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
// Copyright (c) .NET Foundation and contributors. All rights reserved.
|
||||||
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
|
||||||
|
using Microsoft.DotNet.Cli.CommandLine;
|
||||||
|
|
||||||
|
namespace Microsoft.DotNet.Cli
|
||||||
|
{
|
||||||
|
internal static class InstallCommandParser
|
||||||
|
{
|
||||||
|
public static Command Install()
|
||||||
|
{
|
||||||
|
return Create.Command(
|
||||||
|
"install", "",
|
||||||
|
Accept.NoArguments(),
|
||||||
|
CommonOptions.HelpOption(),
|
||||||
|
InstallToolCommandParser.InstallTool());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,130 @@
|
||||||
|
// Copyright (c) .NET Foundation and contributors. All rights reserved.
|
||||||
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
using Microsoft.DotNet.Cli;
|
||||||
|
using Microsoft.DotNet.Cli.CommandLine;
|
||||||
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
|
using Microsoft.DotNet.Configurer;
|
||||||
|
using Microsoft.DotNet.ShellShim;
|
||||||
|
using Microsoft.DotNet.ToolPackage;
|
||||||
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
|
namespace Microsoft.DotNet.Tools.Install.Tool
|
||||||
|
{
|
||||||
|
public class InstallToolCommand : CommandBase
|
||||||
|
{
|
||||||
|
private static string _packageId;
|
||||||
|
private static string _packageVersion;
|
||||||
|
private static string _configFilePath;
|
||||||
|
private static string _framework;
|
||||||
|
|
||||||
|
public InstallToolCommand(
|
||||||
|
AppliedOption appliedCommand,
|
||||||
|
ParseResult parseResult)
|
||||||
|
: base(parseResult)
|
||||||
|
{
|
||||||
|
if (appliedCommand == null)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException(nameof(appliedCommand));
|
||||||
|
}
|
||||||
|
|
||||||
|
_packageId = appliedCommand.Arguments.Single();
|
||||||
|
_packageVersion = appliedCommand.ValueOrDefault<string>("version");
|
||||||
|
_configFilePath = appliedCommand.ValueOrDefault<string>("configfile");
|
||||||
|
_framework = appliedCommand.ValueOrDefault<string>("framework");
|
||||||
|
}
|
||||||
|
|
||||||
|
public override int Execute()
|
||||||
|
{
|
||||||
|
FilePath? configFile = null;
|
||||||
|
|
||||||
|
if (_configFilePath != null)
|
||||||
|
{
|
||||||
|
configFile = new FilePath(_configFilePath);
|
||||||
|
}
|
||||||
|
|
||||||
|
var executablePackagePath = new DirectoryPath(new CliFolderPathCalculator().ExecutablePackagesPath);
|
||||||
|
|
||||||
|
var toolConfigurationAndExecutableDirectory = ObtainPackage(
|
||||||
|
_packageId,
|
||||||
|
_packageVersion,
|
||||||
|
configFile,
|
||||||
|
_framework,
|
||||||
|
executablePackagePath);
|
||||||
|
|
||||||
|
DirectoryPath executable = toolConfigurationAndExecutableDirectory
|
||||||
|
.ExecutableDirectory
|
||||||
|
.WithSubDirectories(
|
||||||
|
toolConfigurationAndExecutableDirectory
|
||||||
|
.Configuration
|
||||||
|
.ToolAssemblyEntryPoint);
|
||||||
|
|
||||||
|
var shellShimMaker = new ShellShimMaker(executablePackagePath.Value);
|
||||||
|
var commandName = toolConfigurationAndExecutableDirectory.Configuration.CommandName;
|
||||||
|
shellShimMaker.EnsureCommandNameUniqueness(commandName);
|
||||||
|
|
||||||
|
shellShimMaker.CreateShim(
|
||||||
|
executable.Value,
|
||||||
|
commandName);
|
||||||
|
|
||||||
|
EnvironmentPathFactory
|
||||||
|
.CreateEnvironmentPathInstruction()
|
||||||
|
.PrintAddPathInstructionIfPathDoesNotExist();
|
||||||
|
|
||||||
|
Reporter.Output.WriteLine(
|
||||||
|
$"{Environment.NewLine}The installation succeeded. If there is no other instruction. You can type the following command in shell directly to invoke: {commandName}");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static ToolConfigurationAndExecutableDirectory ObtainPackage(
|
||||||
|
string packageId,
|
||||||
|
string packageVersion,
|
||||||
|
FilePath? configFile,
|
||||||
|
string framework,
|
||||||
|
DirectoryPath executablePackagePath)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var toolPackageObtainer =
|
||||||
|
new ToolPackageObtainer(
|
||||||
|
executablePackagePath,
|
||||||
|
() => new DirectoryPath(Path.GetTempPath())
|
||||||
|
.WithSubDirectories(Path.GetRandomFileName())
|
||||||
|
.WithFile(Path.GetRandomFileName() + ".csproj"),
|
||||||
|
new Lazy<string>(BundledTargetFramework.GetTargetFrameworkMoniker),
|
||||||
|
new PackageToProjectFileAdder(),
|
||||||
|
new ProjectRestorer());
|
||||||
|
|
||||||
|
return toolPackageObtainer.ObtainAndReturnExecutablePath(
|
||||||
|
packageId: packageId,
|
||||||
|
packageVersion: packageVersion,
|
||||||
|
nugetconfig: configFile,
|
||||||
|
targetframework: framework);
|
||||||
|
}
|
||||||
|
catch (PackageObtainException ex)
|
||||||
|
{
|
||||||
|
throw new GracefulException(
|
||||||
|
message:
|
||||||
|
$"Install failed. Failed to download package:{Environment.NewLine}" +
|
||||||
|
$"NuGet returned:{Environment.NewLine}" +
|
||||||
|
$"{Environment.NewLine}" +
|
||||||
|
$"{ex.Message}",
|
||||||
|
innerException: ex);
|
||||||
|
}
|
||||||
|
catch (ToolConfigurationException ex)
|
||||||
|
{
|
||||||
|
throw new GracefulException(
|
||||||
|
message:
|
||||||
|
$"Install failed. The settings file in the tool's NuGet package is not valid. Please contact the owner of the NuGet package.{Environment.NewLine}" +
|
||||||
|
$"The error was:{Environment.NewLine}" +
|
||||||
|
$"{Environment.NewLine}" +
|
||||||
|
$"{ex.Message}",
|
||||||
|
innerException: ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,32 @@
|
||||||
|
// Copyright (c) .NET Foundation and contributors. All rights reserved.
|
||||||
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
|
||||||
|
using Microsoft.DotNet.Cli.CommandLine;
|
||||||
|
|
||||||
|
namespace Microsoft.DotNet.Cli
|
||||||
|
{
|
||||||
|
internal static class InstallToolCommandParser
|
||||||
|
{
|
||||||
|
public static Command InstallTool()
|
||||||
|
{
|
||||||
|
return Create.Command("tool",
|
||||||
|
"Install tool",
|
||||||
|
Accept.ExactlyOneArgument(o => "packageId")
|
||||||
|
.With(name: "packageId",
|
||||||
|
description: "Package Id in NuGet"),
|
||||||
|
Create.Option(
|
||||||
|
"--version",
|
||||||
|
"Version of the package in NuGet",
|
||||||
|
Accept.ExactlyOneArgument()),
|
||||||
|
Create.Option(
|
||||||
|
"--configfile",
|
||||||
|
"NuGet configuration file",
|
||||||
|
Accept.ExactlyOneArgument()),
|
||||||
|
Create.Option(
|
||||||
|
"-f|--framework",
|
||||||
|
"Target framework to publish for. The target framework has to be specified in the project file.",
|
||||||
|
Accept.ExactlyOneArgument()),
|
||||||
|
CommonOptions.HelpOption());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,12 +3,12 @@
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Microsoft.DotNet.ToolPackageObtainer;
|
using Microsoft.DotNet.Cli;
|
||||||
|
using Microsoft.DotNet.ToolPackage;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.Cli
|
namespace Microsoft.DotNet.Tools.Install.Tool
|
||||||
{
|
{
|
||||||
|
|
||||||
internal class PackageToProjectFileAdder : IPackageToProjectFileAdder
|
internal class PackageToProjectFileAdder : IPackageToProjectFileAdder
|
||||||
{
|
{
|
||||||
public void Add(FilePath projectPath, string packageId)
|
public void Add(FilePath projectPath, string packageId)
|
|
@ -3,11 +3,12 @@
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Microsoft.DotNet.ToolPackageObtainer;
|
using Microsoft.DotNet.Cli;
|
||||||
|
using Microsoft.DotNet.ToolPackage;
|
||||||
using Microsoft.DotNet.PlatformAbstractions;
|
using Microsoft.DotNet.PlatformAbstractions;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.Cli
|
namespace Microsoft.DotNet.Tools.Install.Tool
|
||||||
{
|
{
|
||||||
internal class ProjectRestorer : IProjectRestorer
|
internal class ProjectRestorer : IProjectRestorer
|
||||||
{
|
{
|
||||||
|
@ -18,11 +19,11 @@ namespace Microsoft.DotNet.Cli
|
||||||
{
|
{
|
||||||
var argsToPassToRestore = new List<string>();
|
var argsToPassToRestore = new List<string>();
|
||||||
|
|
||||||
argsToPassToRestore.Add(projectPath.ToQuotedString());
|
argsToPassToRestore.Add(projectPath.Value);
|
||||||
if (nugetconfig != null)
|
if (nugetconfig != null)
|
||||||
{
|
{
|
||||||
argsToPassToRestore.Add("--configfile");
|
argsToPassToRestore.Add("--configfile");
|
||||||
argsToPassToRestore.Add(nugetconfig.Value.ToQuotedString());
|
argsToPassToRestore.Add(nugetconfig.Value.Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
argsToPassToRestore.AddRange(new List<string>
|
argsToPassToRestore.AddRange(new List<string>
|
|
@ -82,9 +82,9 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "dotnet-clean.Tests", "dotne
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.TestFramework", "Microsoft.DotNet.TestFramework\Microsoft.DotNet.TestFramework.csproj", "{D23AFC9C-8FD5-45DD-A84C-0E6528C42F0E}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.TestFramework", "Microsoft.DotNet.TestFramework\Microsoft.DotNet.TestFramework.csproj", "{D23AFC9C-8FD5-45DD-A84C-0E6528C42F0E}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.ToolPackageObtainer.Tests", "Microsoft.DotNet.ToolPackageObtainer.Tests\Microsoft.DotNet.ToolPackageObtainer.Tests.csproj", "{C2A907A3-677B-4C73-9AA4-E53613E13C78}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.ShellShim.Tests", "Microsoft.DotNet.ShellShim.Tests\Microsoft.DotNet.ShellShim.Tests.csproj", "{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.ShellShimMaker.Tests", "Microsoft.DotNet.ShellShimMaker.Tests\Microsoft.DotNet.ShellShimMaker.Tests.csproj", "{1146EAAC-E434-404A-8198-B4F0CB23BC57}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.DotNet.ToolPackage.Tests", "Microsoft.DotNet.ToolPackage.Tests\Microsoft.DotNet.ToolPackage.Tests.csproj", "{453C809B-40FC-4A93-93B8-DE449D48B9FF}"
|
||||||
EndProject
|
EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
@ -540,30 +540,30 @@ Global
|
||||||
{D23AFC9C-8FD5-45DD-A84C-0E6528C42F0E}.Release|x64.Build.0 = Release|Any CPU
|
{D23AFC9C-8FD5-45DD-A84C-0E6528C42F0E}.Release|x64.Build.0 = Release|Any CPU
|
||||||
{D23AFC9C-8FD5-45DD-A84C-0E6528C42F0E}.Release|x86.ActiveCfg = Release|Any CPU
|
{D23AFC9C-8FD5-45DD-A84C-0E6528C42F0E}.Release|x86.ActiveCfg = Release|Any CPU
|
||||||
{D23AFC9C-8FD5-45DD-A84C-0E6528C42F0E}.Release|x86.Build.0 = Release|Any CPU
|
{D23AFC9C-8FD5-45DD-A84C-0E6528C42F0E}.Release|x86.Build.0 = Release|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Debug|x64.ActiveCfg = Debug|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Debug|x64.ActiveCfg = Debug|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Debug|x64.Build.0 = Debug|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Debug|x64.Build.0 = Debug|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Debug|x86.ActiveCfg = Debug|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Debug|x86.ActiveCfg = Debug|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Debug|x86.Build.0 = Debug|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Debug|x86.Build.0 = Debug|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Release|Any CPU.Build.0 = Release|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Release|x64.ActiveCfg = Release|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Release|x64.ActiveCfg = Release|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Release|x64.Build.0 = Release|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Release|x64.Build.0 = Release|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Release|x86.ActiveCfg = Release|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Release|x86.ActiveCfg = Release|Any CPU
|
||||||
{C2A907A3-677B-4C73-9AA4-E53613E13C78}.Release|x86.Build.0 = Release|Any CPU
|
{1BBF0DFE-2138-4E29-BFA1-49A2F0B4C913}.Release|x86.Build.0 = Release|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Debug|x64.ActiveCfg = Debug|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Debug|x64.ActiveCfg = Debug|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Debug|x64.Build.0 = Debug|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Debug|x64.Build.0 = Debug|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Debug|x86.ActiveCfg = Debug|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Debug|x86.ActiveCfg = Debug|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Debug|x86.Build.0 = Debug|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Debug|x86.Build.0 = Debug|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Release|Any CPU.Build.0 = Release|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Release|x64.ActiveCfg = Release|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Release|x64.ActiveCfg = Release|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Release|x64.Build.0 = Release|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Release|x64.Build.0 = Release|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Release|x86.ActiveCfg = Release|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Release|x86.ActiveCfg = Release|Any CPU
|
||||||
{1146EAAC-E434-404A-8198-B4F0CB23BC57}.Release|x86.Build.0 = Release|Any CPU
|
{453C809B-40FC-4A93-93B8-DE449D48B9FF}.Release|x86.Build.0 = Release|Any CPU
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
||||||
|
|
|
@ -5,7 +5,7 @@ using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker.Tests
|
namespace Microsoft.DotNet.ShellShim.Tests
|
||||||
{
|
{
|
||||||
internal class FakeEnvironmentProvider : IEnvironmentProvider
|
internal class FakeEnvironmentProvider : IEnvironmentProvider
|
||||||
{
|
{
|
|
@ -6,7 +6,7 @@ using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker.Tests
|
namespace Microsoft.DotNet.ShellShim.Tests
|
||||||
{
|
{
|
||||||
internal class FakeFile : IFile
|
internal class FakeFile : IFile
|
||||||
{
|
{
|
|
@ -4,7 +4,7 @@
|
||||||
using System;
|
using System;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker.Tests
|
namespace Microsoft.DotNet.ShellShim.Tests
|
||||||
{
|
{
|
||||||
internal class FakeReporter : IReporter
|
internal class FakeReporter : IReporter
|
||||||
{
|
{
|
|
@ -6,11 +6,12 @@ using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using FluentAssertions;
|
using FluentAssertions;
|
||||||
|
using Microsoft.DotNet.Configurer;
|
||||||
using Microsoft.DotNet.Tools.Test.Utilities;
|
using Microsoft.DotNet.Tools.Test.Utilities;
|
||||||
using Microsoft.Extensions.DependencyModel.Tests;
|
using Microsoft.Extensions.DependencyModel.Tests;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker.Tests
|
namespace Microsoft.DotNet.ShellShim.Tests
|
||||||
{
|
{
|
||||||
public class LinuxEnvironmentPathTests
|
public class LinuxEnvironmentPathTests
|
||||||
{
|
{
|
||||||
|
@ -19,7 +20,7 @@ namespace Microsoft.DotNet.ShellShimMaker.Tests
|
||||||
{
|
{
|
||||||
var fakeReporter = new FakeReporter();
|
var fakeReporter = new FakeReporter();
|
||||||
var linuxEnvironmentPath = new LinuxEnvironmentPath(
|
var linuxEnvironmentPath = new LinuxEnvironmentPath(
|
||||||
@"executable\path",
|
new BashPathUnderHomeDirectory("/myhome", "executable/path"),
|
||||||
fakeReporter,
|
fakeReporter,
|
||||||
new FakeEnvironmentProvider(
|
new FakeEnvironmentProvider(
|
||||||
new Dictionary<string, string>
|
new Dictionary<string, string>
|
||||||
|
@ -32,11 +33,11 @@ namespace Microsoft.DotNet.ShellShimMaker.Tests
|
||||||
|
|
||||||
// similar to https://code.visualstudio.com/docs/setup/mac
|
// similar to https://code.visualstudio.com/docs/setup/mac
|
||||||
fakeReporter.Message.Should().Be(
|
fakeReporter.Message.Should().Be(
|
||||||
$"Cannot find the tools executable path. Please ensure executable\\path is added to your PATH.{Environment.NewLine}" +
|
$"Cannot find the tools executable path. Please ensure /myhome/executable/path is added to your PATH.{Environment.NewLine}" +
|
||||||
$"If you are using bash. You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
$"If you are using bash. You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
||||||
$"cat << EOF >> ~/.bash_profile{Environment.NewLine}" +
|
$"cat << EOF >> ~/.bash_profile{Environment.NewLine}" +
|
||||||
$"# Add .NET Core SDK tools{Environment.NewLine}" +
|
$"# Add .NET Core SDK tools{Environment.NewLine}" +
|
||||||
$"export PATH=\"$PATH:executable\\path\"{Environment.NewLine}" +
|
$"export PATH=\"$PATH:/myhome/executable/path\"{Environment.NewLine}" +
|
||||||
$"EOF");
|
$"EOF");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,12 +46,12 @@ namespace Microsoft.DotNet.ShellShimMaker.Tests
|
||||||
{
|
{
|
||||||
var fakeReporter = new FakeReporter();
|
var fakeReporter = new FakeReporter();
|
||||||
var linuxEnvironmentPath = new LinuxEnvironmentPath(
|
var linuxEnvironmentPath = new LinuxEnvironmentPath(
|
||||||
@"executable\path",
|
new BashPathUnderHomeDirectory("/myhome", "executable/path"),
|
||||||
fakeReporter,
|
fakeReporter,
|
||||||
new FakeEnvironmentProvider(
|
new FakeEnvironmentProvider(
|
||||||
new Dictionary<string, string>
|
new Dictionary<string, string>
|
||||||
{
|
{
|
||||||
{"PATH", @"executable\path"}
|
{"PATH", @"/myhome/executable/path"}
|
||||||
}),
|
}),
|
||||||
FakeFile.Empty);
|
FakeFile.Empty);
|
||||||
|
|
||||||
|
@ -64,7 +65,7 @@ namespace Microsoft.DotNet.ShellShimMaker.Tests
|
||||||
{
|
{
|
||||||
var fakeReporter = new FakeReporter();
|
var fakeReporter = new FakeReporter();
|
||||||
var linuxEnvironmentPath = new LinuxEnvironmentPath(
|
var linuxEnvironmentPath = new LinuxEnvironmentPath(
|
||||||
@"executable\path",
|
new BashPathUnderHomeDirectory("/myhome", "executable/path"),
|
||||||
fakeReporter,
|
fakeReporter,
|
||||||
new FakeEnvironmentProvider(
|
new FakeEnvironmentProvider(
|
||||||
new Dictionary<string, string>
|
new Dictionary<string, string>
|
||||||
|
@ -76,7 +77,9 @@ namespace Microsoft.DotNet.ShellShimMaker.Tests
|
||||||
|
|
||||||
linuxEnvironmentPath.PrintAddPathInstructionIfPathDoesNotExist();
|
linuxEnvironmentPath.PrintAddPathInstructionIfPathDoesNotExist();
|
||||||
|
|
||||||
fakeReporter.Message.Should().Be("Since you just installed the .NET Core SDK, you will need to logout or restart your session before running the tool you installed.");
|
fakeReporter.Message.Should()
|
||||||
|
.Be(
|
||||||
|
"Since you just installed the .NET Core SDK, you will need to logout or restart your session before running the tool you installed.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -6,11 +6,12 @@ using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using FluentAssertions;
|
using FluentAssertions;
|
||||||
|
using Microsoft.DotNet.Configurer;
|
||||||
using Microsoft.DotNet.Tools.Test.Utilities;
|
using Microsoft.DotNet.Tools.Test.Utilities;
|
||||||
using Microsoft.Extensions.DependencyModel.Tests;
|
using Microsoft.Extensions.DependencyModel.Tests;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker.Tests
|
namespace Microsoft.DotNet.ShellShim.Tests
|
||||||
{
|
{
|
||||||
public class OsxEnvironmentPathTests
|
public class OsxEnvironmentPathTests
|
||||||
{
|
{
|
||||||
|
@ -19,8 +20,7 @@ namespace Microsoft.DotNet.ShellShimMaker.Tests
|
||||||
{
|
{
|
||||||
var fakeReporter = new FakeReporter();
|
var fakeReporter = new FakeReporter();
|
||||||
var osxEnvironmentPath = new OSXEnvironmentPath(
|
var osxEnvironmentPath = new OSXEnvironmentPath(
|
||||||
@"~/executable/path",
|
new BashPathUnderHomeDirectory("/myhome", "executable/path"),
|
||||||
@"/Users/name/executable/path",
|
|
||||||
fakeReporter,
|
fakeReporter,
|
||||||
new FakeEnvironmentProvider(
|
new FakeEnvironmentProvider(
|
||||||
new Dictionary<string, string>
|
new Dictionary<string, string>
|
||||||
|
@ -33,23 +33,22 @@ namespace Microsoft.DotNet.ShellShimMaker.Tests
|
||||||
|
|
||||||
// similar to https://code.visualstudio.com/docs/setup/mac
|
// similar to https://code.visualstudio.com/docs/setup/mac
|
||||||
fakeReporter.Message.Should().Be(
|
fakeReporter.Message.Should().Be(
|
||||||
$"Cannot find the tools executable path. Please ensure /Users/name/executable/path is added to your PATH.{Environment.NewLine}" +
|
$"Cannot find the tools executable path. Please ensure /myhome/executable/path is added to your PATH.{Environment.NewLine}" +
|
||||||
$"If you are using bash, You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
$"If you are using bash, You can do this by running the following command:{Environment.NewLine}{Environment.NewLine}" +
|
||||||
$"cat << EOF >> ~/.bash_profile{Environment.NewLine}" +
|
$"cat << EOF >> ~/.bash_profile{Environment.NewLine}" +
|
||||||
$"# Add .NET Core SDK tools{Environment.NewLine}" +
|
$"# Add .NET Core SDK tools{Environment.NewLine}" +
|
||||||
$"export PATH=\"$PATH:/Users/name/executable/path\"{Environment.NewLine}" +
|
$"export PATH=\"$PATH:/myhome/executable/path\"{Environment.NewLine}" +
|
||||||
$"EOF");
|
$"EOF");
|
||||||
}
|
}
|
||||||
|
|
||||||
[Theory]
|
[Theory]
|
||||||
[InlineData("/Users/name/executable/path")]
|
[InlineData("/myhome/executable/path")]
|
||||||
[InlineData("~/executable/path")]
|
[InlineData("~/executable/path")]
|
||||||
public void GivenEnvironmentAndReporterItPrintsNothingWhenenvironmentExists(string existingPath)
|
public void GivenEnvironmentAndReporterItPrintsNothingWhenenvironmentExists(string existingPath)
|
||||||
{
|
{
|
||||||
var fakeReporter = new FakeReporter();
|
var fakeReporter = new FakeReporter();
|
||||||
var osxEnvironmentPath = new OSXEnvironmentPath(
|
var osxEnvironmentPath = new OSXEnvironmentPath(
|
||||||
@"~/executable/path",
|
new BashPathUnderHomeDirectory("/myhome", "executable/path"),
|
||||||
@"/Users/name/executable/path",
|
|
||||||
fakeReporter,
|
fakeReporter,
|
||||||
new FakeEnvironmentProvider(
|
new FakeEnvironmentProvider(
|
||||||
new Dictionary<string, string>
|
new Dictionary<string, string>
|
||||||
|
@ -68,8 +67,7 @@ namespace Microsoft.DotNet.ShellShimMaker.Tests
|
||||||
{
|
{
|
||||||
var fakeReporter = new FakeReporter();
|
var fakeReporter = new FakeReporter();
|
||||||
var osxEnvironmentPath = new OSXEnvironmentPath(
|
var osxEnvironmentPath = new OSXEnvironmentPath(
|
||||||
@"~/executable/path",
|
new BashPathUnderHomeDirectory("/myhome", "executable/path"),
|
||||||
@"/Users/name/executable/path",
|
|
||||||
fakeReporter,
|
fakeReporter,
|
||||||
new FakeEnvironmentProvider(
|
new FakeEnvironmentProvider(
|
||||||
new Dictionary<string, string>
|
new Dictionary<string, string>
|
|
@ -12,7 +12,7 @@ using Microsoft.DotNet.TestFramework;
|
||||||
using Microsoft.DotNet.Tools.Test.Utilities;
|
using Microsoft.DotNet.Tools.Test.Utilities;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ShellShimMaker.Tests
|
namespace Microsoft.DotNet.ShellShim.Tests
|
||||||
{
|
{
|
||||||
public class ShellShimMakerTests : TestBase
|
public class ShellShimMakerTests : TestBase
|
||||||
{
|
{
|
|
@ -24,13 +24,13 @@
|
||||||
<PackageReference Include="System.ComponentModel.TypeConverter" Version="4.3.0" />
|
<PackageReference Include="System.ComponentModel.TypeConverter" Version="4.3.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Update="DotnetToolsConfigMissing.xml">
|
<None Update="DotnetToolSettingsMissing.xml">
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||||
</None>
|
</None>
|
||||||
<None Update="DotnetToolsConfigMalformed.xml">
|
<None Update="DotnetToolSettingsMalformed.xml">
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||||
</None>
|
</None>
|
||||||
<None Update="DotnetToolsConfigGolden.xml">
|
<None Update="DotnetToolSettingsGolden.xml">
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||||
</None>
|
</None>
|
||||||
<None Update="TestAssetLocalNugetFeed/*.*">
|
<None Update="TestAssetLocalNugetFeed/*.*">
|
||||||
|
@ -47,7 +47,7 @@
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<testAssetSourceRoot>$(BaseOutputPath)/TestAsset/SampleGlobalTool</testAssetSourceRoot>
|
<testAssetSourceRoot>$(BaseOutputPath)/TestAsset/SampleGlobalTool</testAssetSourceRoot>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<Copy SourceFiles="SampleGlobalTool/DotnetToolsConfig.xml" DestinationFolder="$(testAssetSourceRoot)" />
|
<Copy SourceFiles="SampleGlobalTool/DotnetToolSettings.xml" DestinationFolder="$(testAssetSourceRoot)" />
|
||||||
<MSBuild BuildInParallel="False" Projects="SampleGlobalTool/consoledemo.csproj" Targets="Restore;Build;Publish" Properties="Configuration=Release;BaseOutputPath=$(testAssetSourceRoot)/bin/">
|
<MSBuild BuildInParallel="False" Projects="SampleGlobalTool/consoledemo.csproj" Targets="Restore;Build;Publish" Properties="Configuration=Release;BaseOutputPath=$(testAssetSourceRoot)/bin/">
|
||||||
</MSBuild>
|
</MSBuild>
|
||||||
<MSBuild BuildInParallel="False" Projects="SampleGlobalTool/consoledemo.csproj" Targets="pack" Properties="Configuration=Release;NuspecFile=includepublish.nuspec;NuspecBasePath=$(testAssetSourceRoot);PackageOutputPath=$(OutputPath)/TestAssetLocalNugetFeed">
|
<MSBuild BuildInParallel="False" Projects="SampleGlobalTool/consoledemo.csproj" Targets="pack" Properties="Configuration=Release;NuspecFile=includepublish.nuspec;NuspecBasePath=$(testAssetSourceRoot);PackageOutputPath=$(OutputPath)/TestAssetLocalNugetFeed">
|
|
@ -7,7 +7,7 @@
|
||||||
<authors>testauthor</authors>
|
<authors>testauthor</authors>
|
||||||
</metadata>
|
</metadata>
|
||||||
<files>
|
<files>
|
||||||
<file src="bin\Release\netcoreapp2.1\publish\*.*" target="tools\netcoreapp2.1\" />
|
<file src="bin\Release\netcoreapp2.1\publish\*.*" target="tools\netcoreapp2.1\any\" />
|
||||||
<file src="DotnetToolsConfig.xml" target="tools\DotnetToolsConfig.xml" />
|
<file src="DotnetToolSettings.xml" target="tools\DotnetToolSettings.xml" />
|
||||||
</files>
|
</files>
|
||||||
</package>
|
</package>
|
|
@ -9,14 +9,14 @@ using FluentAssertions;
|
||||||
using NuGet.Protocol.Core.Types;
|
using NuGet.Protocol.Core.Types;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer.Tests
|
namespace Microsoft.DotNet.ToolPackage.Tests
|
||||||
{
|
{
|
||||||
public class ToolConfigurationDeserializerTests
|
public class ToolConfigurationDeserializerTests
|
||||||
{
|
{
|
||||||
[Fact]
|
[Fact]
|
||||||
public void GivenXmlPathItShouldGetToolConfiguration()
|
public void GivenXmlPathItShouldGetToolConfiguration()
|
||||||
{
|
{
|
||||||
ToolConfiguration toolConfiguration = ToolConfigurationDeserializer.Deserialize("DotnetToolsConfigGolden.xml");
|
ToolConfiguration toolConfiguration = ToolConfigurationDeserializer.Deserialize("DotnetToolSettingsGolden.xml");
|
||||||
|
|
||||||
toolConfiguration.CommandName.Should().Be("sayhello");
|
toolConfiguration.CommandName.Should().Be("sayhello");
|
||||||
toolConfiguration.ToolAssemblyEntryPoint.Should().Be("console.dll");
|
toolConfiguration.ToolAssemblyEntryPoint.Should().Be("console.dll");
|
||||||
|
@ -25,28 +25,28 @@ namespace Microsoft.DotNet.ToolPackageObtainer.Tests
|
||||||
[Fact]
|
[Fact]
|
||||||
public void GivenMalformedPathItThrows()
|
public void GivenMalformedPathItThrows()
|
||||||
{
|
{
|
||||||
Action a = () => ToolConfigurationDeserializer.Deserialize("DotnetToolsConfigMalformed.xml");
|
Action a = () => ToolConfigurationDeserializer.Deserialize("DotnetToolSettingsMalformed.xml");
|
||||||
a.ShouldThrow<ToolConfigurationException>()
|
a.ShouldThrow<ToolConfigurationException>()
|
||||||
.And.Message.Should()
|
.And.Message.Should()
|
||||||
.Contain("Failed to retrive tool configuration exception, configuration is malformed xml");
|
.Contain("The tool's settings file is invalid xml");
|
||||||
}
|
}
|
||||||
|
|
||||||
[Fact]
|
[Fact]
|
||||||
public void GivenMissingContentItThrows()
|
public void GivenMissingContentItThrows()
|
||||||
{
|
{
|
||||||
Action a = () => ToolConfigurationDeserializer.Deserialize("DotnetToolsConfigMissing.xml");
|
Action a = () => ToolConfigurationDeserializer.Deserialize("DotnetToolSettingsMissing.xml");
|
||||||
a.ShouldThrow<ToolConfigurationException>()
|
a.ShouldThrow<ToolConfigurationException>()
|
||||||
.And.Message.Should()
|
.And.Message.Should()
|
||||||
.Contain("Configuration content error");
|
.Contain("The tool's settings file contains error");
|
||||||
}
|
}
|
||||||
|
|
||||||
[Fact]
|
[Fact]
|
||||||
public void GivenInvalidCharAsFileNameItThrows()
|
public void GivenInvalidCharAsFileNameItThrows()
|
||||||
{
|
{
|
||||||
Action a = () => new ToolConfiguration("na***me", "my.dll");
|
Action a = () => new ToolConfiguration("na\0me", "my.dll");
|
||||||
a.ShouldThrow<ArgumentException>()
|
a.ShouldThrow<ArgumentException>()
|
||||||
.And.Message.Should()
|
.And.Message.Should()
|
||||||
.Contain("Cannot contain following character");
|
.Contain("Contains one or more invalid characters");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -7,9 +7,10 @@ using FluentAssertions;
|
||||||
using Microsoft.DotNet.Tools.Test.Utilities;
|
using Microsoft.DotNet.Tools.Test.Utilities;
|
||||||
using Microsoft.Extensions.EnvironmentAbstractions;
|
using Microsoft.Extensions.EnvironmentAbstractions;
|
||||||
using Microsoft.DotNet.Cli;
|
using Microsoft.DotNet.Cli;
|
||||||
|
using Microsoft.DotNet.Tools.Install.Tool;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
|
||||||
namespace Microsoft.DotNet.ToolPackageObtainer.Tests
|
namespace Microsoft.DotNet.ToolPackage.Tests
|
||||||
{
|
{
|
||||||
public class ToolPackageObtainerTests : TestBase
|
public class ToolPackageObtainerTests : TestBase
|
||||||
{
|
{
|
||||||
|
@ -60,6 +61,7 @@ namespace Microsoft.DotNet.ToolPackageObtainer.Tests
|
||||||
.GetParentPath()
|
.GetParentPath()
|
||||||
.GetParentPath()
|
.GetParentPath()
|
||||||
.GetParentPath()
|
.GetParentPath()
|
||||||
|
.GetParentPath()
|
||||||
.WithFile("project.assets.json").Value;
|
.WithFile("project.assets.json").Value;
|
||||||
|
|
||||||
File.Exists(assetJsonPath)
|
File.Exists(assetJsonPath)
|
||||||
|
@ -78,13 +80,10 @@ namespace Microsoft.DotNet.ToolPackageObtainer.Tests
|
||||||
Directory.CreateDirectory(tempProjectDirectory.Value);
|
Directory.CreateDirectory(tempProjectDirectory.Value);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* No nuget config means you don't need nuget config passed in during call
|
* In test, we don't want NuGet to keep look up, so we point current directory to nugetconfig.
|
||||||
* NuGet needs a way to find the package, in production, it will keep look up folders for Nuget.Config
|
|
||||||
* and use the feed there.
|
|
||||||
* In test, we don't want NuGet to keep look up, so we just copy paste beside the project.
|
|
||||||
*/
|
*/
|
||||||
File.Copy(nugetConfigPath.Value,
|
|
||||||
tempProjectDirectory.WithFile("nuget.config").Value);
|
Directory.SetCurrentDirectory(nugetConfigPath.GetDirectoryPath().Value);
|
||||||
|
|
||||||
var packageObtainer =
|
var packageObtainer =
|
||||||
new ToolPackageObtainer(
|
new ToolPackageObtainer(
|
||||||
|
@ -135,6 +134,29 @@ namespace Microsoft.DotNet.ToolPackageObtainer.Tests
|
||||||
.BeTrue(executable + " should have the executable");
|
.BeTrue(executable + " should have the executable");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public void GivenAllButNoPackageVersionAndInvokeTwiceItShouldNotThrow()
|
||||||
|
{
|
||||||
|
var nugetConfigPath = WriteNugetConfigFileToPointToTheFeed();
|
||||||
|
var toolsPath = Path.Combine(Directory.GetCurrentDirectory(), Path.GetRandomFileName());
|
||||||
|
|
||||||
|
var packageObtainer =
|
||||||
|
ConstructDefaultPackageObtainer(toolsPath);
|
||||||
|
|
||||||
|
packageObtainer.ObtainAndReturnExecutablePath(
|
||||||
|
packageId: TestPackageId,
|
||||||
|
nugetconfig: nugetConfigPath,
|
||||||
|
targetframework: _testTargetframework);
|
||||||
|
|
||||||
|
Action secondCall = () => packageObtainer.ObtainAndReturnExecutablePath(
|
||||||
|
packageId: TestPackageId,
|
||||||
|
nugetconfig: nugetConfigPath,
|
||||||
|
targetframework: _testTargetframework);
|
||||||
|
|
||||||
|
secondCall.ShouldNotThrow();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
[Fact]
|
[Fact]
|
||||||
public void GivenAllButNoTargetFrameworkItCanDownloadThePackage()
|
public void GivenAllButNoTargetFrameworkItCanDownloadThePackage()
|
||||||
{
|
{
|
||||||
|
@ -166,6 +188,25 @@ namespace Microsoft.DotNet.ToolPackageObtainer.Tests
|
||||||
.BeTrue(executable + " should have the executable");
|
.BeTrue(executable + " should have the executable");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public void GivenNonExistentNugetConfigFileItThrows()
|
||||||
|
{
|
||||||
|
var toolsPath = Path.Combine(Directory.GetCurrentDirectory(), Path.GetRandomFileName());
|
||||||
|
|
||||||
|
var packageObtainer =
|
||||||
|
ConstructDefaultPackageObtainer(toolsPath);
|
||||||
|
Action a = () => packageObtainer.ObtainAndReturnExecutablePath(
|
||||||
|
packageId: TestPackageId,
|
||||||
|
packageVersion: TestPackageVersion,
|
||||||
|
nugetconfig: new FilePath("NonExistent.file"),
|
||||||
|
targetframework: _testTargetframework);
|
||||||
|
|
||||||
|
a.ShouldThrow<PackageObtainException>()
|
||||||
|
.And
|
||||||
|
.Message.Should().Contain("does not exist");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private static readonly Func<FilePath> GetUniqueTempProjectPathEachTest = () =>
|
private static readonly Func<FilePath> GetUniqueTempProjectPathEachTest = () =>
|
||||||
{
|
{
|
||||||
var tempProjectDirectory =
|
var tempProjectDirectory =
|
||||||
|
@ -187,18 +228,24 @@ namespace Microsoft.DotNet.ToolPackageObtainer.Tests
|
||||||
|
|
||||||
private static FilePath WriteNugetConfigFileToPointToTheFeed()
|
private static FilePath WriteNugetConfigFileToPointToTheFeed()
|
||||||
{
|
{
|
||||||
var nugetConfigName = Path.GetRandomFileName() + ".config";
|
var nugetConfigName = "nuget.config";
|
||||||
var executeDirectory =
|
var executeDirectory =
|
||||||
Path.GetDirectoryName(
|
Path.GetDirectoryName(
|
||||||
System.Reflection
|
System.Reflection
|
||||||
.Assembly
|
.Assembly
|
||||||
.GetExecutingAssembly()
|
.GetExecutingAssembly()
|
||||||
.Location);
|
.Location);
|
||||||
|
|
||||||
|
var tempPathForNugetConfigWithWhiteSpace =
|
||||||
|
Path.Combine(Path.GetTempPath(),
|
||||||
|
Path.GetRandomFileName() + " " + Path.GetRandomFileName());
|
||||||
|
Directory.CreateDirectory(tempPathForNugetConfigWithWhiteSpace);
|
||||||
|
|
||||||
NuGetConfig.Write(
|
NuGetConfig.Write(
|
||||||
directory: executeDirectory,
|
directory: tempPathForNugetConfigWithWhiteSpace,
|
||||||
configname: nugetConfigName,
|
configname: nugetConfigName,
|
||||||
localFeedPath: Path.Combine(executeDirectory, "TestAssetLocalNugetFeed"));
|
localFeedPath: Path.Combine(executeDirectory, "TestAssetLocalNugetFeed"));
|
||||||
return new FilePath(Path.GetFullPath(nugetConfigName));
|
return new FilePath(Path.GetFullPath(Path.Combine(tempPathForNugetConfigWithWhiteSpace, nugetConfigName)));
|
||||||
}
|
}
|
||||||
|
|
||||||
private readonly string _testTargetframework = BundledTargetFramework.GetTargetFrameworkMoniker();
|
private readonly string _testTargetframework = BundledTargetFramework.GetTargetFrameworkMoniker();
|
52
test/dotnet.Tests/ParserTests/InstallToolParserTests.cs
Normal file
52
test/dotnet.Tests/ParserTests/InstallToolParserTests.cs
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
// Copyright (c) .NET Foundation and contributors. All rights reserved.
|
||||||
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
|
||||||
|
using System.Linq;
|
||||||
|
using FluentAssertions;
|
||||||
|
using Microsoft.DotNet.Cli;
|
||||||
|
using Microsoft.DotNet.Cli.CommandLine;
|
||||||
|
using Xunit;
|
||||||
|
using Xunit.Abstractions;
|
||||||
|
using Parser = Microsoft.DotNet.Cli.Parser;
|
||||||
|
|
||||||
|
namespace Microsoft.DotNet.Tests.ParserTests
|
||||||
|
{
|
||||||
|
public class InstallToolParserTests
|
||||||
|
{
|
||||||
|
private readonly ITestOutputHelper output;
|
||||||
|
|
||||||
|
public InstallToolParserTests(ITestOutputHelper output)
|
||||||
|
{
|
||||||
|
this.output = output;
|
||||||
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public void InstallGlobaltoolParserCanGetPackageIdAndPackageVersion()
|
||||||
|
{
|
||||||
|
var command = Parser.Instance;
|
||||||
|
var result = command.Parse("dotnet install tool console.test.app --version 1.0.1");
|
||||||
|
|
||||||
|
var parseResult = result["dotnet"]["install"]["tool"];
|
||||||
|
|
||||||
|
var packageId = parseResult.Arguments.Single();
|
||||||
|
var packageVersion = parseResult.ValueOrDefault<string>("version");
|
||||||
|
|
||||||
|
packageId.Should().Be("console.test.app");
|
||||||
|
packageVersion.Should().Be("1.0.1");
|
||||||
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public void InstallGlobaltoolParserCanGetFollowingArguments()
|
||||||
|
{
|
||||||
|
var command = Parser.Instance;
|
||||||
|
var result =
|
||||||
|
command.Parse(
|
||||||
|
@"dotnet install tool console.test.app --version 1.0.1 --framework netcoreapp2.0 --configfile C:\TestAssetLocalNugetFeed");
|
||||||
|
|
||||||
|
var parseResult = result["dotnet"]["install"]["tool"];
|
||||||
|
|
||||||
|
parseResult.ValueOrDefault<string>("configfile").Should().Be(@"C:\TestAssetLocalNugetFeed");
|
||||||
|
parseResult.ValueOrDefault<string>("framework").Should().Be("netcoreapp2.0");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue