Ejemplo n.º 1
0
        private void cmdInicializar_Click(object sender, EventArgs e)
        {
            var gestor = new IssueManager();

            try
            {
                gestor.BeginTransaction();

                gestor.EjecutarSql(kVersionUp);
                gestor.EjecutarSql(kBitacoraActualizacionUp);

                gestor.CommitTransaction();
            }
            catch (Exception ex)
            {
                gestor.RollbackTransaction();
                frmMensaje frm = new frmMensaje();
                frm.Mensaje = "Se produjo un error inicializando la base de datos.";
                frm.Detalle = ex.Message + "\n" + "\n" + ex.StackTrace;
                frm.ShowDialog();
            }

            ReadAndLoadData();
        }
Ejemplo n.º 2
0
        private void cmdRegistrar_Click(object sender, EventArgs e)
        {
            string mensaje =
                "Al registrar un paquete, los scripts no se aplican (no hay execucion de los scripts), solo se registran en la base de datos como aplicados. Esta opcion se utiliza para que en la base de datos figuren los scripts aplicados manualmente. ¿Desea continuar?";

            if (MessageBox.Show(mensaje, "Atención", MessageBoxButtons.YesNo) == DialogResult.Yes)
            {
                this.Cursor = Cursors.WaitCursor;

                if (txtSourceFolder.Text == string.Empty)
                {
                    MessageBox.Show("Debe indicar la carpeta origen. La misma debe contener las incidencias a aplicar");
                    this.Cursor = Cursors.Default;
                    return;
                }

                try
                {
                    var    gestor           = new IssueManager();
                    string directorioActual = string.Empty;
                    string scriptActual     = string.Empty;

                    try
                    {
                        var listaIncidencias = ObtenerIncidenciasSeleccionadas(tvwSource, SortDirection.Ascending);
                        gestor.BeginTransaction();

                        foreach (IssueEntity incidencia in listaIncidencias)
                        {
                            directorioActual = incidencia.Nombre;

                            foreach (ScriptEntity script in incidencia.Scripts.Values)
                            {
                                scriptActual = script.Nombre;
                                gestor.RegistrarAplicacionDeScript(script);
                            }

                            DeseleccionarNodo(tvwSource, incidencia);
                        }

                        gestor.CommitTransaction();
                    }
                    catch (Exception ex)
                    {
                        gestor.RollbackTransaction();
                        frmMensaje frm = new frmMensaje();
                        frm.Mensaje = string.Format("Se ha producido un error al aplicar el script {0} de la incidencia {1}.", scriptActual, directorioActual);
                        frm.Detalle = ex.Message + "\n" + "\n" + ex.StackTrace;
                        frm.ShowDialog();
                    }

                    LeerIncidenciasAplicadas();
                }
                catch (ApplicationException appEx)
                {
                    MessageBox.Show(appEx.Message);
                }

                this.Cursor = Cursors.Default;
            }
        }
Ejemplo n.º 3
0
        private void cmdDeploy_Click(object sender, EventArgs e)
        {
            this.Cursor = Cursors.WaitCursor;

            if (txtSourceFolder.Text == string.Empty)
            {
                string mensaje = "Debe indicar la carpeta origen. La misma debe contener las incidencias a aplicar";
                MessageBox.Show(mensaje);
                this.Cursor = Cursors.Default;
                return;
            }

            try
            {
                var    gestor           = new IssueManager();
                string directorioActual = string.Empty;
                string scriptActual     = string.Empty;

                try
                {
                    var listaIncidencias = ObtenerIncidenciasSeleccionadas(tvwSource, SortDirection.Ascending);
                    gestor.BeginTransaction();

                    foreach (IssueEntity incidencia in listaIncidencias)
                    {
                        directorioActual = incidencia.Nombre;

                        foreach (ScriptEntity script in incidencia.Scripts.Values)
                        {
                            scriptActual = script.Nombre;
                            gestor.AplicarScript(script);
                            gestor.SaveTransaction(script.Nombre + "_" + script.Secuencia);
                        }

                        DeseleccionarNodo(tvwSource, incidencia);

                        incidencia.Aplicada = true;
                    }

                    gestor.CommitTransaction();
                }
                catch (Exception ex)
                {
                    gestor.RollbackTransaction();
                    var listaIncidencias = ObtenerIncidenciasSeleccionadas(tvwSource, SortDirection.Ascending);
                    foreach (var i in listaIncidencias)
                    {
                        i.Aplicada = false;
                    }

                    frmMensaje frm = new frmMensaje();
                    frm.Mensaje = string.Format("Se ha producido un error al aplicar el script {0} de la incidencia {1}.", scriptActual, directorioActual);
                    frm.Detalle = ex.Message + "\n" + "\n" + ex.StackTrace;
                    frm.ShowDialog();
                }

                LeerIncidenciasAplicadas();
                LeerRepositorioDeIncidencias();
                MostrarIncidenciasAplicadas();
                MostrarRepositorioDeIncidencias();
            }
            catch (ApplicationException appEx)
            {
                MessageBox.Show(appEx.Message);
            }

            this.Cursor = Cursors.Default;
        }