0.1.0 • Published 11 months ago

mdlinks-b v0.1.0

Weekly downloads
-
License
ISC
Repository
github
Last release
11 months ago

Markdown Links

Índice


1. Preámbulo

Markdown es un lenguaje de marcado ligero usado en plataformas que manejan texto plano (GitHub, foros, blogs, ...) .

Estos archivos Markdown normalmente contienen links (vínculos/ligas) que muchas veces están rotos o ya no son válidos y eso perjudica mucho el valor de la información que se quiere compartir.

2. Resumen del proyecto

Se creo una herramienta usando Node.js, que lea y analice archivos en formato Markdown, para verificar los links que contengan y reportar algunas estadísticas como total de links, links únicos y links rotos. Por ejemplo para detectar los links rotos en los readmes de los proyectos o en un área de facturación verificar los links rotos de una factura digital.

3. Justificación

La implementación de este proyecto tiene varias partes: leer del sistema de archivos, recibir argumentos a través de la línea de comando, analizar texto, hacer consultas HTTP, ... y todas estas cosas pueden enfocarse de muchas formas, tanto usando librerías como implementando en VanillaJS.

4. Consideraciones generales

  • La librería y el script ejecutable (herramienta de línea de comando - CLI) está implementado en JavaScript para ser ejecutados con Node.js.

  • El módulo debe ser instalable via npm install <github-user>/md-links. Este módulo debe incluir tanto un ejecutable que podamos invocar en la línea de comando como una interfaz que podamos importar con require para usarlo programáticamente.

  • Para personalizar el estilo de la aplicación en la terminal se uso la libreria chalk.

  • Se uso Jest y nodejs native Test runner para los tests unitarios de statements, functions, lines y branches.

  • Para este proyecto no se utilizó async/await.

  • Para este proyecto no se usó la versión síncrona de la función para leer archivos, readFileSync.

  • Uso de ES Modules (import/export), en lugar de commonJS (require/module.exports).

  • Para el parseado (análisis) del markdown para extraer los links se utilizo expresiones regulares(RegExp).

  • StandardJS para evitar que tu código JavaScript contenta errores con npm install standard -D adicional eslintConfig en package.json

5. Criterios de aceptación mínimos del proyecto

Archivos del proyecto

  • README.md con descripción del módulo, instrucciones de instalación/uso, documentación del API y ejemplos.
  • mdlinks.js: Desde este archivo se exportan funciones a index.js
  • index.js: Desde este archivo se exporta una función (mdLinks).
  • package.json con nombre, versión, descripción, autores, licencia, dependencias, scripts (pretest, test, ...), main, bin
  • .editorconfig con configuración para editores de texto. Este archivo no se debe cambiar.
  • .gitignore para ignorar node_modules u otras carpetas que no deban incluirse en control de versiones (git).
  • test/md-links.spec.js y `test/index.spec.js que contienen los tests unitarios.

6. Funcionamiento

Diagrama de flujo

diagrama

CLI (Command Line Interface - Interfaz de Línea de Comando)

Se ejecuta de la siguiente manera a través de la terminal:

md-links <path-to-file> [options]

./some/example.md
$ md-links ./some/example.md 
Href: URL encontrada.
Text: Texto que aparecía dentro del link (`<a>`).
File: Ruta del archivo donde se encontró el link.
./some/example.md --validate
$ md-links ./some/example.md --validate
Href: URL encontrada.
Text: Texto que aparecía dentro del link (`<a>`).
File: Ruta del archivo donde se encontró el link.
Status: Código de respuesta HTTP.
Msg: Mensaje `fail` en caso de fallo u `ok` en caso de éxito.
./some/example.md --stats

Si pasamos la opción --stats el output (salida) será un texto con estadísticas básicas sobre los links.

$ md-links ./some/example.md --stats
Total: 3
Unique: 3
./some/example.md --stats --validate

También podemos combinar --stats y --validate para obtener estadísticas que necesiten de los resultados de la validación.

$ md-links ./some/example.md --stats --validate
Total: 3
Unique: 3
Broken: 1
--help

Información de los comandos a utilizar.

$ md-links --help
<path>                    		All links .md
<path> --validate        		Links with status and msg
<path> --stats            		Stats: Total and Unique links
<path> --stats --validate 	Stats: Total, Unique and Broken links

0.1.0

11 months ago