SlideShare a Scribd company logo
Boost your testing:
End to End with

Docker & Geb


17.03.2018
Markus Schlichting
Markus Schlichting
Senior Software Engineer
Basel, Switzerland
Hackergarten Basel
markus.schlichting@canoo.com
@madmas
End-to-End ?
User experience
Adopt legacy
maintain variants
Say hello to
• Groovy DSL on top of Selenium/WebDriver
• IDE support: syntax & debugging
• PageObject, Modules
import geb.Browser
 
Browser.drive {
    go "http://myapp.com/login"
     
    assert $("h1").text() == "Please Login"
     
    $("form.login").with {
        username = "admin"
        password = "password"
        login().click()
    }
     
    assert $("h1").text() == "Admin Section"
}
Structure,
Technical Details
PageObject
PageObject
Spec
Service
Method
waitFor { }
waitFor { }
package demo
import geb.Browser
Browser.drive {
go "https://mynethome.de/animation.html"
assert title == "Animation For Waitfor Example"
$("div#app button").click()
waitFor { !$("div.modal").hasClass("fade-enter-active") }
$("div.modal button").click()
waitFor { !$("div.modal").hasClass("fade-leave-active") }
}
+ Spock
+ Spock
+ Spock
1
2
+ Spock
Write End-to-End tests with Geb
Demo
Non-blocking tests?
Docker
 Boost your testing: End-to-End with Docker and Geb
• Docker WebDriver Selenium Container
• Xvfb: X virtual frame-buffer
• Chrome, Firefox
• Video recording
Docker
encapsulate 

End-to-End tests
Demo
http://nvie.com/posts/a-successful-git-branching-model/
Automation!
Docker&Geb + CI
Demo
 Boost your testing: End-to-End with Docker and Geb
Unit
Integration
End to End


• E2E do not replace other tests - they rather
complete them
• E2E should merely be seen as the final

„does everything fit together“
• „Acceptance Tests“
The horizon
• Living Documentation:

Geb/Spock Specs + AsciiDoctor
Markus Schlichting
markus.schlichting@canoo.com
@madmas
Happy with End-to-End testing
=

More Related Content

PDF
Introduction to polymer project
PPTX
Web Components: Web back to future.
PDF
Polymer vs other libraries (Devfest Ukraine 2015)
PDF
Polymer
PPTX
The rise of Polymer and Web Components (Kostas Karolemeas) - GreeceJS #17
ODP
Effective TDD - Less is more
PDF
Google Polymer Framework
PDF
Simpler Web Architectures Now! (At The Frontend 2016)
Introduction to polymer project
Web Components: Web back to future.
Polymer vs other libraries (Devfest Ukraine 2015)
Polymer
The rise of Polymer and Web Components (Kostas Karolemeas) - GreeceJS #17
Effective TDD - Less is more
Google Polymer Framework
Simpler Web Architectures Now! (At The Frontend 2016)

What's hot (20)

PPTX
Html5 & less css
PPTX
Google Polymer Introduction
PPTX
Polymer presentation in Google HQ
PDF
A Simpler Web App Architecture (jDays 2016)
PPTX
5 x HTML5 worth using in APEX (5)
KEY
Post GoGaRuco 2010 hack day at Pivotal Labs : HTML5 & CSS3
PDF
AEM responsive
PPTX
Polymer and web component
PPT
Taking Advantage of Client Side / JavsScript Templates in Rich Internet Appli...
PPTX
Grails and Ajax
PPTX
Google AppEngine Workshop
PPTX
Host, deploy & scale Blazor Server Apps
PDF
Booting up with polymer
PPTX
HTML5 for Rich User Experience
PPTX
What’s right & wrong with WCF-WebHTTP Adapter?
PPTX
Browser Developer Tools
PPTX
How to build a web application with Polymer
PPTX
Front end optimization
PDF
Modern Web App Architectures
PPTX
Front-End Development
Html5 & less css
Google Polymer Introduction
Polymer presentation in Google HQ
A Simpler Web App Architecture (jDays 2016)
5 x HTML5 worth using in APEX (5)
Post GoGaRuco 2010 hack day at Pivotal Labs : HTML5 & CSS3
AEM responsive
Polymer and web component
Taking Advantage of Client Side / JavsScript Templates in Rich Internet Appli...
Grails and Ajax
Google AppEngine Workshop
Host, deploy & scale Blazor Server Apps
Booting up with polymer
HTML5 for Rich User Experience
What’s right & wrong with WCF-WebHTTP Adapter?
Browser Developer Tools
How to build a web application with Polymer
Front end optimization
Modern Web App Architectures
Front-End Development
Ad

Similar to Boost your testing: End-to-End with Docker and Geb (20)

PPT
Google Gears
PDF
Familiar HTML5 - 事例とサンプルコードから学ぶ 身近で普通に使わているHTML5
PDF
HTML5 Refresher
PDF
The Big Picture and How to Get Started
KEY
Google App Engine with Gaelyk
KEY
Html5 For Jjugccc2009fall
PDF
Word camp nextweb
PDF
Introduction to web components
PDF
[convergese] Adaptive Images in Responsive Web Design
PDF
HTML5 (and friends) - History, overview and current status - jsDay Verona 11....
PDF
Into The Box 2018 Going live with commandbox and docker
PDF
Going live with BommandBox and docker Into The Box 2018
PDF
A I R Presentation Dev Camp Feb 08
PDF
Spark IT 2011 - Simplified Web Development using Java Server Faces 2.0
PPTX
Cloud Endpoints _Polymer_ Material design by Martin Görner
PPT
PPT
High Performance Web Pages - 20 new best practices
PPT
Html5 drupal7 with mandakini kumari(1)
PPTX
Silverlight 4 @ MSDN Live
Google Gears
Familiar HTML5 - 事例とサンプルコードから学ぶ 身近で普通に使わているHTML5
HTML5 Refresher
The Big Picture and How to Get Started
Google App Engine with Gaelyk
Html5 For Jjugccc2009fall
Word camp nextweb
Introduction to web components
[convergese] Adaptive Images in Responsive Web Design
HTML5 (and friends) - History, overview and current status - jsDay Verona 11....
Into The Box 2018 Going live with commandbox and docker
Going live with BommandBox and docker Into The Box 2018
A I R Presentation Dev Camp Feb 08
Spark IT 2011 - Simplified Web Development using Java Server Faces 2.0
Cloud Endpoints _Polymer_ Material design by Martin Görner
High Performance Web Pages - 20 new best practices
Html5 drupal7 with mandakini kumari(1)
Silverlight 4 @ MSDN Live
Ad

Recently uploaded (20)

PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
PPTX
CHAPTER 2 - PM Management and IT Context
PPTX
Reimagine Home Health with the Power of Agentic AI​
PDF
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
PDF
Design an Analysis of Algorithms I-SECS-1021-03
PDF
Adobe Illustrator 28.6 Crack My Vision of Vector Design
PPTX
Essential Infomation Tech presentation.pptx
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PDF
How Creative Agencies Leverage Project Management Software.pdf
PDF
wealthsignaloriginal-com-DS-text-... (1).pdf
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PDF
medical staffing services at VALiNTRY
PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PDF
2025 Textile ERP Trends: SAP, Odoo & Oracle
PDF
Digital Strategies for Manufacturing Companies
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
PPTX
history of c programming in notes for students .pptx
PPTX
Odoo POS Development Services by CandidRoot Solutions
PDF
System and Network Administration Chapter 2
PPTX
Transform Your Business with a Software ERP System
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
CHAPTER 2 - PM Management and IT Context
Reimagine Home Health with the Power of Agentic AI​
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
Design an Analysis of Algorithms I-SECS-1021-03
Adobe Illustrator 28.6 Crack My Vision of Vector Design
Essential Infomation Tech presentation.pptx
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
How Creative Agencies Leverage Project Management Software.pdf
wealthsignaloriginal-com-DS-text-... (1).pdf
Wondershare Filmora 15 Crack With Activation Key [2025
medical staffing services at VALiNTRY
How to Choose the Right IT Partner for Your Business in Malaysia
2025 Textile ERP Trends: SAP, Odoo & Oracle
Digital Strategies for Manufacturing Companies
Which alternative to Crystal Reports is best for small or large businesses.pdf
history of c programming in notes for students .pptx
Odoo POS Development Services by CandidRoot Solutions
System and Network Administration Chapter 2
Transform Your Business with a Software ERP System

Boost your testing: End-to-End with Docker and Geb