- Selenium - Browser-Based Automated Testing of Web Apps Under Continuous Integration Presented By Chris Bedford Founder & Lackey at Large Build Lackey.

Slides:



Advertisements
Similar presentations
Vincent Massol, 1 st December 2006 Quality with Maven2.
Advertisements

Copyright 2009, Build Lackey Labs (see last slide for licensing terms) - Selenium - Browser-Based Automated Testing of Web Apps.
Introduction to Maven 2.0 An open source build tool for Enterprise Java projects Mahen Goonewardene.
Developing in CAS. Why? As distributed you edit CAS 3 with Eclipse and build with Maven 2 – Best Practice for Release Engineering – Difficult edit-debug.
Pubman and Selenium tests. What is Selenium Selenium is a suite of Web application test automation tools for any browser on any operating system –Firefox,
Test Automation Framework Ashesh Jain 2007EE50403 Manager Amit Maheshwari.
Java Build Tool Comparison HJUG - April 29th, 2009 John Tyler.
Web Applications Basics. Introduction to Web Web features Clent/Server HTTP HyperText Markup Language URL addresses Web server - a computer program that.
Selenium – Testing Tool. What is Selenium? Selenium is a robust set of tools that supports rapid development of test automation for web-based applications.
Talend 5.4 Architecture Adam Pemble Talend Professional Services.
Automation using Selenium Authored & Presented by : Chinmay Sathe & Amit Prabhu Cybage Software Pvt. Ltd.
PHP, QA, and Jenkins Eric Cope June 25, 2013
Maven & Bamboo CONTINUOUS INTEGRATION. QA in a large organization In a large organization that manages over 100 applications and over 20 developers, implementing.
SOA-14: Continuous Integration in SOA Projects Experience from the field Andreas Gies Principal Architect.
MAVEN-BLUEMARTINI Yannick Robin. What is maven-bluemartini?  maven-bluemartini is Maven archetypes for Blue Martini projects  Open source project on.
LDS Account Integration. Disclaimer This is a training NOT a presentation. – Be prepared to learn and participate in labs Please ask questions Prerequisites:
AUTOBUILD Build and Deployment Automation Solution.
Using the ALM Module Fully Automated Deployments in Stack 3.2.
Using the ALM Module Michael Youngstrom. Disclaimer This is a training NOT a presentation. – Be prepared to learn and participate in lab Please ask questions.
Chapter 6 Server-side Programming: Java Servlets
Selenium and Selenium on Rails. Agenda  Overview of Selenium Simple Selenium Tests Selenium IDE  Overview of Selenium on Rails  Problems with Selenium.
Pubman and Selenium tests. What is Selenium Selenium is a suite of Web application test automation tools for any browser on any operating system –Firefox,
Selenium January Selenium course content  Introduction (Session-1)Session-  Automation  What is automation testing  When to go for automation.
Maven for building Java applications By Nalin De Zoysa
(1) Introduction to Continuous Integration Philip Johnson Collaborative Software Development Laboratory Information and Computer Sciences University of.
SPI NIGHTLIES Alex Hodgkins. SPI nightlies  Build and test various software projects each night  Provide a nightlies summary page that displays all.
Selenium server By, Kartikeya Rastogi Mayur Sapre Mosheca. R
Test Automation Using Selenium Presented by: Shambo Ghosh Ankit Sachan Samapti Sinhamahapatra Akshay Kotawala.
8/29/10 Maven Repository Management with Nexus Jim McMahon.
Arklio Studija 2007 File: / / Page 1 Automated web application testing using Selenium
Platform & Maven2 David Šimonek. Certified Engineer Course Agenda What is Maven? Why Maven? NB IDE & Maven NB Platform & Maven.
ArcGIS for Server Security: Advanced
Open-O Client Project Proposal
Agenda:- DevOps Tools Chef Jenkins Puppet Apache Ant Apache Maven Logstash Docker New Relic Gradle Git.
Open-O Integration Project Introduction
Project Management: Messages
Essentials of UrbanCode Deploy QQ147 Components
Open-O Client Project Proposal
Maven 04 March
Essentials of UrbanCode Deploy v6.1 QQ147
Selenium and Selenium on Rails
JRA2: Acceptance Testing senarious
Testing with Selenium IDE
Data Virtualization Tutorial: Introduction to SQL Script
Understanding SOAP and REST calls The types of web service requests
Data Virtualization Tutorial… CORS and CIS
Overall Architecture and Component Model
Test Driven Development 1 November Agenda  What is TDD ?  Steps to start  Refactoring  TDD terminology  Benefits  JUnit  Mocktio  Continuous.
Testing With Selenium - Open source Test Automation Tool
prepared by hasan.we4tech.com
Processes The most important processes used in Web-based systems and their internal organization.
Unit 6-Chapter 2 Struts.
Advanced Integration and Deployment Techniques
PHP / MySQL Introduction
Continuous Integration For Databases
Continuous Performance Engineering
X in [Integration, Delivery, Deployment]
Open Source Continuous Integration Server
Maven IIB9 Plug-in Version 9.0
Automated Testing and Integration with CI Tool
JENKINS TIPS Ideas for making your life with Jenkins easier
Cordova & Cordova Plugin Installation and Management
Your code is not just…your code
Continuous Integration
Maven IIB9 Plug-in Version 9.0
Selenium Tutorials Cheyat Training.
An introduction to jQuery
An introduction to jQuery
Node.js Test Automation using Oracle Developer Cloud- Simplified
Your code is not just…your code
Presentation transcript:

- Selenium - Browser-Based Automated Testing of Web Apps Under Continuous Integration Presented By Chris Bedford Founder & Lackey at Large Build Lackey Labs Company Overview Founded 2008 Services Release engineering & Build/Test Automation for Java Environments Spring/Hibernate & Groovy/Grails App Development Training: Spring/Groovy/Grails & Build/Test Automation Technologies Employees Mike Jackson

How to write functional tests with Agenda KEY TAKE-AWAYS Different Ways To Test a Grails App Unit, Integration, Functional Selenium Demo of IDE Architecture Alternatives (Canoo WebTest) Automating Testing Using Selenium Maven Demo Cargo Viewing Test Results Lab 1 – maven project Ant Continuous Integration With Hudson How to write functional tests with Selenium How to set up Selenium Testing On Grails Apps In Continuous Integration Building with maven Building With Ant Continuous Integration With Hudson

Different Ways To Test a Java Web App Unit Unit Tests are created and run developer and run using framework like Junit or TestNG test class or package functionality in isolation heavy use of mocks and stubs tests should execute quickly and be run often to catch problems early on Integration If you are dependent on someone else’s stuff, the test includes your stuff and theirs Verifies that two or more components work together, usually directly, and not with mocks To simplify test set-up components typically execute same JVM process Functional Testing Run application in container Exercise functionality via a client side agent that executes Javascript. Agent could be either: your actual target browser (Firefox, IE, etc.) [Selenium's approach] a Javascript engine embedded into test framework [Canoo Webtest's approach] Package or class level scope Mock http requests increasingly coarse grained components under test Client requests from same process Separate client Real http requests

Manual Steps Involved In Running Selenium Before running Selenium Functional Tests we need to Compile classes Run unit and integration tests bail on functional tests if we catch problems with lighter weight tests Package .war file Install and start the container in which we want to run the .war Deploy the .war to the container unless your running Jetty, which runs embedded in your app Launch target browser Launch Selenium on desired test suite

Launching Selenium

Recording New Selenium Tests

Exporting test commands to 3GL (Java, etc.)

Saving New or Modified Selenium Tests Individual tests referenced by the suite are recorded using their paths relative to the suite. For simplicity put your suite and all tests in the same directory (to start)

Selenium Components Selenium IDE Selenese Commands Enable test author to simulate navigation, clicks Make assertions about expected responses Selenium RC Client side library that enables you to program more sophistication into your tests than the IDE allows (conditions, looping, error handling) The Selenium Server which launches and kills browsers, interprets and runs the Selenese commands passed from the test program, and acts as an HTTP proxy,

Selenium Client Side Library & Server In Action (javascript) (client side java script / Ajax portion of application under Test – originates from here ) HTTP Application under test (server side) Selenium-server.jar Reports back results of test to client HTTP Source: http://seleniumhq.org/docs/05_selenium_rc.html

A Look Same Origin Policy (Which Selenium’s Architecture Circumvents) Forbids JavaScript code running on a web page from interacting with resources which originate from any web site other than the one which served up that web page

Selenium RC Server Acting As Proxy To Avoid Same Origin Policy Restrictions 4) Server interprets the command and then triggers the corresponding javascript execution to execute that command within the browser (say open page in app under test)s What happens when a test suite starts ? Proxy forwards request to app server 5) Request to open the page is routed through proxy server 6) 2) Selenium-RC server launches a browser (or reuses an old one) with URL that injects Selenium-Core’s javascript into browser-loaded web page. 7) App server returns response 1) client/driver establishes connection w.selenium-RC 3) client-driver passes a Selenese command to the server e.g.: open command

Functional Test Alternatives: Canoo vs Selenium Canoo Web Test built on HtmlUnit pros: excellent test reporting allows you to pin point errors in test very easily. faster to run (no browser spin up overhead) better support for non HTML content (like spread sheets) cons: Weaker IDE (for test recording and playback) develop tests in Ant or Gant only Selenium develop tests in HTML markup or 3 GL's like Java, Ruby, etc. run test in actual browser vs.embedded Javascript engine used by NO popular browser platform slower to start. see 'pros' listed Canoo RECOMMENDATION: I’d go with Canoo for testing a REST-ful API

Canoo Web Test Reports Canoo's reports show overall test results and let you drill down into any test Canoo’s test results reports really excel at providing you drill down capability into the exact step of a test that failed. With Canoo’s reports you see a clickable entries for each test run toward the bottom of the page together with a summary of tests run. (pass fail percentages of both tests and individual steps within tests). If you click on an entry for an individual test, you see a page…. (next slide)…

Canoo Web Test Reports (cont.) Click to review a copy of the response HTML page corresponding to the first test step that failed That gives you the pass/fail status of each individual step within the test. You can go right to the failing test and view the resulting response page from the server.. Then you can figure out why the returned content did not match your assertions about what that content should have been.

Gluing together the steps in your build process Before running Functional Tests need to Compile Run unit and integration tests bail on functional tests if we catch problems with lighter weight tests Package .war file Install the container in which we want to run the .war (optional) Deploy the .war to the container (optional – can just do ‘grails run-app’) Launch your target browser Launch Selenium on your desired test suite To automate this process you can use ant maven Groovy/Gant scripts Gradle Our example uses Maven (demo) (tour of pom.xml files that wire together our build steps)

Download And Install Tomcat deploy Compile Unit Test Integration Test Package .war file

Structure of our demo project Maven Repository org.example:demo:1.1 Lives in $HOME/.m2/repostitory or /Docuemts and Settings/<user>/.m2/repository mvn install declares a a dependency on org.example:demo:1.1 declares the artifact it produces to be org.example:demo:1.1

Demo All Tests Pass Some Tests Fail

Maven Basics Convention over configuration Standardizes where things live and what they are named Lets you know where to look for the things you need… and what to do when you find them Project Object Model (pom.xml) specifies the complete ‘recipe for your build’ what artifact type are your producing ? (the name, the version…) what are the dependencies (things you need) to produce that artifact ? What plug-ins activate at what phases in the build life cycle ? Shared Repository for storing artifacts that result from a build Convention for naming artifacts Build Life Cycle each project is typically responsible for producing a distinct artifact (a.k.a. packaging) type .jar, .war, .ear, etc. each packaging type has an associated life cycle (ordered set of build phases) Nested build project (module) structure overall driver for your build project lives at top level of a directory hierarchy sub-modules underneath the parent can be either individual components of your product …or…. key phases in your build

Maven Nested Module Structure, Dependencies and Shared Repo Maven Repository org.example:demo:1.1 Lives in $HOME/.m2/repostitory or /Docuemts and Settings/<user>/.m2/repository mvn install declares a a dependency on org.example:demo:1.1 declares the artifact it produces to be org.example:demo:1.1

Maven pom.xml – Nested Module Structure

Maven pom.xml – Dependency Relationships Maven Repository org.example:demo:1.1

Hooking Maven Plug-ins Maven Into the Build Life Cycle pom.xml Build Life Cycle Phases validate generate/process-sources process-sources generate/process-resources compile test prepare-package package pre-integration-test integration-test post-integration-test verify install deploy Canoo’s test results reports really excel at providing you drill down capability into the exact step of a test that failed. With Canoo’s reports you see a clickable entries for each test run toward the bottom of the page together with a summary of tests run. (pass fail percentages of both tests and individual steps within tests). If you click on an entry for an individual test, you see a page…. (next slide)…

Cargo A set of APIs that assists in installing web containers (such as Tomcat, JBoss) booting and shutting them down deploying web applications (.wars and .ears) Invokable via ant tasks maven plugin Java API <target name="functional-test" > <cargo containerId="tomcat6x" action="start" … > <zipurlinstaller installurl="http://somewhere/tomcat-6.0.zip"/> <configuration type="standalone" home="${tomcatdir}"> <deployable type="war" file="foo.war"/> </configuration> </cargo> <plugin> ... <artifactId>cargo-maven2-plugin</artifactId> <config> <wait>false</wait> <container> <containerId>tomcat6x</containerId> <zipUrlInstaller> <url>http://somewhere/tomcat-6.0.zip</url> ... Installer installer = new URL("http://somewhere/tomcat-6.0.zip")); installer.iZipURLInstaller(new nstall(); LocalConfiguration configuration = new DefaultConfigurationFactory().createConfiguration("tomcat6x")...) container = new DefaultContainerFactory() .createContainer("tomcat6x"....); container.setHome(installer.getHome()); WAR deployable = new WAR("foo.war); deployable.setContext("ROOT"); configuration.addDeployable(deployable);

Launching Selenium Via Ant Walk through of ant script that launches Selenium server in separate JVM, Waits for server ready, then launches Selenium tests, then waits for shut down

Continuous Integration Dedicated box runs regular full builds (including tests) of your software Build triggers whenever any developer checks into SCM Team is notified of any failures

Continuous Integration Benefits Replaces big (and long) integration cycles with small frequent ones. Same benefits as continous compilation in Eclipse Immediate feedback when an error is introduced. Fewer deltas between when it worked and when it broke => easier resolution of failures Lower ripple through impact when colleagues checks in broken code CI server build fails & team is notified Other developers know it is not safe to pull from source Mail sent out when build goes back to normal

Workflow After Adopting Continous Integration Developer: 0- Check CI server for current build status broken ? don't update ! ... otherwise.. 1- check out from SCM 2- code new feature 3- run automated build on your box 4- Tests pass ? no? go back to 2 ! 5- Commit changes CI Server: 0- Receive notification of change in SCM repo 1- Check out latest sources 2- Build from scratch 3 Build passes? yes: publish, e.g., deploy .war to QA server no: send out email, flash red lights ... Build ok? broken ! SCM Repo

Continuous Integration With Hudson Hudson orchestrates the execution of repeatable jobs periodic builds (e.g., nightly) builds that are triggered by some event (like checkin to source control) Keeps History of Past Builds (Trend Reports) Notifies When Builds Fail Written in Java and runs from a .jar (no install required) Integrates with wide range of SCM systems (SVN, P4, etc.) Supports ant, maven, shell script based builds

Small Sample of Available Hudson Plug-ins Project Metrics Code Coverage (clover, cobertura, emma) Checkstyle Frameworks Grails (invoke grails tasks as build steps) Gradle Build Wrappers Locks and Latches - allows orchestration of multiple jobs Build Time Out

Resources Selenium Mailing List http://old.nabble.com/Selenium-f14083.html Selenium Web Site http://seleniumhq.org/ Ant and Maven CI Tips & Tricks http://wiki.openqa.org/display/SRC/Selenium-RC+and+Continuous+Integration

Thank You !

Content Licensing Terms for This Work You may present, distribute, copy, or incorporate into your own work, any and all portions of this presentation as long as such copies, or derivative works are made available without charge. If you would like to redistribute this work on any type of fee-for-use or subscription basis, or if you wish incorporate any or all portions of this work into content which you charge for, please contact info <at> buildlackey.com to discuss licensing terms.