Usando Drush Site-Install en C #

Estoy tratando de hacer una instalación del sitio Drupal usando Drush en C # como parte de una instalación completa del sitio de Windows Server utilizando MSI. El comando Drush que estoy usando es el siguiente.

C:\ProgramData\Drush\Drush.bat -y si application_name --db-url=sqlsrv://admin_name:password(local)\SQLEXPRESS:/database_name --account-name=admin [email protected] --account-pass=Password1234 --site-mail="[email protected]" --site-name="Site Name" install_configure_form.site_default_country=GB install_configure_form.date_default_timezone="Europe/London"

Y esto funciona perfectamente cuando se ejecuta desde cmd.exe cuando está en el directorio de trabajo (inetpub \ application_name).

El problema surge cuando lo anterior se coloca en el código y se ejecuta durante una instalación y siempre produce el siguiente error (con un nombre de archivo diferente cada vez).

No se puede descomprimir C: \ ProgramData \ Drush \ lib \ druFD63.tmp.gz

El código C # que se utiliza para ejecutar el comando es el siguiente:

public static ActionResult Drush_Configuration(Session session)
    {       
        string strArgs = "-y si application_name --db-url=sqlsrv://admin_name:password(local)\SQLEXPRESS:/database_name --account-name=admin [email protected] --account-pass=Password1234 --site-mail="[email protected]" --site-name="Site Name" install_configure_form.site_default_country=GB install_configure_form.date_default_timezone="Europe/London";
        string strExeCmd = @"C:\ProgramData\Drush\Drush.bat ";
        strExeCmd = strExeCmd + strArgs;
        string strLocation = @"C:\inetpub\application_name";

        session.Log("Starting Drush Configuration");
        session.Log("Command line is: " + strExeCmd + " " + strArgs);

        int exitCode;
        ProcessStartInfo processInfo;
        Process process;
        try
        {
            processInfo = new ProcessStartInfo("cmd.exe", "/c " + strExeCmd);
            processInfo.WorkingDirectory = strLocation;
            processInfo.WindowStyle = ProcessWindowStyle.Normal;
            processInfo.CreateNoWindow = true;
            processInfo.UseShellExecute = false;
            // *** Redirect the output ***
            processInfo.RedirectStandardError = true;
            processInfo.RedirectStandardOutput = true;

            process = Process.Start(processInfo);
            process.WaitForExit();

            // *** Read the streams ***
            string output = process.StandardOutput.ReadToEnd();
            string error = process.StandardError.ReadToEnd();

            exitCode = process.ExitCode;

            session.Log("output>>" + (String.IsNullOrEmpty(output) ? "(none)" : output));
            session.Log("error>>" + (String.IsNullOrEmpty(error) ? "(none)" : error));
            session.Log("ExitCode: " + exitCode.ToString(), "ExecuteCommand");
            process.Close();
        }
        catch (Exception e)
        {
            session.Log("Error: " + e);
            return ActionResult.Failure;
        }

        session.Log("Drush Configuration completed successfully");
        return ActionResult.Success;
    }

Y como se indicó anteriormente, esto siempre da como resultado el error "no se puede descomprimir".

¿Alguna vez alguien ha usado c # para ejecutar Site-Install en Drush? ¿Alguien sabe por qué esto puede fallar cuando se ejecuta de esta manera?

Cualquier pensamiento o consejo sería muy apreciado.

Estoy usando Drush-5.8-2012-12-10-Installer-v1.0.20, Drupal 7 y Windows Server 2008 R2 x64.

Respuestas a la pregunta(1)

Su respuesta a la pregunta