martes, 6 de junio de 2017

Configuración de webdriver para manejar descarga de PDFs.

Uno de los grandes problemas al momento de crear tests para una aplicación web que entregue PDFs como resultado en algunas de sus funcionalidades,  es controlar el comportamiento por defecto que tendrá el navegador frente a dichos archivos. Según mi experiencia como QA de automatización los principales problemas son los siguientes:

  • Ventanas de confirmación de descarga. ¡Un verdadero dolor de cabeza!, es imposible interactuar con ellas porque son parte del navegador y no de la página web.
  • Ubicación del archivo a descargar. Un gran problema si no es manejado en la configuración de tu driver porque el navegador por defecto intentará usar sus carpetas ocultas en los lugares más oscuros de tu pc, ten en cuenta que además las rutas para dichos directorios son diferentes por sistema operativo, por lo tanto buscar manualmente o hardcodear una ruta es casi imposible sin previa investigación.
  • Plugins por defecto del navegador. Actualmente los navegadores son capaces de leer los PDFs sin ningún tipo de plugin de terceros. Esto es un problema bastante recurrente, intentas descargar un pdf, pero ¡pum! el navegador mágicamente lo abre, rompiendo totalmente con el flujo de tu test.


Para poder resolver estos problemas es necesario modificar las configuración de los navegadores y guardar estos cambios dentro de un perfil.

A continuación listaré y explicaré los pasos para crear estos perfiles con sus configuraciones necesarias para los drivers de Firefox y Chrome utilizando Python.

Firefox.

profile = webdriver.FirefoxProfile() #1

profile.set_preference("browser.download.folderList", 2)#2
profile.set_preference("browser.download.dir", cfg.temp_pdf)#3
profile.set_preference("browser.download.useDownloadDir", True)#4
profile.set_preference("browser.download.manager.showWhenStarting", False)#5
profile.set_preference("browser.helperApps.neverAsk.saveToDisk", "application/pdf")#6
profile.set_preference("browser.download.manager.showAlertOnComplete", False)#7
profile.set_preference("browser.download.manager.useWindow", False)#7
profile.set_preference("pdfjs.disabled", True)#9
self.driver = webdriver.Firefox(profile)#10

Configuración para firefox.

  1. Se crea un perfil de firefox vacío.
  2. Con el número 2 le indicamos a firefox que debe utilizar la carpeta especificada en el paso 3.
  3. Acá le proporcionaremos a firefox la carpeta que queremos utilizar como directorio de descarga.
  4. Ahora activamos el uso del directorio asignado en el paso 3.
  5. Apagamos la animación de comienzo de descarga. (Opcional)
  6. Este paso es muy importante, acá le pasaremos como parámetro los MIME type que queremos descargar sin preguntarMás info sobre MIME types.
  7. Desactivamos animación de descarga completa. (Opcional)
  8. Deshabilitamos la ventana de descarga de firefox.
  9. Apagamos el plugin por defecto de firefox para leer archivos PDF.
  10. Instanciamos el driver de Firefox pasando como parámetro nuestro profile recién creado.

Chrome
chrome_profile = webdriver.ChromeOptions()#1
profile = {"download.default_directory": cfg.temp_pdf,
           "download.prompt_for_download": False,
           "download.directory_upgrade": True,
           "safebrowsing.enabled": True,
           "plugins.always_open_pdf_externally": True}#2
chrome_profile.add_experimental_option("prefs", profile)#3
chrome_profile.add_argument("--disable-extensions")#4
chrome_profile.add_argument("--disable-print-preview")#5
self.driver = webdriver.Chrome(chrome_options=chrome_profile)#6

Configuración para Chrome.

  1. Se crea un perfil de chrome vacío.
  2. Acá creamos un diccionario con las siguientes configuraciones.
    1. Directorio por defecto para las descargas de chrome.
    2. Acá apagamos  la ventana que pregunta donde ubicar y como llamar el archivo por descargar.
    3. Opción para que chrome pueda crear la ruta de descarga si es que no existe.
    4. Navegación segura activada. (Opcional)
    5. Para abrir el pdf externamente.
  3. Se añade el diccionario recién creado como las preferencias del perfil.
  4. Desactiva todas las extensiones de Chrome para evitar que algún plugin del navegador intente abrir los archivos PDF.
  5. Acá desactivamos la vista de impresión para evitar nuevamente que algo intente abrir los PDFs.
  6. Finalmente instanciamos el chromedriver pasando como parámetros el perfil de chrome recién creado.
Tal como pudimos apreciar, la configuración para evitar la interrupción de tests que contengan PDFs es un tanto compleja, ya que se debe tener en consideración muchas variables como lugar de descarga, desactivación de plugins, etc. Como comentario profesional siempre recomiendo descargar los pdfs utilizando código para no crear tests completamente dependientes de la máquina en que se están corriendo los tests, debido a que estos tipos de tests no van a funcionar al 100% en drivers provistos por saucelabs.

1 comentario:

  1. Muy bueno..pero yo aun tengo problemas para automatizar la bajada de pdfs de Firefox, todo debido a win10. Como haces para pasar x encima del TWINUI de Windows 10???

    ResponderBorrar

Como activar el comando python en el CMD de windows 10.

Un problema bastante común para los novatos de python que usan windows 10 es correr scripts en la linea de comando. Generalmente este proble...