Manual Tecnico - Pruebas - Semestrales
Manual Tecnico - Pruebas - Semestrales
Manual Tecnico - Pruebas - Semestrales
1. PROPÓSITO................................................................................................... 2
2. INSTALACIÓN ................................................................................................ 4
2.1 Python V 3.4 .............................................................................................. 4
2.2 Entorno Virtual........................................................................................... 4
3. CONFIGURACIONES DE DJANGO ............................................................... 5
3.1 Conexión De La Base De Datos ................................................................ 5
4. MODELO BASE DE DATOS........................................................................... 5
5. DICCIONARIO DE DATOS ............................................................................. 6
6. DESCRIPCIÓN CODIGO FUENTE ................................................................ 9
1
LISTA DE TABLAS
2
LISTA DE FIGURAS
3
1. PROPÓSITO
Con este manual se quiere mostrar la estructura del aplicativo web para la
presentación de pruebas semestrales de la I.E.T.S para que sirva de guía para
aquellos usuarios con conocimientos más avanzados en desarrollo de sistemas
de información y que quieran hacer mejoras a nivel futuro. Propósito
2. INSTALACIÓN
Para la correcta instalación de este aplicativo se requiere de ciertos elementos
como lo es el Python en su versión 3.4, Django versión 1.9, MySQL y para mayor
comodidad se sugiere crear un entorno virtual donde se va a tener instalado todo
lo necesario para que el aplicativo funcione correctamente y sin alterar el resto
de funcionalidades del equipo que lo aloje.
2.1 Python V 3.4
Esta versión de python se puede encontrar en su página oficial, donde se
encuentran con las características de los ejecutables según el tipo de equipo que
se tenga. A continuación, el link de la página:
https://www.python.org/downloads/release/python-340/
Una vez se ha descargado el archivo de extensión .msi, se procede a ejecutarlo
siguiendo los pasos de instalación normales, luego para que el equipo pueda
reconocer el programa se debe agregar unas líneas al PATH de la siguiente
manera:
1. Panel de control
2. Sistema y seguridad
3. Sistema
4. Configuración avanzada del sistema
5. Variables de entorno
6. Variable PATH
Se edita y se escribe: “C:\Python34; C:\Python34\Scripts” la ruta depende de
donde se tenga instálalo el python.
2.2 Entorno virtual
El entorno virtual se usa en casos de que en el equipo se trabajen otros
softwares que requieran los mismos componentes, pero quizás de diferentes
versiones, como no se pueden tener dos versiones de un mismo componente se
crean los entornos virtuales en los que se simula un entorno de desarrollo
permitiendo instalar cuantas dependencias se requieran sin afectar nada en el
equipo.
1. Abrir consola
2. Línea para instalar el virtualenv y para crearlo:
$ pip install virtualenv
$ virtualenv nombre_entorno
4
3. Activar el entorno:
$ nombre_entorno\Scripts\activate
4. Instalar librerías necesarias:
$ pip install Django==1.9
$ pip install django-tinymce==2.3.0
$ pip install html5lib==0.9999999
$ pip install lxml==3.6.0
$ pip install dj-database-url==0.2.2
$ pip install Pillow==3.1.1
$ pip install pisa==3.0.33
$ pip install pycparser==2.14
$ pip install PyPDF2==1.26.0
$ pip install Pyphen==0.9.4
$ pip install six==1.10.0
$ pip install psycopg2==2.5.2
$ pip install dj-static==0.0.6
$ pip install gunicorn==18.0
$ pip install static==1.0.2
3. CONFIGURACIONES DE DJANGO
3.1 Conexión de la base de datos
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'prsemestral',
'USER': 'semusr',
'PASSWORD': '12345',
'OPTIONS': {
'autocommit': True,
},
5
Figura 1 Modelo entidad relación
5. DICCIONARIO DE DATOS
6
Nombre Varchar 20 Not Nombre del grupo
Nivel_id Int 11 Not Foránea a nivel
Llave primaria: id
Llave foránea: grupo.nivel_id REFERENCES nivel.id
7
Materia_id Int 11 Not Foránea a Materia
Nivel_id Int 11 Not Foránea a Nivel
Llave primaria: id
Llave foránea: pregunta.caso_id REFERENCES caso.id
Llave foránea: pregunta.materia _id REFERENCES materia.id
Llave foránea: pregunta.nivel_id REFERENCES nivel.id
8
Llave foránea: test.estudiante_id REFERENCES estudiante.id
Llave foránea: test.examen_id REFERENCES examen.id
Llave foránea: test.pregunta_id REFERENCES pregunta.id
9
aplicativo y están relacionadas con
las funciones que están en el
views.py
Agre_materia.html Vista en la que se agregan
materias, editan y borran
Agre_nivel.html Vista en la que se agregan niveles,
editan y borran
Agregar.html Vista en la que se cargar las
preguntas y enviarlas a la base de
datos
Crear_grados.html Vista en la que se agregan los
grados, editan y borran
CargarEstudiantes.html Vista en la que se carga el listado
de estudiantes para enviarlo a la
base de datos
Examen_nuevo.html Vista para crear, editar, asignar y
activar exámenes
EditPregunta.html Vista para editar el contenido de
una pregunta en especifico
Index_estudiante.html Vista que le muestra al estudiante
los exámenes disponibles para
contestar
Estudiante_examen.html Vista para renderizar el examen con
sus respectivas preguntas y
opciones de respuestas
EditExamen.html Vista para editar la composición del
examen seleccionado
Index.html Es la página inicial del aplicativo
Login.html La vista para ingresar el usuario y
contraseña y poder acceder a la
aplicación
Registro.html Vista para crear usuarios tipo
estudiantes de manera individual
Registro_docente.html Vista para que los docentes y
admirativos se registren
Template.html Es una plantilla de base para el
índex y el Login
Template_docente.html Plantilla base para todas vistas
administrativas
Template_estudiante.html Plantilla base para las vistas del
estudiante
Ver_grados_estudiantes.html Vista para listar los grados y
posteriormente acceder a ver los
estudiantes
Ver_estudiantes.html Vista que muestra el listado de un
grado en especifico
10
Ver_materiasPre.html Vista para listar las materias y luego
acceder a sus preguntas
Ver_preguntas.html Vista para listar las preguntas de
una materia determinada
11
agre_examen Guarda los datos de un
examen nuevo
show_examenes Renderizar y envía los
datos al HTML para que
el usuario active o
asigne un examen
ShowEditExamen Recibe el id del examen
que quieren editar,
recopila la información y
la envía a una vista
EditExamen Recibe la información
del examen ya editado y
procede a guardarla en
la DB
agre_grupo Crea un grupo ligado a
un nivel
grupos_viw renderizar el listado de
todos los grados
viw_estudiantes Renderizar el listado de
estudiantes por grupo
update_estudiante Actualiza a información
de determinado
estudiante
viw_grados_estudiantes Renderizar listado de
grados para poder
seleccionar el grado del
listado de estudiantes
Views.py ViwMateriaPre Renderizar las materias
para seleccionar y ver
sus determinadas
preguntas
ViwPreguntas Renderizar todas las
preguntas de una
materia en especifico
grupo_examen Recibe la asignación de
los exámenes a los
grados
materia_new Guarda el registro de
una nueva materia
nivel_new Guarda el registro de un
nuevo nivel
estudiante_examen Procesa los datos y
renderizar el examen
con sus preguntas y
respuestas
Índex Renderizar la vista
inicial del aplicativo
12
edit_nivel Recibe los cambios del
nivel y los guarda
delete_nivel Recibe el id del nivel,
revisa que no haya
dependencias y lo
elimina
edit_grado Recibe los cambios del
grado y los guarda
delete_grado Recibe el id del grado,
revisa que no haya
dependencias y lo
elimina
delete_pregunta Recibe el id de la
pregunta, revisa que no
haya dependencias y lo
elimina
delete_estudiante Recibe el id del
estudiante, revisa que
Views.py no haya dependencias y
lo elimina
edit_materia Recibe los cambios de la
materia y los guarda
delete_materia Recibe el id del nivel,
revisa que no haya
dependencias y lo
elimina
Archivo Recibe los archivos que
se suben y los almacena
en una ruta del aplicativo
Descomprimir Recibe el nombre del
archivo que se subió en
.zip y lo descomprime
Lectura Lee y procesa al archivo
XML que contiene la
información de las
preguntas y la guarda en
sus respectivas tablas
13