SlideShare a Scribd company logo
TESTING
ANGULAR JS
Juan José Galán López
Acerca de
Desarrollador Web Full Stack
Symfony, Drupal, Magento
LESS, SASS, AngularJS, JavaScript
Indice
Herramientas testing
Instalación/Configuración Karma
Test unitarios - Jasmine
ngMock
Test unitarios AngularJS
Arquitectura aplicación Demo
Testing sobre Servicios, Controlador, Directiva
Herramientas testing
Karma - Test runner
Protractor - Testing framework
Nos permite correr un comando que determina si un conjunto de test pasan o no.
Permite automatizar los test funcionales a través de la interacción con el navegador.
Herramientas testing
Jasmine - Testing framework
Alternativas a Jasmine
Integración por defecto con Karma
Herramientas como: spies, fakes…
Sintaxis limpia, test con formato que describen la conducta que estamos testeando
Selenium, Mocha
Instalación Karma
* npm init
npm install karma -g
karma init
Necesitaremos instalar Jasmine y el lanzador de Chrome
npm install jasmine-core -g
npm install karma-jasmine -g
npm install karma-chrome-launcher -g
karma start
Comprobamos la instalación: karma --version
Configuración Karma
karma.conf.js
Test unitarios - Jasmine
describe
it
expect
matchers
describe("A suite is just a function", function() {
var a;
it("and so is a spec", function() {
a = true;
expect(a).toBe(true);
});
});
https://www.cheatography.com/citguy/cheat-sheets/jasmine-js-testing/
Test unitarios - Jasmine
beforeEach
Es llamado antes de ejecutar el test del bloque
describe en el que se encuentra.
afterEach
Es llamado después de ejecutar el test del bloque
describe en el que se encuentra.
describe("A spec (with setup and tear-down)", function() {
var foo;
beforeEach(function() {
foo = 0;
foo += 1;
});
afterEach(function() {
foo = 0;
});
it("is just a function, so it can contain any code", function() {
expect(foo).toEqual(1);
});
it("can have more than one expectation", function() {
expect(foo).toEqual(1);
expect(true).toEqual(true);
});
});
Test unitarios - Jasmine
Spies
describe("A spy", function() {
var foo, bar = null;
beforeEach(function() {
foo = {
setBar: function(value) {
bar = value;
}
};
spyOn(foo, 'setBar');
foo.setBar(456, 'another param');
});
it("tracks that the spy was called", function() {
expect(foo.setBar).toHaveBeenCalled();
});
it("tracks that the spy was called x times", function() {
expect(foo.setBar).toHaveBeenCalledTimes(2);
});
it("tracks all the arguments of its calls", function() {
expect(foo.setBar).toHaveBeenCalledWith(456, 'another param');
});
});
Algunos matchers para los Spies:
toHaveBeenCalled
toHaveBeenCalledTimes
toHaveBeenCalledWith
Test unitarios - Jasmine
Spies describe("A spy, when configured with an alternate implementation", function() {
var foo, fetchedBar;
beforeEach(function() {
spyOn(foo, "getBar").and.callFake(function(arguments, can, be, received) {
return 1001;
});
});
fetchedBar = foo.getBar();
it("tracks that the spy was called", function() {
expect(foo.getBar).toHaveBeenCalled();
});
it("when called returns the requested value", function() {
expect(fetchedBar).toEqual(1001);
});
});
Encadenando and.callFake.
Test unitarios - Jasmine
Existen otros muchos elementos en Jasmine que podéis consultar en:
https://jasmine.github.io/pages/docs_home.html
Test unitarios - ngMock
Elementos de test necesarios para testear apps Angular JS
$httpBackend
Inject
$controller
$compile
...
Test unitarios AngularJS
Elementos bajo test:
● Servicios
● Controllers
● Directiva
● Eventos
Aplicación demo - Arquitectura
bt-setup-table
Proxies
Services
Controllers
Directives
Transformers
Controllers
Templates
App
Aplicación demo - Arquitectura
Estructura directorio para los tests
Aplicación demo - Arquitectura
bt-setup-controller
bt-setup
SELECT_SHIP
Test Unitario Angular
1. Describimos la suite de test
describe('Setup Table Service test', function () {
1. Cargamos el módulo que contiene el código a ejecutar
beforeEach(module('battleShip'));
1. Definimos cada spec o test
Pasos comunes:
$httpBackend
Test Unitario Angular - SetupTableProxy
SetupTableProxy$http
[[0, 0], [0, 0]]
fakeSetupTableProxy
Test Unitario Angular - SetupTableGetService
SetupTableProxy SetupTableGetService
[[0, 0], [0, 0]]
Test Unitario Angular - SetupTableTransformer
SetupTableTransformer[[0, 0], [0, 0]] [[ { value: 0, class: 'water'}, { value: 0, class: 'water'}],
[ { value: 0, class: 'water'}, { value: 0, class: 'water'}]]
fakeSetupTableTransformerfakeSetupTableGetService
Test Unitario Angular - SetupTableService
SetupTableGetService
[[0, 0], [0, 0]]
[[ { value: 0, class: 'water'}, { value: 0, class: 'water'}],
[ { value: 0, class: 'water'}, { value: 0, class: 'water'}]]
SetupTableGetService SetupTableTransformer
[[0, 0], [0, 0]]
Test Unitario Angular - SetupTableCheckService
SetupTableCheckService
[[ { value: 0, class: 'water'}, { value: 0, class: 'water'}],
[ { value: 0, class: 'water'}, { value: 0, class: 'water'}]]
x y length isVertical
true/false
Test Unitario Angular - Controllers
SetupControllerDirective SetupController
SELECT_SHIP
checkSetupShip
resetCellClass
Test Unitario Angular - Directive
Template
https://github.com/karma-runner/karma-ng-html2js-preprocessor
npm install karma-ng-html2js-preprocessor --save-dev module.exports = function(config) {
config.set({
preprocessors: {
'**/*.html': ['ng-html2js']
},
...
ngHtml2JsPreprocessor: {
moduleName: 'templates'
},
….
files: [
...
'**/*.html'
],
Test Unitario Angular - Directive
setupTableDirective
● Comprobación de creación de tablero
● Conducta tras pasar por las celdas mouseenter/mouseleave
Referencias
https://jasmine.github.io/2.5/introduction
AngularJS By Example - Packt Publishing
https://github.com/atomicposts/battleship
Ad

Recommended

Unit testing in JavaScript with Jasmine and Karma
Unit testing in JavaScript with Jasmine and Karma
Andrey Kolodnitsky
 
Intro to testing Javascript with jasmine
Intro to testing Javascript with jasmine
Timothy Oxley
 
Karma - JS Test Runner
Karma - JS Test Runner
Sebastiano Armeli
 
AngularJS Unit Testing
AngularJS Unit Testing
Prince Norin
 
Basics of Akka
Basics of Akka
佑介 九岡
 
JavaScript TDD with Jasmine and Karma
JavaScript TDD with Jasmine and Karma
Christopher Bartling
 
How Danga::Socket handles asynchronous processing and how to write asynchrono...
How Danga::Socket handles asynchronous processing and how to write asynchrono...
Gosuke Miyashita
 
Ember testing internals with ember cli
Ember testing internals with ember cli
Cory Forsyth
 
Assurer - a pluggable server testing/monitoring framework
Assurer - a pluggable server testing/monitoring framework
Gosuke Miyashita
 
Test like a pro with Ember.js
Test like a pro with Ember.js
Mike North
 
Perlbal Tutorial
Perlbal Tutorial
Takatsugu Shigeta
 
Testing JS with Jasmine
Testing JS with Jasmine
Evgeny Gurin
 
Spring data jpa simple example_스프링학원/자바학원추천/구로IT학원/자바학원
Spring data jpa simple example_스프링학원/자바학원추천/구로IT학원/자바학원
탑크리에듀(구로디지털단지역3번출구 2분거리)
 
JavaFX – 10 things I love about you
JavaFX – 10 things I love about you
Alexander Casall
 
BDD with Behat and Symfony2
BDD with Behat and Symfony2
katalisha
 
Django Celery - A distributed task queue
Django Celery - A distributed task queue
Alex Eftimie
 
The JavaFX Ecosystem
The JavaFX Ecosystem
Andres Almiray
 
Vuejs testing
Vuejs testing
Greg TAPPERO
 
From Swing to JavaFX
From Swing to JavaFX
Yuichi Sakuraba
 
Why You Should Use TAPIs
Why You Should Use TAPIs
Jeffrey Kemp
 
GraphQL gifts from Kiwi.com
GraphQL gifts from Kiwi.com
Michal Sänger
 
Bareon functional testing ci
Bareon functional testing ci
Max Lobur
 
Rare frontend testing
Rare frontend testing
Андрей Вандакуров
 
The JavaFX Ecosystem
The JavaFX Ecosystem
Andres Almiray
 
Unit Testing and Coverage for AngularJS
Unit Testing and Coverage for AngularJS
Knoldus Inc.
 
Laravel 5.5 dev
Laravel 5.5 dev
RocketRoute
 
ZLM-Cython Build you first module
ZLM-Cython Build you first module
Vladimir Ulogov
 
Testing Ansible
Testing Ansible
Anth Courtney
 
Yeoman
Yeoman
James Cryer
 
EasyTest Test Automation Tool Introduction
EasyTest Test Automation Tool Introduction
Zhu Zhong
 

More Related Content

What's hot (20)

Assurer - a pluggable server testing/monitoring framework
Assurer - a pluggable server testing/monitoring framework
Gosuke Miyashita
 
Test like a pro with Ember.js
Test like a pro with Ember.js
Mike North
 
Perlbal Tutorial
Perlbal Tutorial
Takatsugu Shigeta
 
Testing JS with Jasmine
Testing JS with Jasmine
Evgeny Gurin
 
Spring data jpa simple example_스프링학원/자바학원추천/구로IT학원/자바학원
Spring data jpa simple example_스프링학원/자바학원추천/구로IT학원/자바학원
탑크리에듀(구로디지털단지역3번출구 2분거리)
 
JavaFX – 10 things I love about you
JavaFX – 10 things I love about you
Alexander Casall
 
BDD with Behat and Symfony2
BDD with Behat and Symfony2
katalisha
 
Django Celery - A distributed task queue
Django Celery - A distributed task queue
Alex Eftimie
 
The JavaFX Ecosystem
The JavaFX Ecosystem
Andres Almiray
 
Vuejs testing
Vuejs testing
Greg TAPPERO
 
From Swing to JavaFX
From Swing to JavaFX
Yuichi Sakuraba
 
Why You Should Use TAPIs
Why You Should Use TAPIs
Jeffrey Kemp
 
GraphQL gifts from Kiwi.com
GraphQL gifts from Kiwi.com
Michal Sänger
 
Bareon functional testing ci
Bareon functional testing ci
Max Lobur
 
Rare frontend testing
Rare frontend testing
Андрей Вандакуров
 
The JavaFX Ecosystem
The JavaFX Ecosystem
Andres Almiray
 
Unit Testing and Coverage for AngularJS
Unit Testing and Coverage for AngularJS
Knoldus Inc.
 
Laravel 5.5 dev
Laravel 5.5 dev
RocketRoute
 
ZLM-Cython Build you first module
ZLM-Cython Build you first module
Vladimir Ulogov
 
Testing Ansible
Testing Ansible
Anth Courtney
 
Assurer - a pluggable server testing/monitoring framework
Assurer - a pluggable server testing/monitoring framework
Gosuke Miyashita
 
Test like a pro with Ember.js
Test like a pro with Ember.js
Mike North
 
Testing JS with Jasmine
Testing JS with Jasmine
Evgeny Gurin
 
JavaFX – 10 things I love about you
JavaFX – 10 things I love about you
Alexander Casall
 
BDD with Behat and Symfony2
BDD with Behat and Symfony2
katalisha
 
Django Celery - A distributed task queue
Django Celery - A distributed task queue
Alex Eftimie
 
Why You Should Use TAPIs
Why You Should Use TAPIs
Jeffrey Kemp
 
GraphQL gifts from Kiwi.com
GraphQL gifts from Kiwi.com
Michal Sänger
 
Bareon functional testing ci
Bareon functional testing ci
Max Lobur
 
Unit Testing and Coverage for AngularJS
Unit Testing and Coverage for AngularJS
Knoldus Inc.
 
ZLM-Cython Build you first module
ZLM-Cython Build you first module
Vladimir Ulogov
 

Viewers also liked (18)

Yeoman
Yeoman
James Cryer
 
EasyTest Test Automation Tool Introduction
EasyTest Test Automation Tool Introduction
Zhu Zhong
 
AngularJS Testing Strategies
AngularJS Testing Strategies
njpst8
 
Slaven tomac unit testing in angular js
Slaven tomac unit testing in angular js
Slaven Tomac
 
Test-Driven Development with TypeScript+Jasmine+AngularJS
Test-Driven Development with TypeScript+Jasmine+AngularJS
SmartOrg
 
AngularJS Testing
AngularJS Testing
Ahmed Elmehri
 
TDD, unit testing and java script testing frameworks workshop
TDD, unit testing and java script testing frameworks workshop
Sikandar Ahmed
 
Test-Driven Development of AngularJS Applications
Test-Driven Development of AngularJS Applications
FITC
 
Angular testing
Angular testing
Raissa Ferreira
 
Angular 2 - What's new and what's different
Angular 2 - What's new and what's different
Priscila Negreiros
 
AngularJS Unit Test
AngularJS Unit Test
Chiew Carol
 
Unit testing JavaScript: Jasmine & karma intro
Unit testing JavaScript: Jasmine & karma intro
Maurice De Beijer [MVP]
 
TDD Basics with Angular.js and Jasmine
TDD Basics with Angular.js and Jasmine
Luis Sánchez Castellanos
 
Angularjs - Unit testing introduction
Angularjs - Unit testing introduction
Nir Kaufman
 
Automated Testing With Jasmine, PhantomJS and Jenkins
Automated Testing With Jasmine, PhantomJS and Jenkins
Work at Play
 
Javascript Tests with Jasmine for Front-end Devs
Javascript Tests with Jasmine for Front-end Devs
Chris Powers
 
Jasmine
Jasmine
Chris Powers
 
AngularJS Unit Testing w/Karma and Jasmine
AngularJS Unit Testing w/Karma and Jasmine
foxp2code
 
EasyTest Test Automation Tool Introduction
EasyTest Test Automation Tool Introduction
Zhu Zhong
 
AngularJS Testing Strategies
AngularJS Testing Strategies
njpst8
 
Slaven tomac unit testing in angular js
Slaven tomac unit testing in angular js
Slaven Tomac
 
Test-Driven Development with TypeScript+Jasmine+AngularJS
Test-Driven Development with TypeScript+Jasmine+AngularJS
SmartOrg
 
TDD, unit testing and java script testing frameworks workshop
TDD, unit testing and java script testing frameworks workshop
Sikandar Ahmed
 
Test-Driven Development of AngularJS Applications
Test-Driven Development of AngularJS Applications
FITC
 
Angular 2 - What's new and what's different
Angular 2 - What's new and what's different
Priscila Negreiros
 
AngularJS Unit Test
AngularJS Unit Test
Chiew Carol
 
Unit testing JavaScript: Jasmine & karma intro
Unit testing JavaScript: Jasmine & karma intro
Maurice De Beijer [MVP]
 
Angularjs - Unit testing introduction
Angularjs - Unit testing introduction
Nir Kaufman
 
Automated Testing With Jasmine, PhantomJS and Jenkins
Automated Testing With Jasmine, PhantomJS and Jenkins
Work at Play
 
Javascript Tests with Jasmine for Front-end Devs
Javascript Tests with Jasmine for Front-end Devs
Chris Powers
 
AngularJS Unit Testing w/Karma and Jasmine
AngularJS Unit Testing w/Karma and Jasmine
foxp2code
 
Ad

Similar to Testing angular js (20)

Unit Testing in AngularJS - CC FE & UX
Unit Testing in AngularJS - CC FE & UX
JWORKS powered by Ordina
 
Protractor framework architecture with example
Protractor framework architecture with example
shadabgilani
 
Quick tour to front end unit testing using jasmine
Quick tour to front end unit testing using jasmine
Gil Fink
 
Javascript tdd byandreapaciolla
Javascript tdd byandreapaciolla
Andrea Paciolla
 
20160905 - BrisJS - nightwatch testing
20160905 - BrisJS - nightwatch testing
Vladimir Roudakov
 
Javascript testing: tools of the trade
Javascript testing: tools of the trade
Juanma Orta
 
JavaCro'14 - Unit testing in AngularJS – Slaven Tomac
JavaCro'14 - Unit testing in AngularJS – Slaven Tomac
HUJAK - Hrvatska udruga Java korisnika / Croatian Java User Association
 
Automated javascript unit testing
Automated javascript unit testing
ryan_chambers
 
Selenium with java
Selenium with java
Gousalya Ramachandran
 
An Introduction to AngularJs Unittesting
An Introduction to AngularJs Unittesting
Inthra onsap
 
Unit Testing with Jest
Unit Testing with Jest
Maayan Glikser
 
Quick tour to front end unit testing using jasmine
Quick tour to front end unit testing using jasmine
Gil Fink
 
Angular JS Unit Testing - Overview
Angular JS Unit Testing - Overview
Thirumal Sakthivel
 
Full Stack Unit Testing
Full Stack Unit Testing
GlobalLogic Ukraine
 
Europython 2011 - Playing tasks with Django & Celery
Europython 2011 - Playing tasks with Django & Celery
Mauro Rocco
 
Test Driven Development for Microservices
Test Driven Development for Microservices
Ballerina
 
Testing in Ballerina Language
Testing in Ballerina Language
Lynn Langit
 
Angular Unit Testing
Angular Unit Testing
Alessandro Giorgetti
 
Painless Javascript Unit Testing
Painless Javascript Unit Testing
Benjamin Wilson
 
Nashville Symfony Functional Testing
Nashville Symfony Functional Testing
Brent Shaffer
 
Protractor framework architecture with example
Protractor framework architecture with example
shadabgilani
 
Quick tour to front end unit testing using jasmine
Quick tour to front end unit testing using jasmine
Gil Fink
 
Javascript tdd byandreapaciolla
Javascript tdd byandreapaciolla
Andrea Paciolla
 
20160905 - BrisJS - nightwatch testing
20160905 - BrisJS - nightwatch testing
Vladimir Roudakov
 
Javascript testing: tools of the trade
Javascript testing: tools of the trade
Juanma Orta
 
Automated javascript unit testing
Automated javascript unit testing
ryan_chambers
 
An Introduction to AngularJs Unittesting
An Introduction to AngularJs Unittesting
Inthra onsap
 
Unit Testing with Jest
Unit Testing with Jest
Maayan Glikser
 
Quick tour to front end unit testing using jasmine
Quick tour to front end unit testing using jasmine
Gil Fink
 
Angular JS Unit Testing - Overview
Angular JS Unit Testing - Overview
Thirumal Sakthivel
 
Europython 2011 - Playing tasks with Django & Celery
Europython 2011 - Playing tasks with Django & Celery
Mauro Rocco
 
Test Driven Development for Microservices
Test Driven Development for Microservices
Ballerina
 
Testing in Ballerina Language
Testing in Ballerina Language
Lynn Langit
 
Painless Javascript Unit Testing
Painless Javascript Unit Testing
Benjamin Wilson
 
Nashville Symfony Functional Testing
Nashville Symfony Functional Testing
Brent Shaffer
 
Ad

Recently uploaded (20)

Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
WSO2
 
Advance Doctor Appointment Booking App With Online Payment
Advance Doctor Appointment Booking App With Online Payment
AxisTechnolabs
 
ERP Systems in the UAE: Driving Business Transformation with Smart Solutions
ERP Systems in the UAE: Driving Business Transformation with Smart Solutions
dheeodoo
 
IDM Crack with Internet Download Manager 6.42 Build 41 [Latest 2025]
IDM Crack with Internet Download Manager 6.42 Build 41 [Latest 2025]
pcprocore
 
Humans vs AI Call Agents - Qcall.ai's Special Report
Humans vs AI Call Agents - Qcall.ai's Special Report
Udit Goenka
 
Heat Treatment Process Automation in India
Heat Treatment Process Automation in India
Reckers Mechatronics
 
arctitecture application system design os dsa
arctitecture application system design os dsa
za241967
 
Threat Modeling a Batch Job Framework - Teri Radichel - AWS re:Inforce 2025
Threat Modeling a Batch Job Framework - Teri Radichel - AWS re:Inforce 2025
2nd Sight Lab
 
Canva Pro Crack Free Download 2025-FREE LATEST
Canva Pro Crack Free Download 2025-FREE LATEST
grete1122g
 
Why Edge Computing Matters in Mobile Application Tech.pdf
Why Edge Computing Matters in Mobile Application Tech.pdf
IMG Global Infotech
 
OpenChain Webinar - AboutCode - Practical Compliance in One Stack – Licensing...
OpenChain Webinar - AboutCode - Practical Compliance in One Stack – Licensing...
Shane Coughlan
 
Building Geospatial Data Warehouse for GIS by GIS with FME
Building Geospatial Data Warehouse for GIS by GIS with FME
Safe Software
 
CodeCleaner: Mitigating Data Contamination for LLM Benchmarking
CodeCleaner: Mitigating Data Contamination for LLM Benchmarking
arabelatso
 
Foundations of Marketo Engage - Programs, Campaigns & Beyond - June 2025
Foundations of Marketo Engage - Programs, Campaigns & Beyond - June 2025
BradBedford3
 
Best AI-Powered Wearable Tech for Remote Health Monitoring in 2025
Best AI-Powered Wearable Tech for Remote Health Monitoring in 2025
SEOLIFT - SEO Company London
 
Complete WordPress Programming Guidance Book
Complete WordPress Programming Guidance Book
Shabista Imam
 
Microsoft-365-Administrator-s-Guide1.pdf
Microsoft-365-Administrator-s-Guide1.pdf
mazharatknl
 
Best Practice for LLM Serving in the Cloud
Best Practice for LLM Serving in the Cloud
Alluxio, Inc.
 
Introduction to Agile Frameworks for Product Managers.pdf
Introduction to Agile Frameworks for Product Managers.pdf
Ali Vahed
 
Zoho Creator Solution for EI by Elsner Technologies.docx
Zoho Creator Solution for EI by Elsner Technologies.docx
Elsner Technologies Pvt. Ltd.
 
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
WSO2
 
Advance Doctor Appointment Booking App With Online Payment
Advance Doctor Appointment Booking App With Online Payment
AxisTechnolabs
 
ERP Systems in the UAE: Driving Business Transformation with Smart Solutions
ERP Systems in the UAE: Driving Business Transformation with Smart Solutions
dheeodoo
 
IDM Crack with Internet Download Manager 6.42 Build 41 [Latest 2025]
IDM Crack with Internet Download Manager 6.42 Build 41 [Latest 2025]
pcprocore
 
Humans vs AI Call Agents - Qcall.ai's Special Report
Humans vs AI Call Agents - Qcall.ai's Special Report
Udit Goenka
 
Heat Treatment Process Automation in India
Heat Treatment Process Automation in India
Reckers Mechatronics
 
arctitecture application system design os dsa
arctitecture application system design os dsa
za241967
 
Threat Modeling a Batch Job Framework - Teri Radichel - AWS re:Inforce 2025
Threat Modeling a Batch Job Framework - Teri Radichel - AWS re:Inforce 2025
2nd Sight Lab
 
Canva Pro Crack Free Download 2025-FREE LATEST
Canva Pro Crack Free Download 2025-FREE LATEST
grete1122g
 
Why Edge Computing Matters in Mobile Application Tech.pdf
Why Edge Computing Matters in Mobile Application Tech.pdf
IMG Global Infotech
 
OpenChain Webinar - AboutCode - Practical Compliance in One Stack – Licensing...
OpenChain Webinar - AboutCode - Practical Compliance in One Stack – Licensing...
Shane Coughlan
 
Building Geospatial Data Warehouse for GIS by GIS with FME
Building Geospatial Data Warehouse for GIS by GIS with FME
Safe Software
 
CodeCleaner: Mitigating Data Contamination for LLM Benchmarking
CodeCleaner: Mitigating Data Contamination for LLM Benchmarking
arabelatso
 
Foundations of Marketo Engage - Programs, Campaigns & Beyond - June 2025
Foundations of Marketo Engage - Programs, Campaigns & Beyond - June 2025
BradBedford3
 
Best AI-Powered Wearable Tech for Remote Health Monitoring in 2025
Best AI-Powered Wearable Tech for Remote Health Monitoring in 2025
SEOLIFT - SEO Company London
 
Complete WordPress Programming Guidance Book
Complete WordPress Programming Guidance Book
Shabista Imam
 
Microsoft-365-Administrator-s-Guide1.pdf
Microsoft-365-Administrator-s-Guide1.pdf
mazharatknl
 
Best Practice for LLM Serving in the Cloud
Best Practice for LLM Serving in the Cloud
Alluxio, Inc.
 
Introduction to Agile Frameworks for Product Managers.pdf
Introduction to Agile Frameworks for Product Managers.pdf
Ali Vahed
 
Zoho Creator Solution for EI by Elsner Technologies.docx
Zoho Creator Solution for EI by Elsner Technologies.docx
Elsner Technologies Pvt. Ltd.
 

Testing angular js

  • 2. Acerca de Desarrollador Web Full Stack Symfony, Drupal, Magento LESS, SASS, AngularJS, JavaScript
  • 3. Indice Herramientas testing Instalación/Configuración Karma Test unitarios - Jasmine ngMock Test unitarios AngularJS Arquitectura aplicación Demo Testing sobre Servicios, Controlador, Directiva
  • 4. Herramientas testing Karma - Test runner Protractor - Testing framework Nos permite correr un comando que determina si un conjunto de test pasan o no. Permite automatizar los test funcionales a través de la interacción con el navegador.
  • 5. Herramientas testing Jasmine - Testing framework Alternativas a Jasmine Integración por defecto con Karma Herramientas como: spies, fakes… Sintaxis limpia, test con formato que describen la conducta que estamos testeando Selenium, Mocha
  • 6. Instalación Karma * npm init npm install karma -g karma init Necesitaremos instalar Jasmine y el lanzador de Chrome npm install jasmine-core -g npm install karma-jasmine -g npm install karma-chrome-launcher -g karma start Comprobamos la instalación: karma --version
  • 8. Test unitarios - Jasmine describe it expect matchers describe("A suite is just a function", function() { var a; it("and so is a spec", function() { a = true; expect(a).toBe(true); }); }); https://www.cheatography.com/citguy/cheat-sheets/jasmine-js-testing/
  • 9. Test unitarios - Jasmine beforeEach Es llamado antes de ejecutar el test del bloque describe en el que se encuentra. afterEach Es llamado después de ejecutar el test del bloque describe en el que se encuentra. describe("A spec (with setup and tear-down)", function() { var foo; beforeEach(function() { foo = 0; foo += 1; }); afterEach(function() { foo = 0; }); it("is just a function, so it can contain any code", function() { expect(foo).toEqual(1); }); it("can have more than one expectation", function() { expect(foo).toEqual(1); expect(true).toEqual(true); }); });
  • 10. Test unitarios - Jasmine Spies describe("A spy", function() { var foo, bar = null; beforeEach(function() { foo = { setBar: function(value) { bar = value; } }; spyOn(foo, 'setBar'); foo.setBar(456, 'another param'); }); it("tracks that the spy was called", function() { expect(foo.setBar).toHaveBeenCalled(); }); it("tracks that the spy was called x times", function() { expect(foo.setBar).toHaveBeenCalledTimes(2); }); it("tracks all the arguments of its calls", function() { expect(foo.setBar).toHaveBeenCalledWith(456, 'another param'); }); }); Algunos matchers para los Spies: toHaveBeenCalled toHaveBeenCalledTimes toHaveBeenCalledWith
  • 11. Test unitarios - Jasmine Spies describe("A spy, when configured with an alternate implementation", function() { var foo, fetchedBar; beforeEach(function() { spyOn(foo, "getBar").and.callFake(function(arguments, can, be, received) { return 1001; }); }); fetchedBar = foo.getBar(); it("tracks that the spy was called", function() { expect(foo.getBar).toHaveBeenCalled(); }); it("when called returns the requested value", function() { expect(fetchedBar).toEqual(1001); }); }); Encadenando and.callFake.
  • 12. Test unitarios - Jasmine Existen otros muchos elementos en Jasmine que podéis consultar en: https://jasmine.github.io/pages/docs_home.html
  • 13. Test unitarios - ngMock Elementos de test necesarios para testear apps Angular JS $httpBackend Inject $controller $compile ...
  • 14. Test unitarios AngularJS Elementos bajo test: ● Servicios ● Controllers ● Directiva ● Eventos
  • 15. Aplicación demo - Arquitectura bt-setup-table Proxies Services Controllers Directives Transformers Controllers Templates App
  • 16. Aplicación demo - Arquitectura Estructura directorio para los tests
  • 17. Aplicación demo - Arquitectura bt-setup-controller bt-setup SELECT_SHIP
  • 18. Test Unitario Angular 1. Describimos la suite de test describe('Setup Table Service test', function () { 1. Cargamos el módulo que contiene el código a ejecutar beforeEach(module('battleShip')); 1. Definimos cada spec o test Pasos comunes:
  • 19. $httpBackend Test Unitario Angular - SetupTableProxy SetupTableProxy$http [[0, 0], [0, 0]]
  • 20. fakeSetupTableProxy Test Unitario Angular - SetupTableGetService SetupTableProxy SetupTableGetService [[0, 0], [0, 0]]
  • 21. Test Unitario Angular - SetupTableTransformer SetupTableTransformer[[0, 0], [0, 0]] [[ { value: 0, class: 'water'}, { value: 0, class: 'water'}], [ { value: 0, class: 'water'}, { value: 0, class: 'water'}]]
  • 22. fakeSetupTableTransformerfakeSetupTableGetService Test Unitario Angular - SetupTableService SetupTableGetService [[0, 0], [0, 0]] [[ { value: 0, class: 'water'}, { value: 0, class: 'water'}], [ { value: 0, class: 'water'}, { value: 0, class: 'water'}]] SetupTableGetService SetupTableTransformer [[0, 0], [0, 0]]
  • 23. Test Unitario Angular - SetupTableCheckService SetupTableCheckService [[ { value: 0, class: 'water'}, { value: 0, class: 'water'}], [ { value: 0, class: 'water'}, { value: 0, class: 'water'}]] x y length isVertical true/false
  • 24. Test Unitario Angular - Controllers SetupControllerDirective SetupController SELECT_SHIP checkSetupShip resetCellClass
  • 25. Test Unitario Angular - Directive Template https://github.com/karma-runner/karma-ng-html2js-preprocessor npm install karma-ng-html2js-preprocessor --save-dev module.exports = function(config) { config.set({ preprocessors: { '**/*.html': ['ng-html2js'] }, ... ngHtml2JsPreprocessor: { moduleName: 'templates' }, …. files: [ ... '**/*.html' ],
  • 26. Test Unitario Angular - Directive setupTableDirective ● Comprobación de creación de tablero ● Conducta tras pasar por las celdas mouseenter/mouseleave
  • 27. Referencias https://jasmine.github.io/2.5/introduction AngularJS By Example - Packt Publishing https://github.com/atomicposts/battleship