Wiki

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 50

TALLER DE INGENIERA SE SOFTWARE

HIGINIO NAVA BAUTISTA


MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

UNIDAD 1: ESTNDARES Y MODELOS DE CALIDAD APLICADOS AL


SOFTWARE
1.1 ISO
La Organizacin Internacional de Normalizacin o ISO (del griego, (isos),
'igual'), nacida tras la Segunda Guerra Mundial (23 de febrero de 1947), es el
organismo encargado de promover el desarrollo de normas internacionales de
fabricacin (tanto de productos como de servicios), comercio y comunicacin para
todas las ramas industriales a excepcin de la elctrica y la electrnica. Su funcin
principal es la de buscar la estandarizacin de normas de productos y seguridad
para las empresas u organizaciones (pblicas o privadas) a nivel internacional.
La ISO es una red de los institutos de normas nacionales de 163 pases, sobre la
base de un miembro por pas, con una Secretara Central enGinebra (Suiza) que
coordina el sistema. La Organizacin Internacional de Normalizacin (ISO), con
sede en Ginebra, est compuesta por delegaciones gubernamentales y no
gubernamentales subdivididos en una serie de subcomits encargados de
desarrollar las guas que contribuirn al mejoramiento.
Las normas desarrolladas por ISO son voluntarias, comprendiendo que ISO es un
organismo no gubernamental y no depende de ningn otro organismo
internacional, por lo tanto, no tiene autoridad para imponer sus normas a ningn
pas. El contenido de los estndares est protegido por derechos de copyright y
para acceder ellos el pblico corriente debe comprar cada documento.
Est compuesta por representantes de los organismos de normalizacin (ON)
nacionales, que produce diferentes normas internacionales industriales y
comerciales. Dichas normas se conocen como normas ISO y su finalidad es la
coordinacin de las normas nacionales, en consonancia con el Acta Final de
la Organizacin Mundial del Comercio, con el propsito de facilitar el comercio, el
intercambio de informacin y contribuir con normas comunes al desarrollo y a la
transferencia de tecnologas.
La Organizacin ISO est compuesta por tres tipos:
Miembros simples, uno por pas, recayendo la representacin en el organismo
nacional ms representativo.
Miembros correspondientes, de los organismos de pases en vas de desarrollo y
que todava no poseen un comit nacional de normalizacin. No toman parte

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

activa en el proceso de normalizacin pero estn puntualmente informados acerca


de los trabajos que les interesen.
Miembros suscritos, pases con reducidas economas a los que se les exige el
pago de tasas menores que a los correspondientes.
1.2 SPICE
El proyecto SPICE es el proyecto 07.29 del subcomit SC7. Es un documento
compuesto de 9 partes que al momento de publicar el libro estaba en su primera
revisin formal como Proposed Draft Technical Report (PDRT). El siguiente estado
del proceso de estandarizacin es llegar al Draft Technical Report (DTR) y
finalmente publicar Technical Report type 2 (TR-2). El tipo 2 significa que todava
existen dudas en la comunidad sobre la aceptacin del documento. Despus de
dos aos se realiza la ltima votacin para que se vuelva el estndar internacional.
El Software Process Assessment (SPA) y el proyecto SPICE tienen sus orgenes
en el creciente uso y dependencia de la Tecnologa de Informacin que en
consecuencia di el incremento de frustracin e incumplimiento de expectativas
por parte de los desarrolladores y los usuarios de software.
Al principio de los 80s, los militares de E.U. y del Reino Unido se propusieron
mejorar el mecanismo de seleccin de proveedores de software con el objetivo de
detener el creciente costo de software, reducir riesgos en su desarrollo y mejorar
la calidad de los productos de software.
En E.U., el departamento de defensa cre el Software Engineering Institute (SEI),
con el objetivo de desarrollar el mecanismo de seleccin de proveedores. El
modelo CMM y el trabajo e impacto de este instituto son bien conocidos.
Por su parte, en el Reino Unido, el comit conjunto del Gobierno, la Defense
Industry Trade Association (DITA) y el Computing Policy Consultative
Commitee (CPCC) reconocieron la necesidad de abordar con mayor rigor el
problema de seleccin de proveedores para los sistemas que dependen en gran
medida de software (Software Intensive Systems). A la agencia Defense
Evaluation Research Agency (DERA) se le encomend la investigacin de los
mtodos de evaluacin de proveedores en la industria mundial.
1.3 CMMI
Capability Maturity Model Integration (CMMI) es un modelo de aseguramiento de
la calidad que busca la mejora continua de las organizaciones mediante

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

el anlisis y re-diseo de los procesos que subyacen en la organizacin. Fue


creado por el SEI (Software Engineering Institute) de laUniversidad de CarnegieMellon y patrocinado por el Ministerio de Defensa de los Estados Unidos. Con el
propsito de lograr la mejora de los procesos, CMMI provee:

Una forma de integrar los elementos funcionales de una organizacin


[SEI07b].
Un conjunto de mejores prcticas basadas en casos de xito probado de
organizaciones experimentadas en la mejora de procesos.
Ayuda para identificar objetivos y prioridades para mejorar los procesos de
la organizacin [SEI07b], dependiendo de las fortalezas y debilidades de la
organizacin que son obtenidas mediante un mtodo de evaluacin.
Un apoyo para que las empresas complejas en actividades productivas
puedan coordinar sus actividades en la mejora de los procesos.
Un punto de referencia para evaluar los procesos actuales de la
organizacin

CMMI v1.2 corresponde a la tercera versin entregable del modelo CMMI,


posterior a las versiones 1.02 (primera versin ao 2000) y 1.1 (ao 2002). Las
versiones previas sirvieron como retroalimentacin para que los propios usuarios,
evaluadores y evaluados hicieran acotaciones sobre posibles mejoras, las cuales
fueron estudiadas, refinadas y algunas incluidas en la versin 1.2. CMMI v1.2
para desarrollo, que corresponde a una de tres constelaciones de prcticas, es
una gua que ayuda a manejar, medir y monitorear procesos utilizados en el
desarrollo de productos y servicios de una organizacin, y contiene prcticas
ligadas a la administracin de proyectos, administracin de procesos, ingeniera y
soporte. Las otras dos constelaciones son CMMI para Adquisicin que provee una
gua para liderar la adquisicin informada y decisiva, y CMMI para Servicios que
proporciona una gua para la entrega de servicios a clientes internos y externos de
la organizacin. Ambas constelaciones se encuentran an en desarrollo.
Junto con CMMI se desarroll y public el mtodo de evaluacin "Assessment
Requirements for CMMI (ARC)" [SEI00] en el ao 2000, el cual define los
requerimientos considerados esenciales para realizar una evaluacin de CMMI en
una organizacin y "Standard CMMI Appraisal Method for Process Improvement",
(SCAMPI) [SEI01], manual seguido por los evaluadores para medir el nivel de
madurez de una organizacin. Estos dosdocumentos tambin se han actualizado
como consecuencia de la retroalimentacin de la comunidad involucrada en

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

CMMI, generando la ltima versin 1.2 de SCAMPI y ARC ambas publicadas el


ao 2006.
Representaciones
La representacin usada en CMMI entrega una gua para efectuar las actividades
de mejora de los procesos y es utilizada en el mtodo de evaluacin. Segn el
modelo se tienen dos formas para mejorar. Una forma es mejorar un proceso
especfico o un conjunto de ellos usando la Representacin Continua (Continuous
Representation) y la otra es la mejora de la organizacin completa segn los
procesos definidos y ocupados usando la Representacin Escalonada o por
Etapas (Staged Representation). En la Tabla 1 se muestran los niveles para estos
dos tipos de representaciones.
Representacin Continua
La representacin continua se focaliza en la mejora de un proceso o un conjunto
de ellos relacionado(s) estrechamente a un rea de proceso en que una
organizacin desea mejorar, por lo tanto una organizacin puede ser certificada
para un rea de proceso en cierto nivel de capacidad. Existen seis niveles de
capacidad por donde transitan los procesos asociados a un rea de proceso y
cada nivel es construido sobre el nivel anterior, es decir para que un proceso
alcance un nivel de capacidad necesariamente debe haber alcanzado el nivel
anterior.

Tabla 1: Niveles de Representacin continua y escalonada.


Los niveles de capacidad son:
Nivel 0 - Incompleto: Un proceso es denominado "proceso incompleto" cuando una
o ms objetivos especficos del rea de proceso no son satisfechos.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Nivel 1 Realizado: Un proceso es denominado "proceso realizado" cuando


satisface todos los objetivos especficos del rea de proceso. Soporta y permite el
trabajo necesario para producir artefactos [Chr06].
Nivel 2 Manejado: Un proceso es denominado como "proceso manejado"
cuando tiene la infraestructura base para apoyar el proceso. El proceso es
planeado y ejecutado en concordancia con la poltica, emplea gente calificada los
cuales tienen recursos adecuados para producir salidas controladas; involucra
partes interesadas; es monitoreado, controlado y revisado; y es evaluado segn la
descripcin del proceso.
Nivel 3 Definido: Un proceso denominado "proceso definido" es adaptado desde
el conjunto de procesos estndares de la organizacin de acuerdo a las guas de
adaptacin de la organizacin, y aporta artefactos, medidas, y otra informacin de
mejora a los activos organizacionales.
Nivel 4 Manejado cuantitativamente: Un proceso denominado "proceso
manejado cuantitativamente" es controlado usando tcnicas estadsticas y otras
tcnicas cuantitativas. Objetivos cuantitativos para la calidad y realizacin del
proceso son establecidos y usados como criterios para manejar el proceso.
Nivel 5 Optimizacin: Un proceso denominado "proceso optimizacin es
mejorado basado en el entendimiento de causas comunes de variacin del
proceso. Un proceso en optimizacin se focaliza en la mejora continua del
proceso realizado a travs de mejoras incrementales y usando innovacin
tecnolgica.
Representacin Escalonada
En la representacin escalonada o por etapas se ofrece un mtodo estructurado y
sistemtico de mejoramiento de procesos, que implica mejorar por etapas o
niveles. Al alcanzar un nivel, la organizacin se asegura de contar con una
infraestructura robusta en trminos de procesos para optar a alcanzar el nivel
siguiente. Por lo tanto es una organizacin la que puede ser certificada bajo un
nivel, en este caso llamado nivel de madurez. Segn esta representacin un nivel
de madurez est compuesto por reas de procesos (ver Tabla 2) en donde los
objetivos asociados a ese nivel deben ser cumplidos para que la organizacin
pueda certificarse en aquel nivel de madurez. Hay cinco niveles de madurez, los
que son descritos a continuacin:
Nivel 1: Iniciado

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

En el nivel de madurez 1, la mayora de los procesos son "ad-hoc" y caticos. La


organizacin usualmente no provee un ambiente estable para soportar los
procesos. xitos en estas organizaciones se debe a la competencia y esfuerzos
heroicos de la gente dentro de la organizacin y no al uso de procesos probados.
A pesar de este caos, organizaciones pertenecientes al nivel de madurez 1 con
frecuencia producen productos y servicios que funcionan; sin embargo, ellos
frecuentemente exceden sus presupuestos y no cumplen sus planes. Estas
organizaciones son caracterizadas por la tendencia a no cumplir sus
compromisos, al abandono de procesos durante tiempos de crisis, y a la
incapacidad para repetir sus xitos. El Nivel 1 est caracterizado adems por la
realizacin de trabajo redundante, por personas que no comparten sus mtodos
de trabajo a lo largo de la organizacin y cuando una persona clave en un rea de
negocio especfica dentro de la organizacin se marcha, su conocimiento se va
con ella y se pierde para la organizacin. Es claro que el Nivel 1 es uno donde
ninguna organizacin quiere estar y donde por lo general la mayora que no tiene
sus procesos definidos se encuentra.
Nivel 2: Manejado
En el nivel de madurez 2 se ordena el caos. En el nivel 2 las organizaciones se
enfocan en tareas cotidianas referentes a la administracin. Cada proyectode la
organizacin cuenta con una serie de procesos para llevarlo a cabo, los cuales
son planeados y ejecutados de acuerdo con polticas establecidas; los proyectos
utilizan gente capacitada quienes disponen de recursos para producir salidas
controladas; se involucran a las partes interesadas; son monitoreados, controlados
y revisados; y son evaluados segn la descripcin del proceso. La disciplina del
proceso reflejada por el nivel de madurez 2 ayuda a asegurar que existen
prcticas y los proyectos son realizados y manejados de acuerdo a los planes
documentados. En el nivel de madurez 2 el estado de los artefactos y la entrega
de los servicios siguen planes definidos. Acuerdos son establecidos entre partes
interesadas y son revisados cuando sea necesario [Chr06]. Los artefactos y
servicios son apropiadamente controlados. Estos adems satisfacen sus
descripciones especificadas, estndares, y procedimientos.
Nivel 3: Definido
En el nivel de madurez 3, procesos son caracterizados y entendidos de buena
forma, y son descritos en estndares, procedimientos, herramientas, y mtodos. El
conjunto de procesos estndares de la organizacin, los cuales son la base para
el nivel de madurez 3, es establecido y mejorado continuamente. Estos procesos

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

estndares son usados para establecer consistencia a travs de la organizacin.


Los proyectos establecen sus procesos adaptando el conjunto de procesos
estndares de la organizacin de acuerdo a guas de adaptacin.
Una diferencia importante entre el nivel 2 y 3 es el alcance de los estndares: la
descripcin de procesos y los procedimientos. En el nivel de madurez 2, los
estndares pueden ser un poco diferentes en cada instancia especfica del
proceso (por ejemplo sobre un proyecto particular). En el nivel de madurez 3, los
estndares, descripcin de procesos y procedimientos para un proyecto, son
adaptados desde un conjunto de procesos estndares de la organizacin a un
particular proyecto o unidad organizacional y as son ms consistentes. Otra
distincin crtica es que el nivel de madurez 3, los procesos son tpicamente
descritos ms rigurosamente que en el nivel 2. Un proceso definido claramente
plantea el propsito, entradas, criterios de entrada, actividades, roles, medidas,
pasos de verificacin, salidas y criterios de salida. En el nivel de madurez 3,
procesos son manejados ms proactivamente entendiendo las interrelaciones de
las actividades y medidas detalladas del proceso, sus artefactos y sus servicios.
Nivel 4: Manejado cuantitativamente
En el nivel de madurez 4, la organizacin y proyectos establecen objetivos
cuantitativos para medir la calidad y realizacin de los procesos y los usa como
criterios en el manejo de ellos. Los objetivos cuantitativos son definidos en base a
las necesidades de clientes, usuarios finales, organizacin, y actores de los
procesos. La calidad y realizacin de procesos son entendidos en trminos
estadsticos y son manejados durante todo el ciclo de vida del proceso. Para
subprocesos seleccionados, se recolectan y analizan estadsticamente medidas
sobre la realizacin de procesos. Estas mtricas son incorporadas en el
repositorio de mtricas de la organizacin para apoyar la toma de decisiones.
Causas especiales de variacin de procesos son identificadas y, cuando sea
necesario, las fuentes de estas causas son corregidas para prevenir futuras
ocurrencias.
Una diferencia importante entre los niveles 3 y 4 es la capacidad de prediccin de
la realizacin del proceso. En el nivel de madurez 4, la realizacin de procesos es
controlada usando tcnicas estadsticas y cuantitativas, y el proceso es
cuantitativamente predecible, en cambio en el nivel de madurez 3 la realizacin del
proceso es slo predecible cualitativamente.
Nivel 5: Optimizado

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

En el nivel de madurez 5, una organizacin mejora continuamente sus procesos


basndose en el conocimiento de las causas comunes de variacin inherente en
los procesos. El nivel de madurez 5 se focaliza sobre la mejora continua de los
procesos a travs de mejoras continuas, incrementales y tecnolgicas. Los
objetivos de mejora cuantitativa de procesos para la organizacin son
establecidos, continuamente revisados para reflejar cambios en los objetivos del
negocio y usados como criterio en la mejora de procesos. Los efectos
del empleo de las mejoras de procesos son medidos y evaluados contra los
objetivos de mejora cuantitativa del proceso.
Una diferencia importante entre el nivel de madurez 4 y 5 es el enfoque de la
variacin de los procesos. En el nivel de madurez 4, la organizacin est
orientada a encontrar causas especiales de variacin y proveer una
prediccin estadstica de los resultados. Sin embargo, los resultados pueden ser
insuficientes para alcanzar los objetivos establecidos. En el nivel de madurez 5 la
organizacin est enfocada en las causas comunes de variacin de procesos y
modificar los procesos afectados para mejorar la realizacin de ellos y alcanzar
los objetivos cuantitativos de mejora de procesos.
Dado a que la organizacin con que se trabajar quiere certificarse en forma
organizacional en Nivel de madurez 3, en adelante slo se detallar el modelo
segn la Representacin Escalonada.
1.4 BOOTSTRAP
El Estndar Europeo para Evaluacin y Mejoras de Procesos de Desarrollo de
Software (Bootstrap) es otra de las iniciativas para resolver la crisis del desarrollo
de software; mediante prcticas, herramientas y estndares de calidad
internacional; mide, evala y propone mejoras al proceso de desarrollo de SW que
siguen las Unidades de Produccin de Software (UPS) de las empresas.
OBJETIVOS DE BOOTSTRAP
Proporcionar apoyo a la evaluacin de capacidad de proceso entre las mejores
prcticas de una reconocida ingeniera de software.
Incluir estndares de software reconocida internacionalmente como fuentes para
identificar las mejores prcticas.
Apoyar la evaluacin de como el estndar de referencia ha sido puesta en
prctica en la organizacin.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Asegurar la fiabilidad de la evaluacin.


Identificar, en la organizacin, procesos fuertes y dbiles.
Apoyar planificacin de mejora con resultados convenientes y confiables.
Apoyar el logro de los objetivos de la organizacin planeando acciones de mejora.
Ayudar a aumentar la eficiencia de los proceso poniendo en prctica la exigencias
de estndares en la organizacin.

1.5 MOPROSOFT
Modelo de Procesos para la Industria del Software. Modelo para la mejora y
evaluacin de los procesos de desarrollo y mantenimiento de sistemas y productos
de software. Desarrollado por la Asociacin Mexicana para la Calidad en
Ingeniera de Software ([1]) a travs de la Facultad de Ciencias de la Universidad
Nacional Autnoma de Mxico (UNAM) y a solicitud de la Secretara de Economa
para obtener una norma mexicana que resulte apropiada a las caractersticas de
tamao de la gran mayora de empresas mexicanas de desarrollo y mantenimiento

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

de software. Moprosoft es el nombre del modelo en la comunidad universitaria y


profesional, y la norma tcnica a la que da contenido es la NMX-059/01-NYCE2005 que fue declarada Norma Mexicana el 15 de agosto de 2005 con la
publicacin de su declaratoria en el Diario oficial de la Federacin.
Moprosoft considera que los modelos de evaluacin y mejora CMMI e ISO/IEC
15504 no resultan apropiados para empresas pequeas y medianas de desarrollo
y mantenimiento de software. Sobre las reas de procesos de los niveles 2 y 3 del
modelo SW-CMM e inspirndose en el marco de ISO/IEC 15504 se ha
desarrollado este modelo.

Criterios empleados
Se han aplicado los siguientes criterios para la elaboracin de este modelo de
procesos:
La estructura de procesos resultante debe ser acorde a la estructura generalmente
empleada por las organizaciones de la industria del software (alta direccin,
gestin y operacin)
La alta direccin tiene un papel importante a travs de la planificacin estratgica.
Debe actuar como promotor del buen funcionamiento de la organizacin a travs
de su implicacin en la revisin y mejora continua del modelo.
El modelo considera a la gestin como proveedora de recursos, procesos y
proyectos; as como responsable de la vigilancia del cumplimiento de los objetivos
estratgicos de la organizacin.
El modelo considera a la operacin como ejecutora de los proyectos de desarrollo
y mantenimiento de software.
El modelo integra con claridad y consistencia los elementos indispensables para la
definicin de los procesos y las relaciones entre ellos.
El modelo integra los elementos para realizar la administracin de proyectos
desde un slo proceso.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

El modelo integra los elementos para realizar la ingeniera de productos de


software en un nico marco que incluya los procesos precisos de soporte
(verificacin, validacin, documentacin y control de la documentacin).
El modelo destaca la importancia de la gestin de recursos, con especial
relevancia en aquellos que componen el conocimiento de la organizacin:
productos generados por proyectos, datos de los proyectos, mediciones,
documentacin de procesos y datos cosechados a partir del uso y de las lecciones
aprendidas.
Moprosoft se basa en los modelos de procesos ISO 9001:2000, en las reas de
procesos de los niveles 2 y 3 de CMM-SW: CMM-SW v.1.1., en el marco general
ISO/IEC15504 y en prcticas y conceptos de PMBOK Y SWEBOK.
PROSOFT representa un campo diferente de apoyo a los empresarios de las
tecnologas de la informacin, es un sector diverso para hacer negocios y generar
fuentes de empleo dignas
El Plan Nacional de Desarrollo 2001-2006 plantea el fomento a la industria y el
mercado De Tecnologas de la Informacin (TI) como estrategia para aumentar la
competitividad del Pas. Dado el gran potencial con que cuenta Mxico para
desarrollar esta industria, la Secretara de Economa, en coordinacin con
organismos empresariales y empresas del Sector, dise el PROSOFT.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

UNIDAD 2: INGENIERA DEL SOFTWARE PARA COMERCIO ELECTRNICO


2.1 INTRODUCCIN
El comercio electrnico brinda a las empresas la posibilidad de expandir su
mercado a niveles internacionales haciendo uso del internet como punto de
partida. Hoy en da, las barreras geogrficas, las fronteras entre pases importan
poco frente a la versatilidad que ofrece este medio a travs de sus
videoconferencias, chats, foros que comunican proveedores, empresas y
potenciales clientes de todo el mundo. Con el objetivo de proveer a su empresa de
la plataforma tecnolgica ideal para responder a las necesidades de este nuevo
mercado, Softelligence ofrece sus servicios en el desarrollo de software para
comercio en lnea contando con un grupo de expertos y las ms avanzadas
tecnologas digitales.
Actualmente, el desarrollo de software para comercio en lnea genera una serie de
beneficios. Una de las grandes ventajas de este software es que puede
automatizar procesos que si se hacen de forma manual o tradicional tomara una
considerable cantidad de tiempo. Usted puede llevar su negocio a un mayor nivel

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

de eficiencia teniendo un software que permita a sus clientes cotizar en lnea,


comprar productos de manera fcil y rpida o encontrar la informacin que buscan
dentro de su pgina de forma sencilla y clara.
Es por eso que seria til el uso de diversas plataformas en materia de Ingeniera
de Software como software a la medida, sistema bolsa de trabajo, registro de
usuarios, sistema de reservaciones on line, software de gestin, motor bienes
races, outsourcing de programadores, servidores, aplicacin server provider,
AJAX, SQL server, Visual Studio, soluciones integrales en marketing online,
administrador de contenidos, cotizador, inventarios en linea, renta de tiendas en
lnea, entre otros.
Recuerde que tanto en el internet como en la mesa de negocios la rapidez en la
atencin al cliente sin perder calidad es una de las caractersticas que los usuarios
y potenciales clientes valoran mucho al tomar su decisin de a quin comprarle. El
desarrollo de software para el comercio electrnico puede brindar una solucin
integral que combine una atractiva identidad grfica de su empresa, incluso
impactante, a la par de un contenido inteligente y con procesos de ventas
realmente agradables y fciles de entender, como un carrito de compras a la
medida, por ejemplo. Uno de los logros posibles con el desarrollo de software para
comercio en lnea, es darle al sitio un toque moderno y ergonmico, impactando
visualmente a los usuarios.
Un software para comercio electrnico realiza diversas funciones traducidas en
ventajas, entre ellas la de ayudar a administrar negocio, ya que puede realizar por
s mismo control de inventarios, avisndo mediante reportes especializados de
cuntas ventas hubo en el da, que producto est vendindose ms, cuntas
unidades quedan en stock saber cuntos das tardar el proveedor en surtirle
nuevamente. Como parte de las ventajas del desarrollo de software para comercio
en lnea, puede realizar la atencin a sus clientes ofreciendo a estos usuarios
atractivas ventajas como la personalizacin de su producto, donde el sistema deja
que el cliente decida sobre algunas caractersticas del artculo en cuestin como el
color, tamao y nmero de piezas que desea ordenar, siempre al margen de lo
que tiene en existencia.
Otra de las ventajas en de las Tecnologas de la Informacin, es la gran capacidad
de adaptabilidad, donde no slo responde los requerimientos presentes sino que
previene las necesidades futuras, siendo un ahorro bastante significativo en
cuestin de inversin, ya que en vez de comprar un nuevo software cada cierto
tiempo (como suele pasar con los software adaptables existentes en el mercado)

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

El software para comercio electrnico puede ser una til herramienta y la mejor
plataforma para hacer de su negocio, una empresa exitosamente competitiva.
2.2 SISTEMAS DISTRIBUIDOS
Un sistema distribuido se define como una coleccin de computadores autnomos
conectados por una red, y con el software distribuido adecuado para que el
sistema sea visto por los usuarios como una nica entidad capaz de proporcionar
facilidades de computacin.
El desarrollo de los sistemas distribuidos vino de la mano de las redes locales de
alta velocidad a principios de 1970. Mas recientemente, la disponibilidad de
computadoras personales de altas prestaciones, estaciones de trabajo y
ordenadores servidores ha resultado en un mayor desplazamiento hacia los
sistemas distribuidos en detrimento de los ordenadores centralizados multiusuario.
Esta tendencia se ha acelerado por el desarrollo de software para sistemas
distribuidos, diseado para soportar el desarrollo de aplicaciones distribuidas. Este
software permite a los ordenadores coordinar sus actividades y compartir los
recursos del sistema hardware, software y datos.
Los sistemas distribuidos se implementan en diversas plataformas hardware,
desde unas pocas estaciones de trabajo conectadas por una red de rea local,
hasta Internet, una coleccin de redes de rea local y de rea extensa
interconectados, que en lazan millones de ordenadores.
Las aplicaciones de los sistemas distribuidos varan desde la provisin de
capacidad de computo a grupos de usuarios, hasta sistemas bancarios,
comunicaciones multimedia y abarcan prcticamente todas las aplicaciones
comerciales y tcnicas de los ordenadores. Los requisitos de dichas aplicaciones
incluyen un alto nivel de fiabilidad, seguridad contra interferencias externas y
privacidad de la informacin que el sistema mantiene. Se deben proveer accesos
concurrentes a bases de datos por parte de muchos usuarios, garantizar tiempos
de respuesta, proveer puntos de acceso al servicio que estn distribuidos
geogrficamente, potencial para el crecimiento del sistema para acomodar la
expansin del negocio y un marco para la integracin de sistema usados por
diferentes compaas y organizaciones de usuarios.
2.3 COMERCIO ELECTRNICO
El comercio electrnico, tambin conocido como e-commerce (electronic
commerce en ingls), consiste en la compra y venta de productos o deservicios a

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

travs de medios electrnicos, tales como Internet y otras redes informticas.


Originalmente el trmino se aplicaba a la realizacin de transacciones mediante
medios electrnicos tales como el Intercambio electrnico de datos, sin embargo
con el advenimiento de la Internet y laWorld Wide Web a mediados de los aos 90
comenz a referirse principalmente a la venta de bienes y servicios a travs de
Internet, usando como forma de pago medios electrnicos, tales como las tarjetas
de crdito.
La cantidad de comercio llevada a cabo electrnicamente ha crecido de manera
extraordinaria debido a Internet. Una gran variedad de comercio se realiza de esta
manera, estimulando la creacin y utilizacin de innovaciones como
la transferencia de fondos electrnica, la administracin de cadenas de suministro,
el marketing en Internet, el procesamiento de transacciones en lnea (OLTP),
el intercambio electrnico de datos (EDI), los sistemas de administracin
del inventario y los sistemas automatizados de recoleccin de datos.
La mayor parte del comercio electrnico consiste en la compra y venta de
productos o servicios entre personas y empresas, sin embargo un porcentaje
considerable del comercio electrnico consiste en la adquisicin de artculos
virtuales (software y derivados en su mayora), tales como el acceso a contenido
"premium" de un sitio web.

Tipos de comercio electrnico:


- Business to Business (B2B):
Comercio realizado entre proveedores y clientes empresariales, o sea, de
empresa a empresa;
- Business-to-consumer o business-to-customer (B2C)
Es el comercio entre la empresa productora, vendedora o prestadora de
servicios y el consumidor final;
- Consumer to Consumer (C2C)
Comercio electrnico entre usuarios particulares de Internet. La
comercializacin de bienes o servicios no involucra a productores y s a un
consumidor final con otro consumidor final, sin intermediarios;
- Government to consumers (G2C)
Comercio entre gobiernos ,provincial, federal o municipal y consumidores,
por ejemplo, el pago de impuestos, multas y tarifas pblicas;

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

- Government to Business (G2B)


Negocios entre gobierno y empresas, por ejemplo: las compras del Estado
a travs de internet por medio de licitaciones, concurso de precios, etc.
Un sistema de Administracin de comercio electrnico o e-Commerce por su
nombre en ingls es una aplicacin desarrollada con el fin permitir el intercambio
comercial (compra y venta) a travs de medios electrnicos tales como internet,
intranets corporativas y otras redes informticas.
Los sistemas de comercio electrnico son usados como herramientas para:
Creacin de canales nuevos de marketing y ventas.
Acceso interactivo a catlogos de productos, listas de precios y folletos
publicitarios.
Venta directa e interactiva de productos a los clientes.
Soporte tcnico ininterrumpido, permitiendo que los clientes encuentren por s
mismos, y fcilmente, respuestas a sus problemas mediante la obtencin de los
archivos y programas necesarios para resolverlos.
Mejorar los procesos de distribucin.
Optimizar procesos operacionales y sistemas de comunicacin entre las partes
que intervienen.
Facilitar el procedo de fidelizacin de clientes.

Los sistemas de Comercio Electrnico implementan una serie de etapas que se


corresponden con el proceso de compra tradicional:
Se identifican las necesidades.
Eleccin del producto a comprar.
Eleccin del vendedor, a quien se le va realizar la compra.
Negociacin.
Compra y envo.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Uso y evaluacin del producto adquirido.


Para realizar dicho proceso, existen sistemas de agentes, a continuacin vamos a
hablar sobre la funcin que realizan en el proceso y ejemplos de cada uno de
ellos:
Agentes notificadores
Su misin es avisar a sus usuarios cuando encuentran un producto acorde al que
dicho usuario necesita.
Jango (http://www.jango.com): Utiliza Internet, para mediante el ingreso del
nombre de un producto, buscar automaticamente en las tiendas y sitios ms
relevantes. Muestra al usuario un informe con todos los datos e incluso ayuda a
cumplimentar el formulario de pedido, en caso de que se realize la compra.
Agentes de recomendacin
Se basan en el perfil y el conocimiento del contexto de negocio, para poder
recomendar a los usuarios que productos son ms de su inters.
FireFly (http://www.firefly.com): Permite mediante el uso de encuestas e ndices de
popularidad determinar las preferencias de los usuarios, por ejemplo para el sector
de msica y obteniene una lista con los cds que podran ser de su inters. Utiliza
algoritmos para automatizar el proceso de conocer opiniones de personas con
similares gustos musicales. Yahoo utiliza esta tecnologa para su generador de
listas top msica y pelculas. Uno de los incovenientes es que est limitado a un
comerciante, por lo que no realiza comparaciones.
Agentes de compra comparativa
Buscan al comerciante que ofrece las mejores condiciones para la compra del
producto que desea el usuario.
Bargain Finder (http://bf.cstar.ac.com): Agente que busca en varias tiendas los
precios ms baratos para CDs y cintas. Para realizar la bsqueda en un
determinado comerciante, este debe estar suscrito y pagar por aparecer como
referencia a los clientes. La bsqueda se realiza por el nombre exacto del artista o
albm, lo cual hace imprescindible que el usuario sepa exactamente lo que desea
comprar.
Agentes de negociacin

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Se encargan, mediante la existencia de agentes compradores y vendedores de


llegar a acuerdos para la compra de un producto, como los procesos de
negociacin que existen para realizar una transaccin comercial.
Kasbah: Sistema web donde el usuario puede crear agentes tanto compradores
como vendedores. Ayuda al usuario en la bsqueda del producto deseado, y en la
negociacin del mejor precio posible
Agentes de subasta
Permite a los compradores el pujar en la red. Un ejemplo de estos agentes
es AuctionBot.
2.4 TECNOLOGAS UTILIZADAS PARA EL COMERCIO ELECTRNICO
1. Conexiones (Sockets)
Un socket es un tipo de conducto que se utiliza para conectarse a una
computadora, a su vez, conectada a una red basada en TCP/IP. El socket se
configura de tal manera que los datos pueden ser bajados desde el cliente y
devueltos al mismo. Los lenguajes de programacin modernos, como Java,
proporcionan servicios de alta calidad, por medio de los cuales un socket se puede
conectar mediante programacin a una computadora cuya direccin de Internet
sea conocida, y donde los datos se pueden enviar por este conducto. La
programacin necesaria para esto, normalmente no es ms complicada que la
programacin que se requiere para escribir y leer datos de un archivo. Los sockets
son una implementacin a bajo nivel de la conectividad.
Dentro de las aplicaciones tpicas de un socket, estn las aplicaciones de
conferencia, donde una entrada a
Una conferencia se enviara al servidor de conferencia que utiliza una
configuracin de sockets en el servidor.
Los sockets son mecanismos de bajo nivel, pero una forma muy eficiente de
comunicar datos en un sistema distribuido que ejecuta el protocolo TCP/IP.
2. Objetos Distribuidos
Un objeto distribuido es aquel que reside en una computadora, normalmente un
servidor, en un sistema distribuido. Otras computadoras del sistema pueden enviar
mensajes a este objeto, como si residiera en su propia computadora. El software
del sistema se har cargo de varias funciones: localizar el objeto, recoger los

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

datos que se requieren para el mensaje y enviarlos a travs del medio de


comunicacin que se utiliza para el sistema. Los objetos distribuidos representan
un nivel ms alto de abstraccin que las conexiones (sockets), a partir de algn
cdigo de inicializacin, el programador no es consciente del hecho de que el
objeto reside en otra computadora.
Las tecnologas de objetos distribuidos usualmente empleadas son:
RMI. Esta es una tecnologa asociada al lenguaje de programacin Java. Es un
enfoque Java puro en el que slo los programas escritos en ese lenguaje se
pueden comunicar con un objeto RMI distribuido. Es la tecnologa ideal para
sistemas cerrados de Java; estos sistemas generalmente tendrn pocas
conexiones o ninguna con otros sistemas.
DCOM. Esta es una tecnologa desarrollada por la compaa Microsoft y permite
que, programas escritos en lenguajes tales como Visual Basic y Visual J++
(variedad de Java desarrollada por Microsoft), se comuniquen con los objetos que
estn en computadoras remotas.
CORBA. Es la tecnologa de objetos dis tribuidos ms sofisticada. La
caracterstica ms importante del enfoque CORBA es que es multilenguaje, donde
los programadores pueden utilizar diferentes lenguajes de programacin para
enviar mensajes a objetos CORBA.
La principal ventaja de los objetos distribuidos sobre los sockets es, el hecho de
que como abarca enteramente el paradigma de orientacin a objetos, se pueden
emplear los mismos mtodos de anlisis y diseo que se utilizan para la
tecnologa de objetos convencional.
3. Espacios
Esta es una tecnologa que se encuentra en un nivel de abstraccin, incluso ms
alto que los objetos distribuidos.
La tecnologa de espacios concibe un sistema distribuido sobre la base a un gran
almacn de datos persistentes, donde las computadoras de un sistema distribuido
pueden leer o escribir. No concibe el sistema distribuido como una serie de
programas que pasan mensajes a los dems, utilizando un mecanismo como los
sockets, o como una serie de objetos distribuidos que se comunican utilizando
mtodos. Por el contrario, la tecnologa de espacios conlleva procesos como
escribir, leer o copias datos a partir de un almacn persistente. Un programador
que utiliza esta tecnologa, no se preocupa por detalles como dnde estn

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

almacenados los datos, qu proceso va a recoger los datos y cundo los va a


recoger.
4. CGI
El trmino CGI (Common Gateway Interface) significa, interfaz comn de pasarela.
Es la interfaz con el servidor Web al cual se puede acceder, mediante los
programas que se ejecutan en el servidor. Gran parte de la interactividad asociada
a las pginas Web, se implementa programando el acceso a la CGI. Por ejemplo,
cuando el usuario de un navegador accede a una pgina que contiene un
formulario, ste lo rellena y lo enva al servidor Web, programa el acceso a la CGI,
procesa el formulario, y lleva a cabo la funcionalidad asociada al formulario.
5. Contenido Ejecutable
Es el trmino que se aplica a la inclusin en una pgina Web de un programa que
se ejecuta, cuando la pgina es recuperada por un navegador. Este programa
puede llevar a cabo un nmero diverso de funciones, entre las que se incluyen, la
animacin y la presentacin de un formulario al usuario para insertar datos.
Existen varias tecnologas que proporcionan servicios para insertar contenido
ejecutable en una pgina Web, entre ellas se incluyen: applets, ActiveX y
Javascript.
6. Paquetes Cliente / Servidor
Este trmino describe las colecciones de software que normalmente llevan a cabo
algn tipo de procesamiento de sistemas. A continuacin, se muestran ejemplos
tpicos de paquetes de software:
Paquetes de reproduccin de datos (Replicacin). Este tipo de software realiza
una transaccin en la base de datos y la aplica a un nmero de bases de datos
reproducidas, evitando as acceder a estas bases de datos hasta que todas estn
sincronizadas.
Paquetes de seguridad. Estos son paquetes que monitorizan el trfico dentro de
un sistema distribuido y avisan al administrador de sistemas de la aparicin de
cualquier violacin posible en la seguridad.
Monitores de transacciones. Estos son paquetes de software que administran las
transacciones que tienen lugar dentro de un sistema distribuido y aseguran que se
devuelvan los datos correctos como resultado de una transaccin y en el orden
correcto. Muchas de las funciones de estos monitores tienen que ver con asegurar

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

que los resultados correctos se devuelvan, incluso, en el entorno en donde


podran surgir errores de hardware o de transmisin.

2.5 INGENIERIA DE SEGURIDAD


La Ingeniera de la seguridad es una rama de la ingeniera, que usa todo tipo de
ciencias para desarrollar los procesos y diseos en cuanto a las caractersticas de
seguridad, controles y sistemas de seguridad. La principal motivacin de esta
ingeniera ha de ser el dar soporte de tal manera que impidan comportamientos
malintencionados.
El campo de esta ingeniera puede ser muy amplio, podra desarrollarse en
muchas tcnicas:
Equipos: Como el diseo de cerraduras, cmaras, sensores,...
Procesos: polticas de control, procedimientos de acceso,...
Informtico: control de passwords, criptografa,...

UNIDAD 3: INGENIERA WEB


3.1 ATRIBUTOS DE LOS SISTEMAS Y APLICACIONES WEB
Que es la usabilidad?

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Tcnicas que ayudan a los seres humanos a realizar tareas en entornos grficos
de ordenador.
Tres conceptos muy importantes. Trabajamos para seres humanos, que quieren
realizar una tarea de una forma sencilla y eficaz y en este caso particular, la deben
realizar frente a un ordenador en un entorno grafico, la Web. La usabilidad ayuda
a que esta tarea se realice de una forma sencilla analizando el comportamiento
humano, y los pasos necesarios para ejecutar la tarea de una forma eficaz. Quizs
suene un poco a trabajo industrial, pero al hacer referencia al termino tarea,
estamos haciendo referencia a buscar un programa que queremos ver en la tele, a
ver informacin sobre mi equipo de ftbol favorito, a comprar un libro sobre artes
marciales.
Realmente hace falta la usabilidad para hacer una Web?
Si. Sea tu Web un portal o una pagina personal, no olvides que la gente que entra
en tu Web es por que bsicamente busca algo. Hacerlo sencillo es decisin tuya,
pero seguro que entre todos podemos hacer de Internet un sitio mejor donde la
gente no se sienta perdida o extraviada o sencillamente defraudada.
Cuales son las 8 reglas de Oro sobre la usabilidad?
Quizs maana sean 10 reglas.
1. En Internet el usuario es el que manda.
Esto quiere decir que sin usuarios tu pgina muere, as que mas vale que los
cuides y les des lo que te piden, de lo contrario te quedaras solo.
2. En Internet la calidad se basa en la rapidez y la fiabilidad.
En Internet cuenta que tu pagina sea mas rpida que bonita, fiable que moderna,
sencilla que compleja, directa.
3. Seguridad.
Si en el mundo real a veces nos cuesta fiarnos del banco de la esquina, imagnate
como se siente la gente en Internet cuando llega a tu site. Procura que todo
funcione como un reloj para que la gente pueda fiarse de tu site.
4. La confianza es algo que cuesta mucho ganar y se pierde con un mal enlace.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Esto quiere decir que tal y como esta la competencia en Internet, no puedes
perder ni un solo visitante por tener un enlace mal hecho. Es mejor salir con algo
sencillo e irlo complicando poco a poco, que salir con todo y ver que es lo que
pasa. Versiones 1.0 son buenas mientras lo que este puesto este bien asentado y
genere confianza. Poco a poco y con el feedback de los usuarios, podrs ir
complicando la pagina. Pero asegura antes de arriesgar.
5. Si quieres hacer una pagina decente, simplifica, reduce, optimiza.
La gente no se va a aprender tu site por mucho que insistas, as que por lo menos
hazlo sencillo, reutiliza todos los elementos que puedas, para que de este modo
los usuarios se sientan cmodos y no se pierdan cada vez que necesiten
encontrar algo en tu site.
6. Pon las conclusiones al principio.
El usuario se sentir ms cmodo si ve las metas al principio. De esta forma no
tendr que buscar lo que necesita y perder menos tiempo en completar su tarea.
Si completa su tarea en menos tiempo se sentir cmodo y quizs se dedique a
explorar t site o quizs se lo recomiende a un amigo.
7. No hagas perder el tiempo a la gente con cosas que no necesitan.
Cuidado con cruzar promociones, si lo haces por lo menos hazlo con cuidado.
Procurar que la seleccin de productos a cruzar sea consecuente y no lo quieras
vender todo en todas las paginas. Segn avance el usuario en su navegacin
procura dejarle mas espacio libre. Puede ocurrir que cuando este punto de
comprar algo vea una oferta que le distraiga y pierdas esa venta.
8. Buenos contenidos.
Escribir bien para Internet es todo un arte. Pero siguiendo las reglas bsicas de (1)
poner las conclusiones al principio y (2) escribir como un 25% de lo que pondras
en un papel, se puede llegar muy lejos. Leer en pantalla cuesta mucho, por lo que,
en el caso de textos para Internet, reduce y simplifica todo lo que puedas.
9. Evaluacin del contenido.
A diferencia del software de aplicacin que evoluciona continuamente, las
aplicaciones Web involucran una de manera continua. Un seguimiento continuo y
detallado de la informacin implcita en la aplicacin Web. Todo esto hace que la
aplicacin Web sirva al usuario fina.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

3.2 ESTRATOS DE LA INGENIERA WEB


El desarrollo de aplicaciones Web incorpora mtodos de proceso especializados,
mtodos de ingeniera de software adaptados a caractersticas de desarrollo de
las aplicaciones Web y un conjunto de importantes tecnologas que permitan un
correcto desarrollo de las mismas.
Loas procesos, mtodos y tecnologas (herramientas) proporcionan un enfoque en
estratos de la IWeb que es conceptualmente idntico a los estratos de la
ingeniera de software.
Proceso
Los modelos de procesos Web adoptan la filosofa de desarrollo gil. El desarrollo
gil enfatiza un enfoque de desarrollo riguroso que incorpora rpidos ciclos de
desarrollo.
Es importante reconocer que el problema todava debe analizarse, debe
desarrollarse un diseo, la implementacin debe preceder en una forma
incremental y se debe iniciar un enfoque organizado de prueba. Dichas
actividades de marco de trabajo se deben definir dentro de un proceso que:

Adopte el cambio
Aliente la creatividad y la independencia del equipo de desarrollo y
fortalezca la interaccin con en usuario.
Construya sistemas que utilicen pequeos equipos de desarrollo.
Subraye el desarrollo evolutivo o incremental mediante el uso de cortos
ciclos de desarrollo.

Mtodos
Los mtodos de la IWeb abarcan un conjunto de labores tcnicas que permiten al
ingeniero Web comprender, caracterizar y luego construir una aplicacin Web de
alta calidad. ::Los mtodos de la IWeb se puedes categorizar de la siguiente
manera:
Mtodos de comunicacin:
Mtodos de comunicacin: Definen el enfoque con que se facilita la comunicacin
entre:

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Las tcnicas de comunicacin son importantes durante la recoleccin de


requisitos.

Mtodos de anlisis de requisitos:


proporcionan una base para comprender el contenido que se entregar a las
WebApps, la funcin que proporcionar al usuario final y los modos de interaccin
de cada clase de usuario requerir mientras ocurra la navegacin por medio de las
WebApps
Mtodos de diseo:
Abarcan una serie de tcnicas de diseo que abordan el contenido, la aplicacin y
la arquitectura de informacin, as como el diseo de interfase y la estructura de
navegacin de las WebApps.
Mtodo de prueba:
Incorporan revisiones tcnicas formales tanto de contenido y el modelo de diseo
como de una amplia variedad de tcnicas de pruebas que abordan conflictos al
nivel de componentes. Pruebas de la navegacin, pruebas de facilidad de uso ,
pruebas de seguridad y pruebas de configuracin.
Herramientas y tecnologas
Las tecnologas abarcan un amplio conjunto de descripcin de contenido y
lenguaje de modelacin por ejemplo: HTML, VRML, XML, etc. lenguajes de
programacin por ejemplo java, php, jsp, etc. recursos de desarrollo basados en
componentes por ejemplo corba, com, activeX, .net, etc. navegadores,
herramientas multimedia, herramientas de auditoria de sitio, herramientas de
conectividad de base de datos, herramientas de seguridad, servidores y utilidades
de servidor, y herramientas de administracin y anlisis de sitio.
3.3 EL PROCESO DE INGENIERA WEB
En un proceso tan rpido como es el proceso de Ingeniera Web, donde los
tiempos de desarrollo y los ciclos de vida de los productos son tan cortos,
merece la pena el esfuerzo requerido por la gestin? La respuesta es que dada
su complejidad es imprescindible. Entre los aspectos que aaden dificultad a la
gestin destacamos: - alto porcentaje de contratacin a terceros, - el desarrollo
incluye una gran variedad de personal tcnico y no tcnico trabajando en paralelo,

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

- el equipo de desarrollo debe dominar aspectos tan variopintos como, software


basado en componentes, redes, diseo de arquitectura y navegacin, diseo
grfico y de interfaces, lenguajes y estndares en Internet, test de aplicaciones
Web, etc, lo que hace que el proceso de bsqueda y contratacin de personal sea
arduo.
1.4.1 Definir el marco de trabajo
La efectividad de cualquier proceso de ingeniera depende de su adaptabilidad.
Esto es, la organizacin del equipo de trabajo del proyecto, los modos de
comunicacin entre miembros del equipo, las actividades de ingeniera y las tareas
que deben realizarse, la informacin que se recolecte y se cree, y los mtodos
empleados para producir un producto de alta calidad deben estar adaptados a la
gente que realiza el trabajo, el plazo y las restricciones del proyecto, y al problema
que se quiere resolver.
Antes de definir un marco de trabajo de proceso para la IWeb se debe reconocer
que:
Las WebApps con frecuencia se entregan de manera incremental.
Los cambios ocurrirn frecuentemente.
Los plazos son cortos.
Comunicacin con el cliente: La comunicacin con el cliente se caracteriza por
medio de dos grandes tareas: el anlisis del negocio
y la formulacin. El anlisis del negocio define el contexto empresarial-organizativo
para las WebApps y otras aplicaciones de negocio. La formulacin es una
actividad de recopilacin de requisitos que involucran a todos los participantes.
Planeacin:
Se crea el plan del proyecto para el incremento de la WebApp. El plan consiste de
una definicin de tareas y un calendario de plazos respecto al perodo establecido
para el desarrollo del proyecto.
Modelado:
Las labores convencionales de anlisis diseo de la ingeniera del software se
adaptan al desarrollo de las WebApp, se mezclan y luego se funden en una
actividad de modelado de la IWeb. El intento es desarrollar anlisis rpido y

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

modelos de diseo que definan requisitos y al mismo tiempo representen una


WebApp que los satisfar.
Construccin:
Las herramientas y la tecnologa IWeb se aplican para construir la WebApp que se
ha modelado. Una ves que se construye el incremento de WebApp se dirige a una
serie de pruebas rpidas para asegurar que se descubran los errores en el diseo.
Despliegue:
Las WebApp se configuran para su ambiente operativo, se entrega a los usuarios
finales y luego comienza un perodo de evaluacin. La retroalimentacin acerca de
la evaluacin para realizar los procesos respectivos.
Refinamiento del marco de trabajo
La definicin de tareas de ingeniera requerida para refinar cada actividad del
marco de trabajo se dejan a discrecional del juicio del equipo de ingeniera Web.
Es importante destacar que las tareas asociadas con la actividad del marco de
trabajo IWeb pueden modificarse, eliminarse o extenderse con base en las
caractersticas del problema, el producto, el proyecto y la gente en el equipo de
ingeniera Web.
3.4 MEJORES PRCTICAS EN LA INGENIERA WEB.
Tomar tiempo para entender las necesidades del negocio y los objetivos del
producto, incluso si los detalles de la WebApp son vagos.
Describir cmo interactuarn los usuarios con la WebApp aplicando un enfoque
basado en escenarios.
Desarrollar un plan del proyecto, incluso si es muy breve
Utilizar algn tiempo para modelar lo que se construir.
Revisar la consistencia y calidad de los modelos.
Utilizar herramientas y tecnologa que permitan construir el sistema con tantos
componentes reutilizables.
No apoyarse en usuarios anteriores para depurar la webApp

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

3.5 FORMULACIN DE SISTEMAS BASADOS EN WEB


La formulacin se enfoca sobre el gran cuadro en las necesidades y objetivos del
negocio y el la informacin relacionada. Los clientes y los ingenieros Web quieren
definir el contenido requerido, discutir la funcionalidad especfica, caractersticas
especficas e identificar la forma en que los usuarios finales interactuarn con las
WebApp, todo esto es formulacin y recopilacin de requisitos.

Preguntas de formulacin:

En esta etapa es bueno preguntarse y responderse lo siguiente:

Cul es la principal motivacin para las WebApp?

Cules son los objetivos que deben satisfacer las WebApp?

Quin usar la WebApp?

Si tenemos una respuesta correcta a estas preguntas implican metas especficas


para el sitio Web.
En general se identificas dos categoras de metas:

Metas informativas: indican una intencin de proporcionar contenido


informacin especficos al usuario final.

Metas aplicables: indican la habilidad para realizar alguna tarea dentro


de la WebApp.

Recopilacin de requisitos para WebApps


Los objetivos globales de la recopilacin de requisitos propuestos para la
ingeniera de software permanecen inalterados. Adaptados para las WebApp,
dichos objetivos se convierten en:

Identificar requisitos de contenido.

Identificar requisitos funcionales.

Definir escenarios de interaccin para diferentes clases de usuarios.

Los siguientes pasos de la recopilacin de requisitos se dirigen para lograr estos


objetivos

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

1. Pedir a los clientes que definan una categora de usuario y describan


cada categora.
2. Comunicarse con los clientes para definir los requisitos bsicos para las
WebApp.
3. Analizar la informacin recopilada y utilizar la informacin para realizar un
seguimiento a los clientes.
4. Definir casos de uso que describan escenarios de interaccin para cada
clase de usuario.
El puente hacia el modelado de anlisis
Toda la informacin recolectada y tratada se modela con la utilizacin de casos de
uso y notacin UML.
3.6 PLANEACIN DE PROYECTOS DE INGENIERA WEB
Dada la inmediatez de las WebApps es razonable preguntar: En realidad se
necesita gastar tiempo en la planeacin y administracin de un esfuerzo WebApp?
No solo se debera dejar involucrar naturalmente a las WebApp, con poco o
ninguna gestin explicativa?
Mas de un desarrollador Web optara por poca o ninguna gestin, pero eso no
hace que estn en lo correcto.
3.7 EL EQUIPO DE INGENIERA WEB
Un equipo de ingeniera Web exitoso mezcla una amplia variedad de talentos que
deben trabajar como equipo en un ambiente de proyecto con alta presin. Los
plazos son cortos, los cambios son inexorables y la tecnologa contina
cambiando. La creacin de un equipo que se consolide no es asunto sencillo.

Los Actores

Desarrolladores/proveedores de contenido

Editores de Web

Ingeniero Web

Expertos en dominios empresariales

Especialista en Soporte

Administrador

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Construccin del equipo

Para la construccin del equipo tiene particular relevancia cuando una


organizacin se forma un equipo de IWeb

Se debe establecer un conjunto de directrices del equipo.

El liderazgo fuerte es una obligacin

El respeto hacia los talentos individuales es crucial

Cada miembro del equipo se debe comprender

Es fcil comenzar, lo difcil es mantener el espritu.

3.8 CONFLICTOS DE GESTIN DE PROYECTO PARA INGENIERA WEB


Una vez realizada la formulacin y que se han identificado los requisitos bsicos
de la WebApp, la empresa debe elegir una de dos opciones de ingeniera Web:

La WebApp es subcontratada: la ingeniera Web la realiza un tercer


proveedor con experiencia, talento y recursos con los cuales no cuenta
la empresa.

Las WebApp la desarrollan en casa ingenieros Web que sean


empleados de la empresa.

Planeacin de WebApp: subcontratacin


En este caso un negocio(el cliente) pide un precio fijo para desarrollar la WebApp
de uno o ms proveedores, evala los precios competitivos y luego elige un
proveedor para efectuar el trabajo. Pero Qu busca la organizacin contratante?
Cmo se determina la competencia de un proveedor de WebApp? Cmo se
sabe sina cotizacin es razonable?
Qu grado de planeacin, programa de trabajo y valoracin de riesgos se
pueden esperar conforme una organizacin se embarca en un esfuerzo por
desarrollar una gran WebApp?
Estas preguntas no siempre son fciles de contestar, pero vale la pena considerar
algunos lineamientos.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Seleccin de los subcontratistas candidatos:


Con la finalidad de elegir desarrolladores Web candidatos, el contratante debe
realizar algunas tareas obligadas:

Entrevistar a los clientes antiguos para determinar el profesionalismo del


vendedor Web, as cono su habilidad para cumplir con compromiso de
plazos y costos y su destreza para comunicarse efectivamente.
Determinar el nombre de ingeniero(s) Web jefe de la empresa
subcontratista para buscar proyectos anteriores exitosos.
Examinar cuidadosamente ejemplos de trabajo del subcontratista que sean
similares en apariencia y sentido a la WebApp que ser contratada.

Planeacin de WebApp: Ingeniera Web en casa


Los pasos siguientes se recomiendan para proyectos IWeb pequeos y de tamao
moderado.

Entender el mbito, las dimensiones del cambio y las restricciones del


proyecto.
Definir una estrategia del proyecto incremental

Realizar anlisis de riesgo


Desarrollar una estimacin rpida
Elegir un conjunto de tareas
Establecer un programa
Definir mecanismos de rastreo del proyecto
Establecer un enfoque de gestin de cambios

3.9 MEDIACIN PARA INGENIERA WEB Y WEBAPPS


La mediacin del software ofrece una base para mejorar el proceso de software, lo
que aumenta la precisin de las estimaciones del proyecto, incrementa el rastreo
del proyecto y mejora la calidad del software.
Las mediciones tienen tres metas principales:

Proporcionar un indicador de calidad de las WebApp desde el punto de


vista tcnico.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Proporcionar una base para la estimacin del esfuerzo

Proporcionar una indicacin del xito de la WebApp desde el punto de


vista empresarial.

UNIDAD 4: ANLISIS DE APLICACIONES WEB


4.1 REQUISITOS PARA EL ANLISIS DE LAS WEBAPP
El anlisis de requisitos para las WebApp abarca tres grandes tareas:

Formulacin

Recopilacin de requisitos
Modelado de anlisis

La jerarqua de usuario
Las categoras de los usuarios finales se identifican como parte de las tareas de
formulacin y de recopilacin de requisitos. Las categoras de usuarios son
relativamente limitados y no necesitan una representacin UML. Sin embargo,
cuando crece el nmero de categoras de usuario, a veces es aconsejable
desarrollar una jerarqua de usuarios.
Desarrollo de casos de uso

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Los casos de uso se desarrollan para cada categora de usuario descrita en la


jerarqua de usuario. En el contexto de la ingeniera Web, el caso de uso en si
mismo es relativamente informal: un prrafo narrativo que describe una interaccin
especifica entre el usuario y la WebApp.
Afinacin del modelo de caso de uso
A la par que se crean los diagramas de casos de uso para cada categora de
usuario, se desarrolla una vista superior de los requisitos de la WebApp
observables de manera externa.
Cada paquete se valora para garantizar que es:

Comprensible.

Cohesivo

Libremente acoplados

Jerrquicamente superficial.

Puesto que el anlisis y modelado de actividades son actividades iterativas.


4.2 EL MODELADO DE ANLISIS PARA WEBAPPS
Se basa en la informacin que contienen los casos de uso desarrollados para l
aplicacin. Se identifican el contenido que presentar la WebApp y se extraen las
funciones que se desarrollarn a partir de las descripciones de caso de uso.
Finalmente los requisitos especficos de la implementacin se deben desarrollar
de modo que el ambiente y la infraestructura que apoyan la WebApps puedan
construirse.
Cuatro actividades de anlisis, cada una con su aporte a la creacin de un modelo
de anlisis completo son:

Anlisis de contenido

Anlisis de interaccin

Anlisis de funciones

Anlisis de configuracin

El modelo es si mismo contiene elementos estructurales y dinmicos. Los


elementos estructurales identifican las clases de anlisis y los objetivos de

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

contenido que se requieren para crear una WebApp que satisfaga las necesidades
del cliente.
Los elementos dinmicos del modelo de anlisis describen como interactan los
elementos estructurales, entre ellos y con los usuarios finales.
4.3 EL MODELO DE CONTENIDO
El modelo de contenido contiene elementos estructurales que proporcionan una
importante visin de los requisitos de contenido para una WebApp. Adems
incluye todas las clases de anlisis: entidades visibles para el usuario que se
crean o manipulan conforme ste interacta con la WebApp.
Al igual que otros elementos del modelo de anlisis, el modelo de contenido se
deriva a partir de un examen cuidadoso de los casos de uso desarrollados para la
WebApp.
Definicin de objetos de contenido
Un objeto de contenido puede ser una descripcin textual de un producto, un
artculo que describa un evento noticioso.
Los objetos de contenido se extraen en los casos de uso al examinar la
descripcin del escenario para referencias directas e indirectas al contenido.

Relaciones de jerarqua de contenido


El modelo de contenido puede contener diagramas de relacin de entidades o
rboles de datos que bosquejan las relaciones entre los objetos de contenido o la
jerarqua de ste que mantiene una WebApp.
4.4 EL MODELO DE INTERACCIN
Este modelo de interaccin lo comprenden cuatro elementos:

Casos de uso
Diagramas de secuencia
Diagramas de estado
Prototipo de interfaz de usuario

Casos de Uso

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Un caso de uso se modela para todos los procesos que la WebApp debe llevar a
cabo. Los procesos se describen dentro del caso de uso por una descripcin
textual o una secuencia de pasos ejecutados. Los Diagramas de Actividad se
pueden usar tambin para modelar escenarios grficamente. Una vez que el
comportamiento de la aplicacin est captado de esta manera, los casos de uso
se examinan y amplan para mostrar qu objetos se interrelacionan para que
ocurra este comportamiento.
Diagrama de Secuencia
Un diagrama de Secuencia muestra una interaccin ordenada segn la secuencia
temporal de eventos. En particular, muestra los objetos participantes en la
interaccin y los mensajes que intercambian ordenados segn su secuencia en el
tiempo. El eje vertical representa el tiempo, y en el eje horizontal se colocan los
objetos y actores participantes en la interaccin, sin un orden prefijado. Cada
objeto o actor tiene una lnea vertical, y los mensajes se representan mediante
flechas entre los distintos objetos. El tiempo fluye de arriba abajo. Se pueden
colocar etiquetas (como restricciones de tiempo, descripciones de acciones, etc.)
bien en el margen izquierdo o bien junto a las transiciones o activaciones a las que
se refieren.
Diagramas de Estado
El comportamiento en tiempo real de cada clase que tiene comportamiento
dinmico y significativo, se modela usando un Diagrama de Estado. El diagrama
de actividad puede ser usado tambin aqu, esta vez como una extensin del
diagrama de estado, para mostrar los detalles de las acciones llevadas a cabo por
los objetos en respuesta a eventos internos. El diagrama de actividad se puede
usar tambin para representar grficamente las acciones de mtodos de clases.
Prototipo de interfaz de usuario
Algunas propuestas se basan en obtener de la definicin de requisitos prototipos
que, sin tener la totalidad de la funcionalidad del sistema, permitan al usuario
hacerse una idea de la estructura de la interfaz del sistema con el usuario. Esta
tcnica tiene el problema de que el usuario debe entender que lo que est viendo
es un prototipo y no el sistema final.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Puesto que las herramientas de desarrollo de la WebApp son abundantes y


funcionalmente poderosas, es mejor crear prototipos de la interfaz mediante tales
herramientas.
4.5 EL MODELO FUNCIONAL
Este modelo funcional aborda dos elementos de procesamiento de la WebApp y
cada uno representa un grafico diferente de la abstraccin de procedimiento:

Funcionalidad observable respecto al usuario y que entrega al usuario


final de WebApp.

Las operaciones dentro de las clases de anlisis que implementan


comportamientos asociados con la clase.

La funcionalidad observable para el usuario comprende cualesquiera funciones de


procesamiento que ste indicia directamente. Por ejemplo, un sitio Web financiero
puede implementar una variedad de funciones financieras.
4.6 EL MODELO DE CONFIGURACIN
Las WebApps se deben disear e implementar de forma que se acomoden a una
diversidad de ambientes, tanto del lado del servidor como del cliente. Se deben
especificar el hardware del servidor y el ambiente del sistema operativo. Si las
WebApp deben tener acceso a una gran base de datos o nter operar con las
aplicaciones corporativas existentes en el lado del servidor, se deben especificar
las interfaces apropiadas, los protocolos de comunicacin y la informacin.
Las WebApp deben someterse a una amplia prueba de cada configuracin de
navegador que se especifique como parte del modelo de configuracin.
Anlisis relacin navegacin
El anlisis relacin-navegacin proporciona una serie de pasos de anlisis que
luchan por identificar relaciones entre los elementos descubiertos como parte de la
creacin del modelo de anlisis.
El enfoque de ARN se organiza en cinco pasos:

Anlisis de los participantes

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Anlisis de los elementos

Anlisis de relaciones

Anlisis de navegacin

Anlisis de evaluacin.

Anlisis de relaciones: preguntas claves


En este anlisis se formulan una serie de preguntas que nos ayudar a
comprender mas la relacin, para ello debe acudir al libro gua pagina 516.
Anlisis de navegacin
Uno de los aspectos ms importantes en los sistemas de informacin en las
WebApp es el de la navegacin. La gran mayora de las propuestas metodolgicas
para sistemas WebApp resaltan este aspecto ofreciendo modelos que permitan
disearlo e implementarlo asegurando la calidad del resultado. Sin embargo,
analizando dichos modelos y tcnicas y viendo los resultados de diferentes
estudios comparativos, se puede observar que este aspecto, en la mayora de las
propuestas, se trata solamente en las ltimas fases del ciclo de vida,
principalmente en diseo e implementacin.
Los mecanismos de navegacin se definen como parte del diseo. En esta etapa,
los desarrolladores deben considerar requisitos de navegacin globales.

UNIDAD 5: DISEO PARA APLICACIONES WEB


5.1 TEMAS DE DISEO PARA INGENIERA WEB
Cuando se aplica el diseo dentro del contexto de la ingeniera Web, se deben
considerar cuestiones tanto genricas como especficas. El diseo debe ser muy
especfico.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Diseo de calidad de una WebApp


En la prctica, la calidad de los sitios web se ha evaluado de una manera ad hoc,
basada en el sentido comn y en la experiencia de los desarrolladores. El estudio
de la calidad de productos y procesos de desarrollo para la Web es muy reciente y
todava no se dispone de mtodos de evaluacin ampliamente difundidos para
este tipo de entorno.
Por lo tanto, existe la gran necesidad de metodologas efectivas para la obtencin
de aplicaciones Web de calidad. Actualmente, hay dos vertientes de metodologas
de desarrollo para la Web: la comunidad de Ingeniera de Software y la comunidad
de Hipermedia. Estas metodologas carecen sin embargo de mtricas que puedan
ser aplicadas a los modelos intermedios (Ej. Modelo de Objetos, Modelo
Navegacional) utilizados en el proceso de desarrollo orientado a la Web.
Otras caractersticas de diseo de calidad Web son:

Seguridad

Disponibilidad

Escalabilidad

Tiempo en el mercado

Metas de diseo
Una de las metas de diseo de una WebApp es abarcar lo siguiente:

Simplicidad

Consistencia

Identidad

Robustez

Navegabilidad

Apariencia visual

Compatibilidad

5.2 PIRMIDE DEL DISEO IWEB


El diseo conduce a un modelo que contiene una mezcla adecuada de esttica,
contenido y tecnologa.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

5.3 DISEO DE LA INTERFAZ DE LA WEBAPP


Toda interfaz de usuario debe presentar las siguientes caractersticas:

Fcil de usar

Fcil de aprender

Fcil de navegar

Intuitiva

Consistente

Eficiente

Libre de errores

Funcional

Debe ofrecer al usuario final una experiencia satisfactoria y gratificante.


Los principios y directrices esenciales del diseo de una WebApp se pueden
mencionar:

Uso equitativo

Flexibilidad en el uso

Uso sencillo e intuitivo

Informacin perceptible

Tolerancia al error

Esfuerzo fsico reducido

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Tamao y espacio para acercarse y usar

En un momento de nuestra vida, cualquiera de nosotros puede llegar a


experimentar una transicin fsica. Ya sea una minusvala temporal, como un
hueso roto, o una discapacidad permanente, nos veremos enfrentados al cambio.
El simple proceso de envejecimiento nos lleva a ser dependientes de otros. El
diseo universal nos permite transitar por esos cambios y seguir disfrutando de
igualdad de oportunidades, autodeterminacin y calidad de vida.
Tcnicas de diseo
Diseo fijo
Diseo que utiliza dimensiones de tamao absoluto: inches (in), centimetros (cm),
milmetros (mm), puntos (pt), picas (pc). Su efecto es bloquear el tamao de un
elemento a un tamao fijo.
Diseo lquido (o fluido)
Diseo que utiliza cmo unidad de medida el porcentaje (%). Su efecto es la
adaptacin de los elementos y su disposicin aprovechando todo el ancho de
pantalla que ser calculada en base a la resolucin del dispositivo utilizado.
Diseo elstico (o flexible)
Diseo que utiliza cmo unidad de medida em. Su efecto es adaptar el ancho de
los elementos y su disposicin en base al tamao de texto configurado por el
usuario.
Diseo hibrido
Diseo que utiliza unidades de medida absolutas, porcentaje y em.

No hay un diseo ms accesible que otro.

Se elije el tipo de diseo en base a las necesidades (proyecto).

Flujo de trabajo en el diseo de la interfaz


Las siguientes tareas representan un flujo de trabajo rudimentario para el diseo
de la interfaz WebApp.
1. Revisar la informacin contenida en el modelo de anlisis y refinarla
conforme se requiera.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

2. Desarrollar un bosquejo aproximado de la plantilla de la interfaz de la


WebApp.
3. Correlacionar los objetivos del usuario con acciones especficas de la
interfaz.
4. Definir un conjunto de tareas de usuario que estn asociadas con cada
accin.
5. Elaborar bosquejos con imgenes de la pantalla para cada accin de la
interfaz.
6. Refinar la plantilla de la interfaz y los bosquejos con el uso de entradas
desde el diseo esttico.
7. Identificar los objetos de la interfaz del usuario que se requieren para
implementarla.
8. Desarrollar una representacin de procedimiento de la interaccin del
usuario con la interfaz.
9. Desarrollar una representacin del comportamiento de la interfaz.
10. Describir la plantilla de la interfaz par acada estado.
11. Refinar y revisar el modelo de diseo de la interfaz.

5.4 DISEO ESTTICO


El diseo esttico, tambin llamado diseo grafico, es un esfuerzo artstico que
complementa los aspectos tcnicos de la ingeniera Web. Sin l una WebApp
puede ser funcional, pero sin atractivo.
5.5 DISEO DE CONTENIDO
El diseo de contenido se enfoca en dos asuntos de diseo diferentes, cada uno lo
abordan individuos con distintos conjuntos de habilidades. El diseo de contenido
desarrolla una representacin de diseo para los objetos de contenido y
representa los mecanismos que se requieren para que establezcan sus relaciones
uno con otro.
Objetos de contenido

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

La relacin entre objetos de contenido, defina como parte del modelo de anlisis
WebApp y los objetos de diseo que representan contenido es anloga a la
relacin entre las clases de anlisis y los componentes de diseo.
Un objeto de contenido tiene atributos que incluyen informacin especfica de
contenido y atributos especficos de implementacin que se especifican como
parte del diseo.
5.7 DISEO DE NAVEGACIN
El diseador debe definir las rutas de navegacin que habiliten para la ruta de los
usuarios el acceso al contenido y las funciones de las WebApp. Para ello se debe:

Identificar la semntica de navegacin para diferentes usuarios del sitio

Definir la mecnica que logra la navegacin.

Semntica de navegacin
Durante las etapas iniciales del diseo, de navegacin se valora la arquitectura de
contenido de la WebApp para determinar una o mas FdN para cada caso de uso.
Como se anot anteriormente, una FdN identifica los nodos de navegacin y los
vnculos que permiten la navegacin entre ellos.
Sintaxis de navegacin
Conforme el diseo se lleva a cabo se define la mecnica de navegacin, entre
sus posibilidades tenemos:

Vinculo de navegacin individual

Barra de navegacin horizontal

Columna de navegacin vertical

Pestaas

Mapas del sitio

5.8 METRICAS DE DISEO PARA WEBAPPS


Las mtricas deben ofrecer respuestas cuantitativas a las siguientes preguntas
La interfaz de usuario promueve la facilidad de uso?

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

La esttica de la WebApp es apropiada para el dominio de la aplicacin y


confortable al uso?
El contenido esta diseado en una forma que proporciona mayor informacion
con el menor esfuerzo?
La navegacin es eficiente y directa?
La arquitectura de la WebApp se ha diseado para acomodar las metas y
objetivos especiales de los usuarios de la WebApp la estructura de contenido y
funcionalidad y el flujo de navegacin requerido para usar el sistema de manera
efectiva?
Los componentes estndar diseado en una forma que reduce la complejidad y
aumenta la exactitud, la confiabilidad y el desempeo?
Hasta el momento no existe un conjunto de mtricas cuantitativas por lo que estos
deben ser tratados de manera cualitativa

UNIDAD 6: VERIFICACIN Y VALIDACIN DE APLICACIONES WEB


6.1 PLANIFICACIN DE LA VERIFICACIN Y VALIDACIN

La verificacin y validacin es un proceso caro.

Para algunos sistemas, ms de la mitad del presupuesto para desarrollar el


sistema se invierte en V & V.

Es necesaria una planificacin cuidadosa para obtener el mximo provecho


de las inspecciones y pruebas y controlar los costos del proceso de V & V.

Debe comenzarse la planificacin de la V & V del sistema en etapas


tempranas del proceso de desarrollo.

Dentro del proceso de planificacin de V & V, hay que buscar un equilibrio


entre las aproximaciones estticas y dinmicas de V & V.

Tambin hay que pensar procedimientos para las inspecciones y pruebas


del software, establecer listas de comprobacin para conducir las
inspecciones de programas y definir el plan de pruebas del software.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

El esfuerzo destinado a las inspecciones y las pruebas depende del tipo de


sistema a desarrollar y de los expertos de la organizacin en V & V con que
se cuente.

Como regla general, cuanto ms crtico sea el sistema, debe dedicarse ms


esfuerzo a las tcnicas de verificacin estticas.

Los planes de pruebas, adems de ayudar a asignar recursos y estimar el


calendario de pruebas, son tiles para los ingenieros del software
implicados en el diseo y la realizacin de las pruebas del sistema.

Ayudan a obtener una panormica general de las pruebas del sistema y


ubicar su propio trabajo en este contexto.

6.2 INSPECCIONES DE SOFTWARE

Proceso de V & V esttico donde un software se revisa para encontrar


errores, omisiones y anomalas.

Las inspecciones se suelen centrar en el cdigo fuente, pero puede


inspeccionarse cualquier representacin legible del software.

Hay 3 ventajas fundamentales de la inspeccin sobre las pruebas:

Durante las pruebas, los errores pueden ocultar otros errores.

Cuando se descubre un error, nunca se puede estar seguro de si otras


anomalas de salida son debidas a un nuevo error o son efectos laterales
del error original.

Como la inspeccin es un proceso esttico, no hay que preocuparse de las


interacciones entre errores.

As, una nica sesin de inspeccin puede descubrir muchos errores en un


sistema.

Pueden inspeccionarse versiones incompletas de un sistema sin costos


adicionales.

Si un programa est incompleto, entonces se necesita desarrollar software


de pruebas, para probar las partes disponibles.

Esto, obviamente, aade costos al desarrollo del sistema.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Adems de buscar los defectos en el programa, una inspeccin tambin puede


considerar otros atributos de calidad ms amplios: cumplimiento con los
estndares, portabilidad y mantenibilidad.

Puede buscarse ineficiencias, algoritmos no adecuados y estilos de


programacin que podran tornar al sistema difcil de mantener y actualizar.

Muchos autores observaron que la revisin esttica de cdigo era ms


efectiva y menos costosa que las pruebas de defectos, a la hora de
encontrar fallas en los programas.

6.3 PRUEBAS DE LAS APLICACIONES WEB


Las pruebas que por cierto son de diferentes tipos.
- El contenido: evaluacin sintctica (ortografa y gramtica de contenido) y
semntica (exactitud de la informacin presentada y consistencia entre
objetos de contenido y objetos relacionados)
- La funcin: comprobar la concordancia con los requisitos del cliente
- Estructura: se comprueba que se entregue adecuadamente el contenido y
la funcionalidad de la WebApp.
- Facilidad de uso: para cada categora de usuario, que va relacionado con la
sintaxis y semntica de la navegacin
- Navegabilidad: comprobar la sintaxis y semntica de navegacin as como
comprobar que est controlado todo flujo, por ejemplo: vnculos rotos,
vnculos inadecuados, etc.)
- Desempeo: se prueba en una diversidad de condiciones operativas,
configuraciones, y cargas para saber que el software responde
adecuadamente a cargas extremas
- Compatibilidad: se comprueba que la WebApp funciona en varias
configuraciones husped tanto del lado del cliente como del servidor e
infraestructura de seguridad
- Interoperabilidad: se prueba para asegurar que la WebApp realiza
interfaces adecuadas con otras aplicaciones y/o bases de datos, y que
estas sean con un buen desempeo
- Seguridad: se prueba la vulnerabilidad potencial.
EJEMPLOS DE PRUEBAS PARA WEBAPPS
Prueba de Contenido
- Sintctica (ortografa y gramtica de contenido)
- Semntica (exactitud de la informacin presentada y consistencia entre objetos
de contenido y objetos relacionados).

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Esta evaluacin que se hace para cada objeto de contenido debe el examinador
responder a las siguientes preguntas:
- La informacin realmente es precisa (concisa y exacta)?
- La plantilla del objeto de contenido es fcil de entender para el usuario?
- La informacin anidada en un objeto de contenido se encuentra con
facilidad?
- La informacin presentada internamente es consistente con la informacin
de otros objetos de contenido?
- El contenido es ofensivo, engaoso o abre la puerta a pleitos?
- El contenido infringe derechos de autor o marcas registradas?
- El estilo esttico del contenido entra en conflicto con el estilo esttico de la
interfaz global
Un grupo de pruebas adicionales en cuanto a la semntica es para los WebApp
que construyen objetos de contenido dinmicos que se crean en tiempo real en
base a una base de datos. Para esto se deben observar varios factores:
- Pruebas que descubran errores cometidos al traducir la solicitud del usuario
en una forma que pueda procesar la DBMS
- Pruebas para comprobar errores en la comunicacin con la base de datos
- Validar que los datos brutos provenientes de la DBMS hacia el servidor y
este hacia el cliente estn correctamente formateados para crear los
objetos de contenido
- Probar el formato y compatibilidad de presentacin de los objetos de
contenido dinmico al usuario con diferentes configuraciones de ambiente
del cliente
- Estructurales/arquitectura (que se entregue adecuadamente el contenido y la
funcin de la WebApp. Que pueda ser extensible en contenido y funcionalidad)
CMS.
Prueba de Interfaz del Usuario
La verificacin y validacin de la interfaz del usuario se lo hace en tres puntos del
proceso, en el anlisis (formulacin y anlisis de requisitos), en el diseo (al
disear la interfaz que garantice la calidad) y durante las pruebas donde
bsicamente se prueban ejecutando la aplicacin.
Los objetivos que se obtienen con las pruebas de interfaz son:
- Las caractersticas de la interfaz se prueban para asegurar que las reglas
del diseo, la esttica y el contenido visual relacionado estn a disposicin
del usuario sin error alguno
- Los mecanismos individuales de la interfaz se prueban en forma unitaria
(por ejemplo se prueba HTML dinmico, cgi, carrito de compras, etc.)
- La interfaz se prueba frente cada caso de uso (USN) para descubrir errores
de semntica, y facilidad de uso
- La interfaz se prueba dentro de una diversidad de ambientes para asegurar
su compatibilidad.

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Pruebas de semntica de la interfaz. Una vez que se ha probado de forma


unitaria cada mecanismo de interfaz, se procede con la prueba semntica que
evala cun bien el diseo se ocupa de los usuarios, ofreciendo una direccin
clara, manteniendo consistencia de lenguaje y enfoque.
Para esto se sugiere probar cada caso de uso (categoras de usuario) versus el
diseo de la interfaz para confirmar que no hay errores y si los hubiere como los
maneja y su recuperacin.
Pruebas de compatibilidad. Como sabemos, el usuario puede tener diferentes
ambientes (sistemas operativos, navegador, plataformas de hardware), por lo que
se debe hacer pruebas de compatibilidad para descubrir errores asociados con un
ambiente especfico. Para esto se debe definir un conjunto de configuraciones de
computadoras cliente ms comunes y en funcin de estas armar las pruebas.
Prueba al nivel de Componentes
Conocidas como pruebas de funcin, que intentan descubrir errores en la
funcionalidad de la WebApp. Para esto existen algunos mtodos de prueba:
- Particin de equivalencia. Cuyo dominio de entrada se divide en categoras
o clases de entrada y a partir de estos se derivan los casos de prueba. Se
hacen pruebas con cada categora mientras las otras permanecen
constantes, por ejemplo en una pgina que importe el cdigo postal, aqu
se hace pruebas posibles con el cdigo postal mientras los otros valores
permanecen constantes
- Anlisis de valores lmite. Probar los valores mximos o mnimos de
campos o atributos que maneja el componente o la funcin
- Pruebas de ruta. Para comprobar y garantizar que se ha ejercitado toda
ruta posible en su funcionamiento.
Para cada caso se debe especificar la entrada y salida esperada.
Existen circunstancias en las que la funcionalidad es tan extensa que complica
probar todas las posibles situaciones, por lo que una sugerencia seria acudir a un
anlisis de riesgo para obtener los casos de prueba de mayor riesgo, como por
ejemplo:
- Cul funcionalidad es la ms importante para el propsito
- Cuales reas del sitio amerita ms dura interaccin con la DB?
- Cuales mecanismos especficos (cgi, applets, ActiveX) son los ms
complejos?
- Qu tipos de problemas causara la mayora de las quejas o la peor
publicidad?
- Qu reas del sitio sern las ms populares?
- Qu partes del sitio tendrn mayores riesgos de seguridad?
Pruebas de Navegacin

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Las pruebas de navegacin garantizan que todos los mecanismos que permiten al
usuario de la WebApp viajar a travs de ella sean funcionales y validar que cada
USN pueda ser alcanzado por la categora de usuario adecuada.
La primera prueba de navegacin inicia con la prueba de interfaz. Estas pruebas
inicialmente son probadas por los Ingenieros Web para luego pasar que prueben
los usuarios.
Prueba de sintaxis de navegacin. Con cada mecanismo de navegacin se
prueba: vnculos navegacin, redirigir (destinos removidos), mapas de sitio,
motores de bsqueda.
Prueba de semntica de navegacin. Se deben probar los USN (unidad
semntica de navegacin). Si no se han hecho los USN en el anlisis, se puede
tomar los casos de uso para armar casos de prueba de navegacin respondiendo
a las siguientes preguntas:
Pruebas de Configuracin
En las pruebas de compatibilidad en pruebas de interfaz usuario se probaron solo
del lado del cliente, mientras que en estas pruebas de configuracin se prueban
un conjunto de probables configuraciones de cliente y servidores.
Del lado del servidor:
- La WebApp es totalmente compatible con el sistema operativo del
servidor?
- Los archivos de sistema, directorios y datos de sistema relacionados se
crean correctamente cuando la WebApp esta operativa?
- Las medidas de seguridad del sistema permiten a la WebApp ejecutarse y
dar el servicio a los usuarios sin interferencia y a un buen desempeo?
- La WebApp se ha probado con la configuracin de servidor distribuido
(clster o balanceo de carga)?
- La WebApp est integrada adecuadamente con la base de datos
(incluyendo diferentes versiones de DB)?
- Si se usan proxys, las diferencias en configuraciones se han abordado?
Del lado del cliente:
- Hardware: CPU, memoria, dispositivos de impresin, monitor
- Sistemas operativos: normales y especiales para equipos mviles
- Software de navegacin
- Componentes de interfaz del usuario: ActiveX, applets java, otros
- Plug in: QuickTime, real player, adobe, otros
- Conectividad: cable, DSL, Modem, proxys, otros
- Aplicaciones que corren al mismo tiempo.
Pruebas de Desempeo

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Se aplican para descubrir problemas de desempeo que se presentan debido a la


falta de recursos en el lado del servidor, ancho de banda de red inapropiada,
capacidades inadecuadas de bases de datos, capacidades/defectuosos de
sistemas operativos, funcionalidad mal diseada, u otros conflictos de hardware o
software (seguridad) que impidan un buen desempeo.
Esto conducir a comprender como el sistema responde a cierta carga (numero de
usuarios activos, numero de transacciones, volumen de datos, etc.) y a poder
recolectar mtricas para poder modificar el diseo o acoplar soluciones
(hardware/software apropiadas) para mejorar el rendimiento.
Las pruebas deben responder a las siguientes preguntas:
- En qu punto (usuarios, transacciones, carga de datos) el desempeo se
vuelve inaceptable?
- Que componentes del sistema son responsables de la reduccin del
desempeo?
- Cul es el tiempo de respuesta promedio para los usuarios en una variedad de
condiciones de carga?
- Que ocurre cuando se aplican cargas que rebasan la capacidad mxima del
servidor?
Para contestar a estas preguntas se hacen las pruebas de desempeo comunes
(carga y tensin).
Pruebas de carga. Para esta prueba se consideran variables:
- N: nmero de usuarios concurrentes
- T: numero de transacciones en lnea por usuario por unidad de tiempo
- D: la carga de datos procesada por el servidor por transaccin.
De estas variables el Ingeniero Web obtiene valores promedios aceptables y si en
el momento de la prueba encuentra una disminucin precipitada de desempeo se
debe revisar el porqu.
Pruebas de tensin. Es una continuacin de la prueba de carga, en donde las
variables N, T y D se fuerzan para poder superar los lmites operativos. Con esta
prueba se responden a las siguientes preguntas:
- El sistema se degrada o el servidor se desconecta cuando se rebasa su
capacidad?
- El software emite mensajes al cliente y al soporte tcnico del sitio que se
no puede alcanzar el servidor?
- El servidor pone en cola las peticiones que no alcanza a resolverlas para ir
atendiendo poco a poco como su capacidad lo permita?
- Las transacciones se pierden conforme se rebasa los lmites?
- La integridad de datos se pierde cuando se rebasa los lmites?
- Si el sistema falla, cunto tarda en estar en lnea de nuevo?

TALLER DE INGENIERA SE SOFTWARE


HIGINIO NAVA BAUTISTA
MIRIAM HERNANDEZ SERAFIN
5 SEMESTRE ITICS

Ciertas funciones del WebApp se descontinan cuando el servidor llega a


sus umbrales (memoria, procesador, disco)?

Una variacin de pruebas de tensin son las llamadas pruebas pico, que son las
mismas pruebas de tensin pero se lo hace muy repentino llegar o sobrepasar el
lmite volviendo a la normalidad y luego nuevamente sobrepasando el lmite para
efectos de poder comprobar cun bien que el sistema/servidor se recupera
regresando a su normalidad.

También podría gustarte