ETH Kipu
  • Ethereum Developer Pack
  • Módulo 1
    • Intro a Smart Contracts
      • Fundamentos de Blockchain
        • Antecedentes
        • Bitcoin
        • Qué es Blockchain
        • Conceptos Clave en Blockchain
        • Cómo funciona la Blockchain
        • Tipos de Blockchain
        • Modelos de Consenso
      • El nuevo Internet
        • Web 3
        • Elementos Fundamentales
        • Impacto de Ethereum en Diversos Sectores
      • Wallets
        • Componentes de una wallet
        • Tipos de Wallet
        • Códigos mnemónicos
      • Ethereum 101
        • Smart Contracts
        • Cuentas
          • Tipos de cuentas
          • Contenido de cuentas
        • Transacciones
          • Componentes
          • Ciclo de vida
        • Gas
        • Solidity
        • EVM
          • La máquina de estados
          • Opcodes
          • Cómo funciona la EVM
          • Clientes de ejecución
          • DApps
      • Blockchain Explorer
        • Funciones de un blockchain explorer
        • Beneficios de utilizar un blockchain explorer
      • Remix
        • Características de Remix
        • Workspaces o espacios de trabajo
        • Cargar y compilar un contrato
        • Desplegar en la máquina virtual de Remix (Remix VM)
        • Interactuando con funciones
        • Desplegar en una red pública
      • Crea tu primer Smart Contract
  • Módulo 2
    • Fundamentos de Solidity
      • Hello World
      • Tipos de Datos
      • Funciones
      • Variables
        • Ejercicio 1
      • Operadores
        • Ejercicio 2
      • Constructor
        • Ejercicio 3
      • Convenciones de nomenclatura
      • Tipos de almacenamiento para variables
      • Estructuras de Control
        • Ejercicio 4
      • Modificadores
      • Eventos
        • Ejercicio 5
      • Tipos de Referencia
        • Arrays
          • Ejercicio 6
        • Mappings
          • Ejercicio 7
        • Structs
          • Ejercicio 8
      • Address Payable
      • Cómo reciben Ether los contratos y funciones
      • Transferencias de Ether
      • Conceptos Avanzados
        • Codificación ABI
        • Hashing
        • This
        • Herencia
        • Abstract
        • Interface
        • Llamadas entre contratos
        • EVM
        • ABI
        • Bytecode
        • Opcodes
  • Módulo 3
    • Estándares, Librerías y Patrones
      • Buenas Prácticas de Diseño
      • Patrones de Diseño
      • EIP y ERC
      • ERC-20
      • ERC-721
      • Open Zeppelin
      • Crea un Token ERC-20
      • Almacenamiento Descentralizado: IPFS
      • Crea un Token ERC-721
      • DeFi
  • Módulo 4
    • Toolkit para desarrollo en Ethereum
      • Requisitos para el módulo 4
        • Terminal
        • Git y Github
        • Node.js y npm
        • Visual Studio Code para Solidity
      • Toolkit
        • JSON-RPC
        • Ethers.js
          • Ejercicio
        • Hardhat
          • Despliegue de un contrato en Hardhat
          • Despliegue de un contrato en una red pública
        • Scaffold-ETH
          • Características
          • Cómo instalar Scaffold-ETH
  • Módulo 5
    • Seguridad, Pruebas y Auditoría
      • Pruebas
        • Importancia de realizar pruebas
        • Métodos para probar contratos inteligentes
          • Pruebas automatizadas
          • Pruebas manuales
        • Conceptos importantes en testing
        • Herramientas para testing
        • Testing con Hardhat
        • Recursos adicionales
      • Seguridad
        • Una mentalidad distinta de diseño
        • Principales vulnerabilidades en smart contracts
          • Reentrancy attack (ataque de reentrada)
          • Replay attack (ataque de repetición)
          • Price Oracle Manipulation (Manipulación de Oráculos de Precios)
          • Missing Access Control (Pérdida de Control de Acceso)
          • Reward Manipulation (Manipulación de Recompensas)
          • Failure to Initialize (Falla al Inicializar)
          • Front-running
          • Invariant Breaks (Ruptura de invariantes)
          • Mishandling of ETH (Mal manejo de ETH)
          • Denial of Service (DoS - Denegación de Servicio)
          • Integer overflow and underflow (desbordamiento y subdesbordamiento de enteros)
          • Phishing y Typosquatting
        • Recursos adicionales
      • Auditoría de smart contracts
        • Proceso de Auditoría
        • Herramientas
        • Cómo prepararse para una auditoría
        • El test Rekt
        • Retos
        • Recursos adicionales
  • Contribuye
    • Kipu Explorer
Powered by GitBook
On this page

Was this helpful?

  1. Módulo 5
  2. Seguridad, Pruebas y Auditoría
  3. Pruebas
  4. Métodos para probar contratos inteligentes

Pruebas manuales

Las pruebas manuales son asistidas por humanos e implican ejecutar cada caso de prueba en la suite de pruebas uno tras otro. Son diferentes de las pruebas automatizadas, donde se puede ejecutar simultáneamente múltiples pruebas distintas en un contrato y obtener un informe que muestre todas las pruebas fallidas y exitosas.

Las pruebas manuales efectivas requieren considerables recursos (habilidad, tiempo, dinero y esfuerzo) y sin embargo eso no implica que se deje de pasar por alto ciertos errores al ejecutarlas. Pero las pruebas manuales también pueden ser beneficiosas: por ejemplo, un tester humano (por ejemplo, un auditor) puede usar la intuición para detectar casos límite que una herramienta de pruebas automatizadas pasaría por alto.

Las pruebas manuales de contratos inteligentes a menudo se realizan al final en el ciclo de desarrollo después de ejecutar pruebas automatizadas. Esta forma de prueba evalúa el contrato inteligente como un producto completamente integrado para ver si funciona según lo especificado en los requisitos técnicos.

Las pruebas manuales se hacen normalmente en blockchains locales o en redes de prueba.

Probar contratos en una blockchain local

Si bien las pruebas automatizadas realizadas en un entorno de desarrollo local pueden proporcionar información útil de depuración, siempre nos interesará saber cómo se comporta tu contrato inteligente en un entorno de producción. Sin embargo, implementar en mainnet de Ethereum conlleva tarifas de gas, sin mencionar que los activos que gestiona el contrato se pueden perder si el contrato inteligente aún tiene errores.

Probar tu contrato en una blockchain local es una alternativa recomendada a probar en mainnet. Una blockchain local es una copia de la blockchain de Ethereum que se ejecuta localmente en tu computadora y simula el comportamiento de la capa de ejecución de Ethereum. Como tal, puedes programar transacciones para interactuar con un contrato sin incurrir en costos significativos.

Probar contratos en redes de prueba

Una red de prueba o testnet funciona exactamente como la mainnet de Ethereum, excepto que usa Ether (ETH) sin valor en el mundo real. Implementar tu contrato en una testnet como Sepeoli significa que cualquiera puede interactuar con él (por ejemplo, a través del frontend de la dapp) sin poner en riesgo fondos.

Esta forma de prueba manual es útil para evaluar el flujo de extremo a extremo de tu aplicación desde el punto de vista del usuario. Aquí, los beta testers también pueden realizar pruebas y reportar cualquier problema con la lógica de negocio del contrato y la funcionalidad general.

Implementar en una testnet después de probar en una blockchain local es ideal, ya que la primera está más cerca del comportamiento de la EVM de Ethereum. Por lo tanto, es común que muchos proyectos nativos de Ethereum implementen dapps en testnets para evaluar la operación de contratos inteligentes bajo condiciones del mundo real.

PreviousPruebas automatizadasNextConceptos importantes en testing

Last updated 8 months ago

Was this helpful?