Ejemplo n.º 1
0
        protected override bool DoExecute()
        {
            if (!base.DoExecute())
                return false;

            if (!File.Exists(PackagePath))
            {
                LogError($"Provided path {PackagePath} is invalid. File does not exist.");
                return false;
            }

            string arguments = "push";

            if (!string.IsNullOrWhiteSpace(Source))
                arguments += $" -source {Source}";

            arguments += $" \"{PackagePath}\"";

            if (!string.IsNullOrWhiteSpace(ApiKey))
                arguments += $" {ApiKey}";

            var psi = new ProcessStartInfo(NuGetExePath);
            psi.Arguments = arguments;

            LogInformation($"Executing:  \"{NuGetExePath}\" {psi.Arguments}");

            var std_output = string.Empty;
            var std_err = string.Empty;
            var exit_code = -1;

            if(psi.StartAndWaitForExit(TimeSpan.FromMilliseconds(TimeOut), out exit_code, out std_output, out std_err) && std_err.IsNullOrEmpty())
            {
                LogInformation($"NuGet Push complete.");
                LogVerbose("NuGet Output: " + std_output);
                return true;
            }
            else
            { 
                LogError($"NuGet Push failed with exit code {exit_code}, {std_err}");
                return false;
            }
        }
        protected override bool DoExecute()
        {
            if (!base.DoExecute())
                return false;

            if (!File.Exists(SolutionPath))
            {
                LogError($"Provided path {SolutionPath} is invalid. File does not exist.");
                return false;
            }

            string arguments = "restore";

            arguments += $" \"{SolutionPath}\"";

            if (!Source.IsNullOrEmpty())
                arguments += $" -source \"{Source}\"";

            if (!MSBuildVersion.IsNullOrEmpty())
                arguments += $" -MSBuildVersion {MSBuildVersion}";

            var psi = new ProcessStartInfo(NuGetExePath);
            psi.Arguments = arguments;

            LogInformation($"Executing:  \"{NuGetExePath}\" {psi.Arguments}");

            var std_output = string.Empty;
            var std_err = string.Empty;
            var exit_code = -1;

            if (psi.StartAndWaitForExit(TimeSpan.FromMilliseconds(TimeOut), out exit_code, out std_output, out std_err) && std_err.IsNullOrEmpty())
            {
                LogInformation($"NuGet Restore complete.");
                LogVerbose("NuGet Output: " + std_output);
                return true;
            }
            else
            {
                LogError($"NuGet Restore failed with exit code {exit_code}, {std_err}");
                return false;
            }
        }