Example #1
0
def prueba_obtener_nombres_posibles_de_clientes(resultados_pruebas):
    archivo_3 = consultas.cargar_archivo(NOMBRE_ARCHIVO_VALIDO_3)

    descripcion = "obtiene clientes cuando se especifica el nombre completo"
    res_esperado = ["C0"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(archivo_3, "C0")
    correr_prueba(res_esperado == res_real, descripcion, resultados_pruebas)
    
    descripcion = "obtiene clientes sin repetir si hicieron varias compras"
    res_esperado = ["C1"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(archivo_3, "C1")
    correr_prueba(res_esperado == res_real, descripcion, resultados_pruebas)
    
    descripcion = "obtener clientes diferencia espacios"
    res_esperado = ["C2"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(archivo_3, "C2")
    correr_prueba(res_esperado == res_real, descripcion, resultados_pruebas)
    
    descripcion = "obtiene clientes cuando se especifica el nombre incompleto"
    res_esperado = ["CC3", "C3C", "DC3", "C3"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(archivo_3, "C3")
    correr_prueba(set(res_esperado) == set(res_real), descripcion, resultados_pruebas)
    
    descripcion = "obtiene clientes cuando sus nombres tienen espacios"
    res_esperado = ["C C4 C C"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(archivo_3, "C4")
    correr_prueba(res_esperado == res_real, descripcion, resultados_pruebas)
Example #2
0
def prueba_obtener_nombres_posibles_de_clientes(resultados_pruebas):
    archivo_3 = consultas.cargar_archivo(NOMBRE_ARCHIVO_VALIDO_3)

    descripcion = "obtiene clientes cuando se especifica el nombre completo"
    res_esperado = ["C0"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(
        archivo_3, "C0")
    correr_prueba(res_esperado == res_real, descripcion, resultados_pruebas)

    descripcion = "obtiene clientes sin repetir si hicieron varias compras"
    res_esperado = ["C1"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(
        archivo_3, "C1")
    correr_prueba(res_esperado == res_real, descripcion, resultados_pruebas)

    descripcion = "obtener clientes diferencia espacios"
    res_esperado = ["C2"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(
        archivo_3, "C2")
    correr_prueba(res_esperado == res_real, descripcion, resultados_pruebas)

    descripcion = "obtiene clientes cuando se especifica el nombre incompleto"
    res_esperado = ["CC3", "C3C", "DC3", "C3"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(
        archivo_3, "C3")
    correr_prueba(
        set(res_esperado) == set(res_real), descripcion, resultados_pruebas)

    descripcion = "obtiene clientes cuando sus nombres tienen espacios"
    res_esperado = ["C C4 C C"]
    res_real = consultas.obtener_clientes_con_nombre_incompleto(
        archivo_3, "C4")
    correr_prueba(res_esperado == res_real, descripcion, resultados_pruebas)
Example #3
0
def consultar_productos_comprados_por_cliente(archivo):
    ''' Función que exporta a un archivo de salida un listado de los 
    productos comprados por un cliente, dado un archivo de entrada. 
    Se le solicita al usuario parte del nombre del cliente para después 
    seleccionar el nombre completo de una lista.
    '''
    # Obtiene el nombre del cliente.
    print ("Ingrese parte del nombre del cliente a consultar.")
    nombre_parcial = interaccion_usuario.ingresar_cadena_no_vacia()
    nombres_posibles = \
        consultas.obtener_clientes_con_nombre_incompleto(archivo, nombre_parcial)    
        
    if len(nombres_posibles) == 0:
        print ("No se encontraron productos con ese nombre.")
        return
    
    indice_nombre = \
        interaccion_usuario.mostrar_menu_generico(nombres_posibles, "Cancelar")
    if indice_nombre == -1:
        return
        
    nombre_cliente = nombres_posibles[indice_nombre]
    resultados = consultas.obtener_productos_comprados_por_cliente(archivo, nombre_cliente)
    
    # Exporta los resultados - se preparan los datos de acuerdo a la 
    #   documentación de la función del módulo salida_resultados.
    titulo_consulta = "Productos que compró el cliente %s" % nombre_cliente
    cabecera = ("Producto",)
    resultados = [ (resultado,) for resultado in resultados ]
    nombre_salida = \
        salida_resultados.exportar_resultados(resultados, cabecera, titulo_consulta)
    
    print ("Resultados exportados al archivo " + nombre_salida)
Example #4
0
def consultar_productos_comprados_por_cliente(archivo):
    ''' Función que exporta a un archivo de salida un listado de los 
    productos comprados por un cliente, dado un archivo de entrada. 
    Se le solicita al usuario parte del nombre del cliente para después 
    seleccionar el nombre completo de una lista.
    '''
    # Obtiene el nombre del cliente.
    print("Ingrese parte del nombre del cliente a consultar.")
    nombre_parcial = interaccion_usuario.ingresar_cadena_no_vacia()
    nombres_posibles = \
        consultas.obtener_clientes_con_nombre_incompleto(archivo, nombre_parcial)

    if len(nombres_posibles) == 0:
        print("No se encontraron productos con ese nombre.")
        return

    indice_nombre = \
        interaccion_usuario.mostrar_menu_generico(nombres_posibles, "Cancelar")
    if indice_nombre == -1:
        return

    nombre_cliente = nombres_posibles[indice_nombre]
    resultados = consultas.obtener_productos_comprados_por_cliente(
        archivo, nombre_cliente)

    # Exporta los resultados - se preparan los datos de acuerdo a la
    #   documentación de la función del módulo salida_resultados.
    titulo_consulta = "Productos que compró el cliente %s" % nombre_cliente
    cabecera = ("Producto", )
    resultados = [(resultado, ) for resultado in resultados]
    nombre_salida = \
        salida_resultados.exportar_resultados(resultados, cabecera, titulo_consulta)

    print("Resultados exportados al archivo " + nombre_salida)