d3e6a30c493666b0993e9c04beaef64fc3d785c1
[PFCLatex/.git] / capitulo4 / capitulo4.tex
1 \chapter{Análisis, diseño e 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 se usará un formato tabular para la formulación de los requisitos software. 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}: nombre con el cual se identifica el 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 o con algún tipo de restricción.
32     \item Requisitos de usabilidad: relacionados con cómo el usuario interactúa con las aplicaciones.
33 \end{itemize}
34
35 \subsection{Requisitos software, aplicación Web}
36
37 \subsubsection{Funcionales}
38
39 \begin{table}[H]
40 \centering
41 \scriptsize
42     \begin{tabularx}{\textwidth}{|l|X|}
43         \hline
44         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Roles de usuario}} \\
45         \hline
46         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-01}} \\
47         \hline
48         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
49         \hline
50         \normalsize\textbf{Descripción} & \normalsize{Se deben definir dos 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. Estos últimos solo pueden asociarse a categorías de las cuales recibirán notificaciones en sus dispositivos móviles.} \\
51         \hline
52         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
53         \hline
54     \end{tabularx}
55     \caption{\emph{Tabla Requisito Aplicación Web 1.}}
56     \label{tab:requisitoSW1}
57 \end{table}
58
59 \begin{table}[H]
60 \centering
61 \scriptsize
62     \begin{tabularx}{\textwidth}{|l|X|}
63         \hline
64         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Registro nuevos usuarios}} \\
65         \hline
66         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-02}} \\
67         \hline
68         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
69         \hline
70         \normalsize\textbf{Descripción} & \normalsize{Se deben poder registrar nuevos usuarios de cualquier rol de los definidos en el RSW-01.} \\
71         \hline
72         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
73         \hline
74     \end{tabularx}
75     \caption{\emph{Tabla Requisito Aplicación Web 2.}}
76     \label{tab:requisitoSW2}
77 \end{table}
78
79 \begin{table}[H]
80 \centering
81 \scriptsize
82     \begin{tabularx}{\textwidth}{|l|X|}
83         \hline
84         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Debe existir una sección donde se puedan listar los anuncios.}} \\
85         \hline
86         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-03}} \\
87         \hline
88         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
89         \hline
90         \normalsize\textbf{Descripción} & \normalsize{El sistema debe poder listar todos los anuncios creados o asignados a un determinado usuario con rol empresarial.} \\
91         \hline
92         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
93         \hline
94     \end{tabularx}
95     \caption{\emph{Tabla Requisito Aplicación Web 3.}}
96     \label{tab:requisitoSW3}
97 \end{table}
98
99 \begin{table}[H]
100 \centering
101 \scriptsize
102     \begin{tabularx}{\textwidth}{|l|X|}
103         \hline
104         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Edición de anuncios}} \\
105         \hline
106         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-04}} \\
107         \hline
108         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
109         \hline
110         \normalsize\textbf{Descripción} & \normalsize{Se deberá poder editar anuncios ya existentes en el sistema.} \\
111         \hline
112         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
113         \hline
114     \end{tabularx}
115     \caption{\emph{Tabla Requisito Aplicación Web 4.}}
116     \label{tab:requisitoSW4}
117 \end{table}
118
119 \begin{table}[H]
120 \centering
121 \scriptsize
122     \begin{tabularx}{\textwidth}{|l|X|}
123         \hline
124         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Añadir nuevos anuncios}} \\
125         \hline
126         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-05}} \\
127         \hline
128         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
129         \hline
130         \normalsize\textbf{Descripción} & \normalsize{El sistema debe permitir añadir nuevos anuncios.} \\
131         \hline
132         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
133         \hline
134     \end{tabularx}
135     \caption{\emph{Tabla Requisito Aplicación Web 5.}}
136     \label{tab:requisitoSW5}
137 \end{table}
138
139 \begin{table}[H]
140 \centering
141 \scriptsize
142     \begin{tabularx}{\textwidth}{|l|X|}
143         \hline
144         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Asociar anuncios con categorías definidas por una empresa determinada}} \\
145         \hline
146         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-06}} \\
147         \hline
148         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
149         \hline
150         \normalsize\textbf{Descripción} & \normalsize{Los anuncios deben poder asociarse con categorías previamente descritas por el propio usuario con rol empresarial.} \\
151         \hline
152         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
153         \hline
154     \end{tabularx}
155     \caption{\emph{Tabla Requisito Aplicación Web 6.}}
156     \label{tab:requisitoSW6}
157 \end{table}
158
159 \begin{table}[H]
160 \centering
161 \scriptsize
162     \begin{tabularx}{\textwidth}{|l|X|}
163         \hline
164         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Anuncios con textos descriptivos en múltiples idiomas}} \\
165         \hline
166         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-07}} \\
167         \hline
168         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
169         \hline
170         \normalsize\textbf{Descripción} & \normalsize{Los anuncios deben estar ``internacionalizados''. Es decir, el sistema debe admitir más de un tipo de idioma para describir un anuncio. El usuario con rol ``normal'' recibirá el anuncio en el idioma que él o ella elijan.} \\
171         \hline
172         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
173         \hline
174     \end{tabularx}
175     \caption{\emph{Tabla Requisito Aplicación Web 7.}}
176     \label{tab:requisitoSW7}
177 \end{table}
178
179 \begin{table}[H]
180 \centering
181 \scriptsize
182     \begin{tabularx}{\textwidth}{|l|X|}
183         \hline
184         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Geo localizar anuncios}} \\
185         \hline
186         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-08}} \\
187         \hline
188         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
189         \hline
190         \normalsize\textbf{Descripción} & \normalsize{Los anuncios deben poder ser localizados geográficamente mediante coordenadas GPS.} \\
191         \hline
192         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Baja}} \\
193         \hline
194     \end{tabularx}
195     \caption{\emph{Tabla Requisito Aplicación Web 8.}}
196     \label{tab:requisitoSW8}
197 \end{table}
198
199 \begin{table}[H]
200 \centering
201 \scriptsize
202     \begin{tabularx}{\textwidth}{|l|X|}
203         \hline
204         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Ver y editar datos personales}} \\
205         \hline
206         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-09}} \\
207         \hline
208         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
209         \hline
210         \normalsize\textbf{Descripción} & \normalsize{El sistema debe permitir que cualquier usuario con cualquier rol pueda ver y editar sus datos personales.} \\
211         \hline
212         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Baja}} \\
213         \hline
214     \end{tabularx}
215     \caption{\emph{Tabla Requisito Aplicación Web 9.}}
216     \label{tab:requisitoSW9}
217 \end{table}
218
219 \begin{table}[H]
220 \centering
221 \scriptsize
222     \begin{tabularx}{\textwidth}{|l|X|}
223         \hline
224         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Añadir nuevas oficinas o sucursales}} \\
225         \hline
226         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-10}} \\
227         \hline
228         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
229         \hline
230         \normalsize\textbf{Descripción} & \normalsize{Se debe permitir que el usuario con rol empresarial añada nuevas oficinas o sucursales de una determinada empresa.} \\
231         \hline
232         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
233         \hline
234     \end{tabularx}
235     \caption{\emph{Tabla Requisito Aplicación Web 10.}}
236     \label{tab:requisitoSW10}
237 \end{table}
238
239 \begin{table}[H]
240 \centering
241 \scriptsize
242     \begin{tabularx}{\textwidth}{|l|X|}
243         \hline
244         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Edición de los datos de las oficinas y sucursales}} \\
245         \hline
246         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-11}} \\
247         \hline
248         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
249         \hline
250         \normalsize\textbf{Descripción} & \normalsize{Se deberá permitir la edición de los datos de las oficinas o sucursales existentes en el sistema y pertenecientes a un determinado usuario con rol empresarial.} \\
251         \hline
252         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
253         \hline
254     \end{tabularx}
255     \caption{\emph{Tabla Requisito Aplicación Web 11.}}
256     \label{tab:requisitoSW11}
257 \end{table}
258
259 \begin{table}[H]
260 \centering
261 \scriptsize
262     \begin{tabularx}{\textwidth}{|l|X|}
263         \hline
264         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Asociar oficinas y sucursales con anuncios}} \\
265         \hline
266         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-12}} \\
267         \hline
268         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
269         \hline
270         \normalsize\textbf{Descripción} & \normalsize{El sistema debe permitir que las oficinas y sucursales pertenecientes a un determinado usuario con rol empresarial se asocien con anuncios pertenecientes a ese mismo usuario y por tanto a la empresa a la que pertenecen esas oficinas o sucursales.} \\
271         \hline
272         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
273         \hline
274     \end{tabularx}
275     \caption{\emph{Tabla Requisito Aplicación Web 12.}}
276     \label{tab:requisitoSW12}
277 \end{table}
278
279 \begin{table}[H]
280 \centering
281 \scriptsize
282     \begin{tabularx}{\textwidth}{|l|X|}
283         \hline
284         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Las oficinas y sucursales deben estar localizadas geográficamente}} \\
285         \hline
286         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-13}} \\
287         \hline
288         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
289         \hline
290         \normalsize\textbf{Descripción} & \normalsize{Se debe poder localizar geográficamente las oficinas y sucursales.} \\
291         \hline
292         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
293         \hline
294     \end{tabularx}
295     \caption{\emph{Tabla Requisito Aplicación Web 13.}}
296     \label{tab:requisitoSW13}
297 \end{table}
298
299 \begin{table}[H]
300 \centering
301 \scriptsize
302     \begin{tabularx}{\textwidth}{|l|X|}
303         \hline
304         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Añadir nuevas categorías de empresa}} \\
305         \hline
306         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-14}} \\
307         \hline
308         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
309         \hline
310         \normalsize\textbf{Descripción} & \normalsize{El sistema debe permitir añadir nuevas categorías de empresa por parte del usuario con rol empresarial.} \\
311         \hline
312         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
313         \hline
314     \end{tabularx}
315     \caption{\emph{Tabla Requisito Aplicación Web 14.}}
316     \label{tab:requisitoSW14}
317 \end{table}
318
319 \begin{table}[H]
320 \centering
321 \scriptsize
322     \begin{tabularx}{\textwidth}{|l|X|}
323         \hline
324         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Editar categorías de empresa}} \\
325         \hline
326         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-15}} \\
327         \hline
328         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
329         \hline
330         \normalsize\textbf{Descripción} & \normalsize{Se debe permitir la edición de las categorías de empresa que el usuario con rol empresarial haya creado previamente.} \\
331         \hline
332         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
333         \hline
334     \end{tabularx}
335     \caption{\emph{Tabla Requisito Aplicación Web 15.}}
336     \label{tab:requisitoSW15}
337 \end{table}
338
339 \begin{table}[H]
340 \centering
341 \scriptsize
342     \begin{tabularx}{\textwidth}{|l|X|}
343         \hline
344         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Sección para el listado de oficinas y sucursales de una empresa}} \\
345         \hline
346         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-16}} \\
347         \hline
348         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
349         \hline
350         \normalsize\textbf{Descripción} & \normalsize{El sistema debe permitir el listado de las oficinas y sucursales creadas previamente por el usuario con rol empresarial.} \\
351         \hline
352         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
353         \hline
354     \end{tabularx}
355     \caption{\emph{Tabla Requisito Aplicación Web 16.}}
356     \label{tab:requisitoSW16}
357 \end{table}
358
359 \begin{table}[H]
360 \centering
361 \scriptsize
362     \begin{tabularx}{\textwidth}{|l|X|}
363         \hline
364         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Sección para el listado de las categorías de una empresa}} \\
365         \hline
366         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-17}} \\
367         \hline
368         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
369         \hline
370         \normalsize\textbf{Descripción} & \normalsize{Se debe permitir el listado de todas las categorías creadas previamente por el usuario con rol empresarial.} \\
371         \hline
372         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
373         \hline
374     \end{tabularx}
375     \caption{\emph{Tabla Requisito Aplicación Web 17.}}
376     \label{tab:requisitoSW17}
377 \end{table}
378
379 \begin{table}[H]
380 \centering
381 \scriptsize
382     \begin{tabularx}{\textwidth}{|l|X|}
383         \hline
384         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Las categorías de las empresas deben tener un orden jerárquico}} \\
385         \hline
386         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-18}} \\
387         \hline
388         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
389         \hline
390         \normalsize\textbf{Descripción} & \normalsize{Las categorías de las empresas deben ordenarse de forma jerárquica. Por ejemplo, de una categoría llamada ``Calzado'' podrán depender jerárquicamente otras como por ejemplo pueden ser ``Sandalias'', ``Mocasines'', etc. Las relaciones jerárquicas serán creadas por el usuario con rol empresarial y el sistema debe facilitar la creación de nuevas jerarquías y debe mostrar correctamente las relaciones entre categorías creadas por este usuario.} \\
391         \hline
392         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
393         \hline
394     \end{tabularx}
395     \caption{\emph{Tabla Requisito Aplicación Web 18.}}
396     \label{tab:requisitoSW18}
397 \end{table}
398
399 \begin{table}[H]
400 \centering
401 \scriptsize
402     \begin{tabularx}{\textwidth}{|l|X|}
403         \hline
404         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Las categorías de las empresas deben asociarse a categorías genéricas}} \\
405         \hline
406         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-19}} \\
407         \hline
408         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
409         \hline
410         \normalsize\textbf{Descripción} & \normalsize{Toda categoría de empresa debe estar asociada con una categoría de tipo general que es la que el usuario final (el usuario con rol ``normal'') finalmente verá y a la que se asociará para recibir notificaciones de nuevos anuncios de su interés. Estas categorías generales pueden ser creadas directamente por un súper usuario con permisos de administración de la aplicación Web.} \\
411         \hline
412         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
413         \hline
414     \end{tabularx}
415     \caption{\emph{Tabla Requisito Aplicación Web 19.}}
416     \label{tab:requisitoSW19}
417 \end{table}
418
419 \begin{table}[H]
420 \centering
421 \scriptsize
422     \begin{tabularx}{\textwidth}{|l|X|}
423         \hline
424         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Usuario rol ``normal'' asociado a categorías generales}} \\
425         \hline
426         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-20}} \\
427         \hline
428         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
429         \hline
430         \normalsize\textbf{Descripción} & \normalsize{Los usuarios que no tienen rol empresarial únicamente pueden asociarse a categorías de tipo general. El sistema debe permitir que el usuario se asocie de forma fácil e intuitiva con las categorías generales que se hallen en la Web. El usuario acabará recibiendo anuncios relacionados con esas categorías generales.} \\
431         \hline
432         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Baja}} \\
433         \hline
434     \end{tabularx}
435     \caption{\emph{Tabla Requisito Aplicación Web 20.}}
436     \label{tab:requisitoSW20}
437 \end{table}
438
439 \begin{table}[H]
440 \centering
441 \scriptsize
442     \begin{tabularx}{\textwidth}{|l|X|}
443         \hline
444         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Al entrar en la aplicación se mostrarán los datos del usuario.}} \\
445         \hline
446         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-21}} \\
447         \hline
448         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
449         \hline
450         \normalsize\textbf{Descripción} & \normalsize{Al hacer login por primera vez, el sistema mostrará los datos del usuario. En caso de ser el usuario con rol empresarial se mostrarán los datos de la empresa creada por dicho usuario.} \\
451         \hline
452         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Baja}} \\
453         \hline
454     \end{tabularx}
455     \caption{\emph{Tabla Requisito Aplicación Web 21.}}
456     \label{tab:requisitoSW21}
457 \end{table}
458
459 \begin{table}[H]
460 \centering
461 \scriptsize
462     \begin{tabularx}{\textwidth}{|l|X|}
463         \hline
464         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Framework Symfony PHP.}} \\
465         \hline
466         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-23}} \\
467         \hline
468         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{No funcional}} \\
469         \hline
470         \normalsize\textbf{Descripción} & \normalsize{Se usará para el desarrollo web el framework PHP Symfony.} \\
471         \hline
472         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Baja}} \\
473         \hline
474     \end{tabularx}
475     \caption{\emph{Tabla Requisito Aplicación Web 23.}}
476     \label{tab:requisitoSW22}
477 \end{table}
478
479 \subsubsection{No funcionales}
480
481 \begin{table}[H]
482 \centering
483 \scriptsize
484     \begin{tabularx}{\textwidth}{|l|X|}
485         \hline
486         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Código abierto.}} \\
487         \hline
488         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-24}} \\
489         \hline
490         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{No funcional}} \\
491         \hline
492         \normalsize\textbf{Descripción} & \normalsize{Las herramientas empleadas deben ser de código abierto.} \\
493         \hline
494         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
495         \hline
496     \end{tabularx}
497     \caption{\emph{Tabla Requisito Aplicación Web 24.}}
498     \label{tab:requisitoSW22}
499 \end{table}
500
501 \subsubsection{Usabilidad}
502
503 \begin{table}[H]
504 \centering
505 \scriptsize
506     \begin{tabularx}{\textwidth}{|l|X|}
507         \hline
508         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{El nombre del usuario debe ser siempre visible.}} \\
509         \hline
510         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSW-22}} \\
511         \hline
512         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Usabilidad}} \\
513         \hline
514         \normalsize\textbf{Descripción} & \normalsize{El nombre del usuario debe mostrarse en la esquina superior derecha de la aplicación.} \\
515         \hline
516         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Baja}} \\
517         \hline
518     \end{tabularx}
519     \caption{\emph{Tabla Requisito Aplicación Web 22.}}
520     \label{tab:requisitoSW22}
521 \end{table}
522
523
524 \subsection{Requisitos software, aplicación Android}
525
526 \subsubsection{Funcionales}
527
528 \begin{table}[H]
529 \centering
530 \scriptsize
531     \begin{tabularx}{\textwidth}{|l|X|}
532         \hline
533         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{El usuario debe hacer login para recibir notificaciones}} \\
534         \hline
535         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSA-01}} \\
536         \hline
537         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
538         \hline
539         \normalsize\textbf{Descripción} & \normalsize{Para poder empezar a recibir nuevas notificaciones o anuncios el usuario debe hacer login en el sistema remoto.} \\
540         \hline
541         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
542         \hline
543     \end{tabularx}
544     \caption{\emph{Tabla Requisito Aplicación Android 1.}}
545     \label{tab:requisitoSA1}
546 \end{table}
547
548 \begin{table}[H]
549 \centering
550 \scriptsize
551     \begin{tabularx}{\textwidth}{|l|X|}
552         \hline
553         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Administrar notificaciones/anuncios sin login}} \\
554         \hline
555         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSA-02}} \\
556         \hline
557         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
558         \hline
559         \normalsize\textbf{Descripción} & \normalsize{El usuario debe poder administrar los anuncios recibidos incluso cuando no tiene conexión con el sistema remoto, es decir, cuando no tiene conexión con la aplicación Web.} \\
560         \hline
561         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
562         \hline
563     \end{tabularx}
564     \caption{\emph{Tabla Requisito Aplicación Android 2.}}
565     \label{tab:requisitoSA2}
566 \end{table}
567
568 \begin{table}[H]
569 \centering
570 \scriptsize
571     \begin{tabularx}{\textwidth}{|l|X|}
572         \hline
573         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Recepción de notificaciones en segundo plano}} \\
574         \hline
575         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSA-03}} \\
576         \hline
577         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
578         \hline
579         \normalsize\textbf{Descripción} & \normalsize{Se debe permitir que el usuario pueda recibir notificaciones en segundo plano acerca de la recepción de nuevos anuncios. La aplicación no tiene por qué estar ejecutándose en primer plano para recibir notificaciones de anuncios de interés.} \\
580         \hline
581         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
582         \hline
583     \end{tabularx}
584     \caption{\emph{Tabla Requisito Aplicación Android 3.}}
585     \label{tab:requisitoSA3}
586 \end{table}
587
588 \begin{table}[H]
589 \centering
590 \scriptsize
591     \begin{tabularx}{\textwidth}{|l|X|}
592         \hline
593         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Habilitar/deshabilitar la recepción de notificaciones}} \\
594         \hline
595         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSA-04}} \\
596         \hline
597         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
598         \hline
599         \normalsize\textbf{Descripción} & \normalsize{Debe existir una opción por la cual el usuario de la aplicación Android pueda habilitar y deshabilitar la recepción de nuevas notificaciones o anuncios.} \\
600         \hline
601         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Baja}} \\
602         \hline
603     \end{tabularx}
604     \caption{\emph{Tabla Requisito Aplicación Android 4.}}
605     \label{tab:requisitoSA4}
606 \end{table}
607
608 \begin{table}[H]
609 \centering
610 \scriptsize
611     \begin{tabularx}{\textwidth}{|l|X|}
612         \hline
613         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Visionado rápido de notificaciones no leídas}} \\
614         \hline
615         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSA-05}} \\
616         \hline
617         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
618         \hline
619         \normalsize\textbf{Descripción} & \normalsize{A través de una ventana emergente y en cualquier momento (incluso cuando la aplicación está ejecutándose en segundo plano) el usuario debe poder tener acceso a las notificaciones o anuncios que haya recibido y que todavía no ha leído.} \\
620         \hline
621         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
622         \hline
623     \end{tabularx}
624     \caption{\emph{Tabla Requisito Aplicación Android 5.}}
625     \label{tab:requisitoSA5}
626 \end{table}
627
628 \begin{table}[H]
629 \centering
630 \scriptsize
631     \begin{tabularx}{\textwidth}{|l|X|}
632         \hline
633         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Administración de notificaciones y anuncios}} \\
634         \hline
635         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSA-06}} \\
636         \hline
637         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Funcional}} \\
638         \hline
639         \normalsize\textbf{Descripción} & \normalsize{El sistema debe facilitar la administración de los anuncios y notificaciones recibidas. Para ello el usuario debe poder eliminar o borrar los anuncios y notificaciones que haya recibido y que ya no desea continuar teniendo en su dispositivo móvil.} \\
640         \hline
641         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Alta}} \\
642         \hline
643     \end{tabularx}
644     \caption{\emph{Tabla Requisito Aplicación Android 6.}}
645     \label{tab:requisitoSA6}
646 \end{table}
647
648 \subsubsection{Usabilidad}
649
650 \begin{table}[H]
651 \centering
652 \scriptsize
653     \begin{tabularx}{\textwidth}{|l|X|}
654         \hline
655         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Configuración de pantalla}} \\
656         \hline
657         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSA-07}} \\
658         \hline
659         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Usabilidad}} \\
660         \hline
661         \normalsize\textbf{Descripción} & \normalsize{Solo es necesario que la aplicación Android se muestre correctamente en modo vertical.} \\
662         \hline
663         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
664         \hline
665     \end{tabularx}
666     \caption{\emph{Tabla Requisito Aplicación Android 7.}}
667     \label{tab:requisitoSA7}
668 \end{table}
669
670 \begin{table}[H]
671 \centering
672 \scriptsize
673     \begin{tabularx}{\textwidth}{|l|X|}
674         \hline
675         \multicolumn{2}{|c|}{\cellcolor[gray]{0.8}\normalsize\textbf{Lenguaje sencillo}} \\
676         \hline
677         \normalsize\textbf{Código identificador} & \multicolumn{1}{c|}{\cellcolor[gray]{0.8}\normalsize\textbf{RSA-08}} \\
678         \hline
679         \normalsize\textbf{Tipo} & \multicolumn{1}{c|}{\normalsize{Usabilidad}} \\
680         \hline
681         \normalsize\textbf{Descripción} & \normalsize{El sistema debe ser fácilmente entendible por cualquier usuario.} \\
682         \hline
683         \normalsize\textbf{Prioridad} & \multicolumn{1}{c|}{\normalsize{Media}} \\
684         \hline
685     \end{tabularx}
686     \caption{\emph{Tabla Requisito Aplicación Android 8.}}
687     \label{tab:requisitoSA7}
688 \end{table}
689
690
691 \subsection{Modelando los requisitos, diagrama de casos de uso}
692
693 En la Figura~\ref{fig:MobiAdsUseCaseWeb}) se puede observar el diagrama de casos de uso de la aplicación Web desarrollada.
694 \begin{figure}[H]
695     \centering
696         \includegraphics[width=\textwidth]{fig/MobiAdsUseCaseWeb}
697     \caption{\emph{Diagrama de casos de uso de la aplicación Web}}
698     \label{fig:MobiAdsUseCaseWeb}
699 \end{figure}
700
701 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.
702
703 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''.
704
705 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.
706
707 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}.
708
709
710 \subsection{Descripción de los casos de uso}
711
712 \begin{table}[H]
713 \centering
714 \scriptsize
715     \begin{tabularx}{\textwidth}{|X|X|}
716         \hline
717         \normalsize\textbf{Nombre} & \\
718         \hline
719         \normalsize\textbf{Requisito} & \\
720         \hline
721         \normalsize\textbf{Actores} & \\
722         \hline
723         \normalsize\textbf{Objetivo} & \\
724         \hline
725         \normalsize\textbf{Precondiciones} & \\
726         \hline
727         \normalsize\textbf{Postcondiciones} & \\
728         \hline
729         \normalsize\textbf{Escenario de éxito principal} & \\
730         \hline
731     \end{tabularx}
732     \caption{\emph{Tabla de casos de uso 1.}}
733     \label{tab:tabladecasosdeuso1}
734 \end{table}