SlideShare ist ein Scribd-Unternehmen logo
1 von 47
Downloaden Sie, um offline zu lesen
Introducción a!
Testing
Testing
¿Para que sirve?
¿Para que sirve?
•

Verificar del funcionamiento de la aplicación!

•

Automatización!

•

Evitar recurrir en bugs!

•

Construir casos de uso difíciles de reproducir!

•

Simplificar la introducción de cambios!

•

Simplificar la refactorización!
¿Que vamos a ver?
•

Unit Testing!

•

Functional Testing
Unit Testing
Es una forma de probar el correcto funcionamiento de un módulo de
código. Esto sirve para asegurar que cada uno de los módulos funcione
correctamente por separado.

http://es.wikipedia.org/wiki/Prueba_unitaria
¿Ventajas?
•

Facilita el debug!

•

Demuestra el funcionamiento del código sin importar el entorno!

•

Viendo el test puedo determinar que hace el código!

•

Confirma si el pequeño cambio en realidad fue tan pequeño!

•

El código tiende a ser más limpio!

•

Nos permite corregir bugs y asegurarnos que no vuelven a aparecer!

•

Simplifica la integración
¿Desventajas?
•

No muestran errores de integración!

•

Es difícil anticipar todos los casos de uso y futuros bugs!

•

Código extenso
Herramientas
PHPUnit http://phpunit.de/!
SimpleTest http://simpletest.org/!
SnapTest https://github.com/Jakobo/snaptest
Herramientas
PHPUnit http://phpunit.de/!
SimpleTest http://simpletest.org/!
SnapTest https://github.com/Jakobo/snaptest
<?php!

!

namespace IsmaAmbrosi;!

!

class Math!
{!
    private $number;!

!

    public function __construct($number)!
    {!
        $this->number = $number;!
    }!

!

    public function getNumber()!
    {!
        return $this->number;!
    }!

!

    public function sum($number)!
    {!
        return $this->number += $number;!
    }!
}
<?php!

!

namespace 

!

class Math!
{!
    private 

!

    public function 
    {!
        $this
    }!

!

    public function 
    {!
        return 
    }!

!

    public function 
    {!
        return 
    }!
}

<?php!

!

namespace IsmaAmbrosiTests;!

!

use IsmaAmbrosiMath;!

!

/**!
 * Class MathTest!
 *!
 * @package IsmaAmbrosiTests!
 */!
class MathTest extends PHPUnit_Framework_TestCase!
{!
    public function testSumWorks()!
    {!
        $math = new Math(5);!

!

        $this->assertEquals(5, $math->getNumber());!

!

        $math->sum(2); # Sumo 2 al valor original!

!

        $this->assertEquals(7, $math->getNumber());!
    }!
}
<?php!

!

namespace 

!

class Math!
{!
    private 

!

    public function 
    {!
        $this
    }!

!

    public function 
    {!
        return 
    }!

!

    public function 
    {!
        return 
    }!
}

<?php!

!

namespace IsmaAmbrosiTests;!

!

use IsmaAmbrosiMath;!

!

/**!
 * Class MathTest!
 *!
 * @package IsmaAmbrosiTests!
 */!
class MathTest extends PHPUnit_Framework_TestCase!
{!
    public function testSumWorks()!
    {!
        $math = new Math(5);!

!

        $this->assertEquals(5, $math->getNumber());!

!

        $math->sum(2); # Sumo 2 al valor original!

!

        $this->assertEquals(7, $math->getNumber());!
    }!
}

Clase base para las
clases de tests
<?php!

!

namespace 

!

class Math!
{!
    private 

!

    public function 
    {!
        $this
    }!

!

    public function 
    {!
        return 
    }!

!

    public function 
    {!
        return 
    }!
}

<?php!

!

namespace IsmaAmbrosiTests;!

!

use IsmaAmbrosiMath;!

!

/**!
 * Class MathTest!
 *!
 * @package IsmaAmbrosiTests!
 */!
class MathTest extends PHPUnit_Framework_TestCase!
{!
    public function testSumWorks()!
    {!
        $math = new Math(5);!

!

        $this->assertEquals(5, $math->getNumber());!

!

        $math->sum(2); # Sumo 2 al valor original!

!

        $this->assertEquals(7, $math->getNumber());!
    }!
}

Verifica el valor de
getNumber() es el
original
<?php!

!

namespace 

!

class Math!
{!
    private 

!

    public function 
    {!
        $this
    }!

!

    public function 
    {!
        return 
    }!

!

    public function 
    {!
        return 
    }!
}

<?php!

!

namespace IsmaAmbrosiTests;!

!

use IsmaAmbrosiMath;!

!

/**!
 * Class MathTest!
 *!
 * @package IsmaAmbrosiTests!
 */!
class MathTest extends PHPUnit_Framework_TestCase!
{!
    public function testSumWorks()!
    {!
        $math = new Math(5);!

!

        $this->assertEquals(5, $math->getNumber());!

!

        $math->sum(2); # Sumo 2 al valor original!

!

        $this->assertEquals(7, $math->getNumber());!
    }!
}

Verifica que el valor
actual sea igual al
resultado de la suma
Métodos comunes
$this->assertEquals(2, 1 + 1);!
$this->assertTrue(2 == 2);!
$this->assertFalse(2 == 4);!
$this->assertNull(null);!
$this->assertInstanceOf('NamespaceClass', $instance);!
$this->assertEmpty("");!
$this->assertGreaterThan(2, 5);!
$this->assertLessThan(2, 1);!
$this->assertCount(3, array(1, 2, 3));!
$this->assertFileExists('/path/to/file.txt');
Nota: La falla en el assert finaliza la ejecución del método test.
Instalación
# 1 - Composer!
$ composer require —dev “phpunit/phpunit” “~3.7”

# 2 - Pear!
$ pear config-set auto_discover 1
$pear install pear.phpunit.de/PHPUnit

# 3 - PHP Archive (PHAR)!
$ wget https://phar.phpunit.de/phpunit.phar
Ejecución
$ phpunit

# Single test class!
$ phpunit tests/Namespace/ClassTest.php

# Proyecto de Symfony!
$ phpunit -c app
Test Driven Development
Es un proceso de desarrollo que se basa en la repetición de un corto ciclo
de desarrollo: Primero se desarrollan los test, definiendo como debe
funcionar la librería a desarrollar, luego se escribe la mínima cantidad de
código necesaria para que pasen los tests, y finalmente se hace la
refactorización del código a los estandares aceptables.

http://en.wikipedia.org/wiki/Test-driven_development
Escritura de test

Escritura del código necesario para pasar el test

Refactorización

Verificación de los tests
Code Coverage
IsmaAmbrosiGeneratorBundle
Code Coverage
IsmaAmbrosiGeneratorBundle
Mock Objects
Son objetos que imitan el comportamiento de objetos reales de una forma
controlada. Se usan para probar a otros objetos en pruebas unitarias que
esperan mensajes de una clase en particular para sus métodos, al igual
que los diseñadores de autos usan un crash dummy cuando simulan un
accidente.

http://es.wikipedia.org/wiki/Objeto_simulado
Herramientas
PHPUnit Mock Objects http://phpunit.de/ !
Mockery https://github.com/padraic/mockery!
Prophecy https://github.com/phpspec/prophecy
<?php!

<?php!

namespace IsmaAmbrosiLogger;!

namespace IsmaAmbrosiLogger;!

/**!
 * Class Logger!
 *!
 * @package IsmaAmbrosiLogger!
 */!
class Logger!
{!
    private $handler;!

/**!
 * Interface HandlerInterface!
 *!
 * @package IsmaAmbrosiLogger!
 */!
interface HandlerInterface!
{!
    public function write($log);!
}

!
!

!

    public function __construct(HandlerInterface $handler)!
    {!
        $this->handler = $handler;!
    }!

!

    public function log($text)!
    {!
        return $this->handler->write($text);!
    }!
}

!
!
<?php!

!

namespace 

!

<?php!

!

namespace IsmaAmbrosiTestsLogger;!

!

<?php!

!

namespace 

!

/**!
/**!
use IsmaAmbrosiLoggerLogger;!
 * Class Logger!
 * Interface HandlerInterface!
!
 *!
 *!
/**!
 * @package IsmaAmbrosiLogger!
 * @package IsmaAmbrosiLogger!
 * Class LoggerTest!
 */!
 */!
 *!
class Logger!
interface 
 * @package IsmaAmbrosiTestsLogger!
{!
{!
 */!
    private 
    public function 
class LoggerTest extends PHPUnit_Framework_TestCase!
!
}
{!
    public function 
    public function testLogger()!
    {!
    {!
        
        $handler = $this->getMock('IsmaAmbrosiLoggerHandlerInterface');!
    }!

!

!

        $logger = new Logger($handler);!
    public function 
!
    {!
        $logger->log('Este es un mensaje de log');!
        return
    }!
    }!
}
}
Ejemplo
!
# src/IsmaAmbrosi/Logger/Logger.php!
public function log($text)!
{!
    return $this->handler->write($text);!
}!

!
!

# src/IsmaAmbrosi/Tests/Logger/LoggerTest.php!
public function testLogger()!
{!
    $handler = $this->getMock('IsmaAmbrosiLoggerHandlerInterface');!
    $handler!
        ->expects($this->any())!
        ->method('write')!
        ->will($this->returnValue(7));!

!

    $logger = new Logger($handler);!

!

    $this->assertEquals(7, $logger->log('Message'));!
}
Functional Testing
Una prueba funcional es una prueba basada en la ejecución, revisión y
retroalimentación de las funcionalidades previamente diseñadas para el
software. Son pruebas específicas, concretas y exhaustivas para probar y
validar que el software hace lo que debe y sobre todo, lo que se ha
especificado.

http://es.wikipedia.org/wiki/Pruebas_funcionales
¿Ventajas?
•

Se escriben una sola vez!

•

Ofrecen mayor cobertura de casos de uso!

•

Puedo ver como se comporta mi aplicación y para casos específicos!

•

Sirven como test de integración en algunos casos!

•

Confirma si los pequeños cambios en realidad fue tan pequeños
¿Desventajas?
•

Es difícil descubrir todos los errores del código!

•

No siempre puedo determinar que hace el código!

•

Es difícil anticipar todos los casos de uso y futuros bugs
Ejemplo (Symfony)
<?php!

!

namespace IsmaAmbrosiMyBundleTestsController;!

!

use SymfonyBundleFrameworkBundleTestWebTestCase;!

!

class DefaultControllerTest extends WebTestCase!
{!
    public function testIndex()!
    {!
        $client = static::createClient();!

!

        $crawler = $client->request('GET', '/');!

!

        $this->assertEquals(1, $crawler->filter('h1:contains("Welcome")')->count());!
    }!
}
Pruebas de Integración

Son aquellas que se realizan en el ámbito del desarrollo de software una
vez que se han aprobado las pruebas unitarias. Únicamente se refieren a la
prueba o pruebas de todos los elementos unitarios que componen un
proceso, hecha en conjunto, de una sola vez.

http://es.wikipedia.org/wiki/Pruebas_de_integración
Behavior Driven Development
Es una técnica de desarrollo ágil de software que nos permite crear una
aplicación describiendo su funcionamiento desde la perspectiva de los
inversores.

http://www.ticketea.com/introduccion-bdd-granada
Herramientas

•

Behat http://behat.org!

•

PHPUnit http://phpunit.de/
Behat

Un framework PHP para testing de las expectativas de negocios.
Behat
Se escriben historias en lenguaje entendible para cualquier
humano(Gherkin).!
Esas historias luego se comprueban con el funcionamiento de la aplicación.!
Se separan en features.!
Cada feature desarrolla uno o más escenarios.
Feature
Feature: ls!
In order to see the directory structure!
As a UNIX user!
I need to be able to list the current directory's contents!
!
Scenario: List 2 files in a directory!
Given I am in a directory "test"!
And I have a file named "foo"!
And I have a file named "bar"!
When I run "ls"!
Then I should get:!
"""!
bar!
foo!
"""
http://docs.behat.org/quick_intro.html
Feature para Web
Feature: Login!
Para poder acceder al sistema!
Como un usuario registrado!
Necesito poder identificarme con un usuario y contraseña!
!

Scenario: Ingreso al sistema con usuario válido!
Given I am on “/login”!
When I fill in “username” with “iambrosi”!
And I fill in “password” with “12345”!
And I press “Ingresar”!
Then I should see “Bienvenido Ismael”
Para los tests de funcionalidades web se debe utilizar la extensión Mink
y uno de los drivers para navegadores.

http://mink.behat.org/
Para los tests de funcionalidades web se debe utilizar la extensión Mink
y uno de los drivers para navegadores.

Goutte

Sahi

Zombie

Selenium

Selenium2

http://mink.behat.org/
Resumen
Resumen
•

Utilizamos Unit Testing para probar pequeños módulos
Resumen
•

Utilizamos Unit Testing para probar pequeños módulos!

•

Utilizamos Integration Testing para probar la union de varios módulos
Resumen
•

Utilizamos Unit Testing para probar pequeños módulos!

•

Utilizamos Integration Testing para probar la union de varios módulos !

•

Utilizamos Fuctional Testing para probar el resultado de la ejecución
Resumen
•

Utilizamos Unit Testing para probar pequeños módulos!

•

Utilizamos Integration Testing para probar la union de varios módulos!

•

Utilizamos Fuctional Testing para probar el resultado de la ejecución!

•

Utilizamos BDD(Behat) para desarrollar los test tal cual es visto en el
negocio
¿Preguntas?
¡Gracias!

Weitere ähnliche Inhalte

Ähnlich wie Introducción a testing en php

Probando aplicaciones AngularJS
Probando aplicaciones AngularJSProbando aplicaciones AngularJS
Probando aplicaciones AngularJSRodrigo Pimentel
 
Integracion Continua
Integracion ContinuaIntegracion Continua
Integracion ContinuaLenin Lozano
 
Pruebas unitarias 7mo -b
Pruebas unitarias   7mo -bPruebas unitarias   7mo -b
Pruebas unitarias 7mo -bJairoSimbaa
 
pruebasunitarias-110921232512-phpapp02.pptx
pruebasunitarias-110921232512-phpapp02.pptxpruebasunitarias-110921232512-phpapp02.pptx
pruebasunitarias-110921232512-phpapp02.pptxCompusoftnetCiaLtda
 
¿Cómo poner software de calidad en manos del usuario de forma rápida?
¿Cómo poner software de calidad en manos del usuario de forma rápida?¿Cómo poner software de calidad en manos del usuario de forma rápida?
¿Cómo poner software de calidad en manos del usuario de forma rápida?Micael Gallego
 
Cypress en un mundo lleno de Selenium
Cypress en un mundo lleno de SeleniumCypress en un mundo lleno de Selenium
Cypress en un mundo lleno de SeleniumSoftware Guru
 
Herramientas Ágiles para Desarrollo
Herramientas Ágiles para DesarrolloHerramientas Ágiles para Desarrollo
Herramientas Ágiles para DesarrolloGastón Guillerón
 
Herramientas agilesdesarrollo
Herramientas agilesdesarrolloHerramientas agilesdesarrollo
Herramientas agilesdesarrollogabrielpiccoli
 
Automatización de pruebas funcionales
Automatización de pruebas funcionalesAutomatización de pruebas funcionales
Automatización de pruebas funcionalesVicenç García-Altés
 

Ähnlich wie Introducción a testing en php (20)

Practicas tecnicas
Practicas tecnicasPracticas tecnicas
Practicas tecnicas
 
Probando aplicaciones AngularJS
Probando aplicaciones AngularJSProbando aplicaciones AngularJS
Probando aplicaciones AngularJS
 
Pruebas unitarias
Pruebas unitariasPruebas unitarias
Pruebas unitarias
 
Practicas técnicas
Practicas técnicasPracticas técnicas
Practicas técnicas
 
Prueba unitaria
Prueba unitariaPrueba unitaria
Prueba unitaria
 
Integracion Continua
Integracion ContinuaIntegracion Continua
Integracion Continua
 
Pruebas automaticas
Pruebas automaticasPruebas automaticas
Pruebas automaticas
 
Pruebas unitarias 7mo -b
Pruebas unitarias   7mo -bPruebas unitarias   7mo -b
Pruebas unitarias 7mo -b
 
pruebasunitarias-110921232512-phpapp02.pptx
pruebasunitarias-110921232512-phpapp02.pptxpruebasunitarias-110921232512-phpapp02.pptx
pruebasunitarias-110921232512-phpapp02.pptx
 
¿Cómo poner software de calidad en manos del usuario de forma rápida?
¿Cómo poner software de calidad en manos del usuario de forma rápida?¿Cómo poner software de calidad en manos del usuario de forma rápida?
¿Cómo poner software de calidad en manos del usuario de forma rápida?
 
ASP.NET MVC Workshop Día 2
ASP.NET MVC Workshop Día 2ASP.NET MVC Workshop Día 2
ASP.NET MVC Workshop Día 2
 
Automatizacion de Pruebas
Automatizacion de PruebasAutomatizacion de Pruebas
Automatizacion de Pruebas
 
Cypress en un mundo lleno de Selenium
Cypress en un mundo lleno de SeleniumCypress en un mundo lleno de Selenium
Cypress en un mundo lleno de Selenium
 
Herramientas Ágiles para Desarrollo
Herramientas Ágiles para DesarrolloHerramientas Ágiles para Desarrollo
Herramientas Ágiles para Desarrollo
 
Herramientas agilesdesarrollo
Herramientas agilesdesarrolloHerramientas agilesdesarrollo
Herramientas agilesdesarrollo
 
Automatización de pruebas funcionales
Automatización de pruebas funcionalesAutomatización de pruebas funcionales
Automatización de pruebas funcionales
 
El coste de no usar integración continua
El coste de no usar integración continuaEl coste de no usar integración continua
El coste de no usar integración continua
 
Pruebas automaticas
Pruebas automaticasPruebas automaticas
Pruebas automaticas
 
Unit testing consejos
Unit testing   consejosUnit testing   consejos
Unit testing consejos
 
Integracion continua
Integracion continuaIntegracion continua
Integracion continua
 

Mehr von Ismael Ambrosi

Mehr von Ismael Ambrosi (6)

Assetic PHPmvd
Assetic PHPmvdAssetic PHPmvd
Assetic PHPmvd
 
Symfony forms
Symfony formsSymfony forms
Symfony forms
 
Doctrine
DoctrineDoctrine
Doctrine
 
Empezando con Twig
Empezando con TwigEmpezando con Twig
Empezando con Twig
 
Introducción a composer
Introducción a composerIntroducción a composer
Introducción a composer
 
Introducción a Symfony
Introducción a SymfonyIntroducción a Symfony
Introducción a Symfony
 

Kürzlich hochgeladen

guía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Josephguía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan JosephBRAYANJOSEPHPEREZGOM
 
Desarrollo Web Moderno con Svelte 2024.pdf
Desarrollo Web Moderno con Svelte 2024.pdfDesarrollo Web Moderno con Svelte 2024.pdf
Desarrollo Web Moderno con Svelte 2024.pdfJulian Lamprea
 
Proyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptxProyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptx241521559
 
Trabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíaTrabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíassuserf18419
 
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE  DE TECNOLOGIA E INFORMATICA PRIMARIACLASE  DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIAWilbisVega
 
EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveFagnerLisboa3
 
9egb-lengua y Literatura.pdf_texto del estudiante
9egb-lengua y Literatura.pdf_texto del estudiante9egb-lengua y Literatura.pdf_texto del estudiante
9egb-lengua y Literatura.pdf_texto del estudianteAndreaHuertas24
 
International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)GDGSucre
 
Redes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfRedes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfsoporteupcology
 
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...silviayucra2
 
pruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNITpruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNITMaricarmen Sánchez Ruiz
 
Presentación guía sencilla en Microsoft Excel.pptx
Presentación guía sencilla en Microsoft Excel.pptxPresentación guía sencilla en Microsoft Excel.pptx
Presentación guía sencilla en Microsoft Excel.pptxLolaBunny11
 
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricGlobal Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricKeyla Dolores Méndez
 

Kürzlich hochgeladen (13)

guía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Josephguía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Joseph
 
Desarrollo Web Moderno con Svelte 2024.pdf
Desarrollo Web Moderno con Svelte 2024.pdfDesarrollo Web Moderno con Svelte 2024.pdf
Desarrollo Web Moderno con Svelte 2024.pdf
 
Proyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptxProyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptx
 
Trabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíaTrabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnología
 
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE  DE TECNOLOGIA E INFORMATICA PRIMARIACLASE  DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
 
EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial Uninove
 
9egb-lengua y Literatura.pdf_texto del estudiante
9egb-lengua y Literatura.pdf_texto del estudiante9egb-lengua y Literatura.pdf_texto del estudiante
9egb-lengua y Literatura.pdf_texto del estudiante
 
International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)
 
Redes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfRedes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdf
 
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
 
pruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNITpruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNIT
 
Presentación guía sencilla en Microsoft Excel.pptx
Presentación guía sencilla en Microsoft Excel.pptxPresentación guía sencilla en Microsoft Excel.pptx
Presentación guía sencilla en Microsoft Excel.pptx
 
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricGlobal Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
 

Introducción a testing en php