7d4e10a6b9e7383794be9afa7813240e9237aca2
[PFCLatex/.git] / capitulo4 / capitulo4.tex
1 \chapter{Análisis, diseño en implementación de las aplicaciones}
2
3 \section{Análisis}
4
5 A lo largo de esta primera sección se intentará explicar de forma detallada todos los requisitos y los casos de uso de las dos aplicaciones de las que se compone este proyecto fin de carrera: la aplicación web y la aplicación basada en Android.
6
7 \subsection{Análisis de requisitos}
8
9 Todo desarrollo software comienza con la toma de requisitos y el análisis de la aplicación por parte de los \emph{analistas de software}. A lo largo del desarrollo, la especificación de los requisitos suele variar bien porque el usuario o cliente final cambia de idea o bien por motivos técnicos relacionados con la implementación de la funcionalidad inicialmente solicitada.
10
11 En este apartado se especificarán los principales requisitos de la aplicación Web y la basada en Android. Para la extracción de requisitos existen diversas técnicas, en el caso de este proyecto el cliente y desarrollador son la misma persona por tanto no es necesario emplear ninguna técnica en particular.
12
13 Se hará una división entre requisitos software y requisitos de restricción y se usará un formato tabular para la formulación de dichos requisitos. Los campos de los que se compondrán las tablas serán los siguientes:
14
15 \begin{itemize}
16     \item \textbf{Título de la tabla}: descripción del objetivo del requisito.
17     \item \textbf{Código}: identificador único del requisito.
18     \item \textbf{Tipo}: los tipos funcionales, no funcionales y de usabilidad serán descritos en la siguiente sección.
19     \item \textbf{Descripción}: como su nombre indica es la descripción breve y detallada del requisito en sí mismo.
20     \item \textbf{Prioridad}: puede ser alta, media o baja y define la prioridad con la cual un requisito en particular debe ser cumplido durante el desarrollo del software. 
21 \end{itemize}
22
23 \subsection{Requisitos software}
24
25 La fase de especificación de requisitos software (SRS por sus siglas en Inglés) está diseñada para documentar y describir el comportamiento de un sistema que se desea desarrollar. Supone un acuerdo entre el usuario y el desarrollador respecto a la especificación del producto software solicitado~\cite{C4:Specifications}. El principal propósito de la especificación de requisitos software consiste en proporcionar una completa y clara descripción de los requisitos solicitados por el usuario~\cite{C4:Specifications}, dicha descripción puede ser usada como referencia en etapas posteriores del desarrollo del software solicitado.
26
27 Identificaremos tres tipos de requisitos:
28
29 \begin{itemize}
30     \item Requisitos funcionales: suponen una funcionalidad propia del sistema software que se debe desarrollar.
31     \item Requisitos no funcionales: suelen estar relacionados con funcionalidades del software a implementar. No son una funcionalidad en sí mismos. Por ejemplo, requisitos relacionados con el rendimiento.
32     \item Requisitos de usabilidad: relacionados con cómo el usuario interactúa con las aplicaciones.
33 \end{itemize}
34
35 \begin{table}[h]
36 \centering
37 \scriptsize
38     \begin{tabularx}{\textwidth}{|l|X|}
39         \hline
40         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Roles de usuario}} \\
41         \hline
42         \normalsize\textbf{Código identificador} & \multicolumn{1}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-01}} \\
43         \hline
44         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
45         \hline
46         \normalsize\textbf{Descripción} & \normalsize{Se deben definir diferentes roles para el acceso a la aplicación. Por un lado los usuarios tipo empresa pueden generar nuevo contenido y por el otro los usuarios ``normales'' accederán y recibirán en sus teléfonos dicho contenido.} \\
47         \hline
48         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
49         \hline
50     \end{tabularx}
51     \caption{\emph{Tabla Requisito Funcional 1.}}
52     \label{tab:requisitoSW1}
53 \end{table}
54
55
56
57 \subsection{Modelando los requisitos, diagrama de casos de uso}
58
59 En la Figura~\ref{fig:MobiAdsUseCaseWeb}) se puede observar el diagrama de casos de uso de la aplicación Web desarrollada. Se puede observar el diagrama de casos de uso de la aplicación Web desarrollada.
60 \begin{figure}[H]
61     \centering
62         \includegraphics[width=\textwidth]{fig/MobiAdsUseCaseWeb}
63     \caption{\emph{Diagrama de casos de uso de la aplicación Web}}
64     \label{fig:MobiAdsUseCaseWeb}
65 \end{figure}
66
67 Se puede observar como los principales casos están relacionados con el listado de la información con la que el usuario debe trabajar. También se comprueba que todos los casos de uso pueden ser extendidos o ampliados para la edición de los datos.
68
69 Por otra parte, se muestra la existencia de usuarios sin registrar y de usuarios registrados. El usuario no registrado lo único que puede hacer es autenticarse en la aplicación o registrarse como nuevo usuario. Además se muestra claramente la existencia de dos tipos de usuarios: el usuario ``empresa'' y el usuario ``normal''.
70
71 Los usuarios de tipo empresa son los encargados de introducir los datos en el sistema, siendo estos datos los anuncios que posteriormente recibirán los usuarios en sus teléfonos móviles.
72
73 A continuación se describirán textualmente cada uno de los casos de uso indicados en la Figura~\ref{fig:MobiAdsUseCaseWeb}) Para ello, se ha creado un formato de tabla común para todos los casos, con los campos recomendados por el lenguaje de modelado gráfico UML (Unified Modeling Language) y algunos más que si bien no están completamente estandarizados por el lenguaje UML sí se recomienda hacer uso de ellos~\cite{C4:UMLDistilled}.
74
75
76 \subsection{Descripción de los casos de uso}
77
78 \begin{table}[h]
79 \centering
80 \scriptsize
81     \begin{tabularx}{\textwidth}{|X|X|}
82         \hline
83         \normalsize\textbf{Nombre} & \\
84         \hline
85         \normalsize\textbf{Requisito} & \\
86         \hline
87         \normalsize\textbf{Actores} & \\
88         \hline
89         \normalsize\textbf{Objetivo} & \\
90         \hline
91         \normalsize\textbf{Precondiciones} & \\
92         \hline
93         \normalsize\textbf{Postcondiciones} & \\
94         \hline
95         \normalsize\textbf{Escenario de éxito principal} & \\
96         \hline
97     \end{tabularx}
98     \caption{\emph{Tabla de casos de uso 1.}}
99     \label{tab:tabladecasosdeuso1}
100 \end{table}