Automated Testing
A software adventure
https://www.flickr.com/photos/nancyvioletavelez/
Hello World
Infinite possibility.
That Escalated Quickly
https://www.flickr.com/photos/aigle_dore/
At some point we realize that there is uncertainty.
Is it going to break?
Software
Is
Hard :(
Testing can tell you exactly what will break and where.
Think of it like a contract with your product.
An agreement on function.
How does it work?
Tests are simply expectations of how your code is supposed to work. If your expectation is met, then the test passes. Otherwise, it fails.
Think
Long
Term
https://www.flickr.com/photos/patt-ach/
Case Study #1
Testing All The Things
JavaScript
Selenium
Sauce Labs
Python
Jasmine
PhantomJS
Expensive to write.
--------------
--------------
Cheap to write
run
maintain
get results
maintain
run
get results
https://www.flickr.com/photos/calsidyrose/
Unit Test
Integration Test
it("should detect an empty object", function(){
expect(Util.isEmptyObject({})).toEqual(true);
expect(Util.isEmptyObject({name:"ricky"})).toEqual(false);
});
@Test
public void noApiKey() {
final String actualResponse = getResponse(RULE, "/nitro", String.class);
String expected = "{\"status\":\"error\",\"message\":\"apiKey parameter is required\"}";
assertThat("The /nitro should complain about apiKey", actualResponse,
is(equalTo(expected)));
}
Lesson Learned
The 90-10 Rule
Leverage unit test for 90% of your test coverage
Leverage integration tests for 10% of your test coverage (SMOKE TEST)
https://www.flickr.com/photos/vonlind/
What We Had
What We Needed
Case Study #2
Test Some of The Things
Existing Monolithic Application
No Documentation
https://www.flickr.com/photos/calsidyrose/
Per page of our app
1. Document functionality
2. Agree to functionality across teams
3. Write Manual Tests
4. Evaluate to see if we can automate it
Don't do it all at once. Iterate on it. We created a ticket for each page. We pull a few in each iteration. This way we are not completely blocking our product to market pipeline.
https://www.flickr.com/photos/texturetime/
What to test?
- Define your expectations. Your contract.
- Does this contract reflect what we are selling?
- Test YOUR code, not third party code.
- Business logic
- start with mission critical functions
- If your function has an "if", test all cases
- handle bad input
- edge cases
https://www.flickr.com/photos/30127497@N04/
Where to start?
- Fixing a bug?
- Write a test that confirms the bug.
- Fixing the code will make the test pass.
- Writing new functionality? Write tests.
- When updating legacy code. Write tests.
- Test Driven Development?
- We want a test suite that reflects the contract.
- Doesn't matter how you get there.
https://www.flickr.com/photos/30127497@N04/
Jasmine Examples
define([
'jquery'
], function($) {
describe("Namespacing", function(){
it("window.$ should not be defined", function(){
expect(window.$).toEqual(null);
});
it("window.jQuery should not be defined", function(){
expect(window.jQuery).toEqual(null);
})
});
});
más ejemplos
it("should detect email address", function() {
expect(Util.isEmail("ricky@ricardo.com")).toEqual(true);
expect(Util.isEmail("234")).toEqual(false);
expect(Util.isEmail("1@1.1")).toEqual(false);
expect(Util.isEmail("ricky.guy@ricardo.com")).toEqual(true);
});
it("should detect an empty object", function(){
expect(Util.isEmptyObject({})).toEqual(true);
expect(Util.isEmptyObject({name:"ricky"})).toEqual(false);
});
// Ought to be named stripAngleBrackets
it("should strip angle brackets", function(){
expect(Util.stripHTML("<h1>")).toEqual('h1');
});
it("should escape HTML", function(){
expect(Util.escapeHTML("<h1>Page Title</h1>")).toEqual('<h1>Page Title</h1>');
});
it("should escape double qoutes", function() {
expect(Util.escapeDoubleQuotes("So I says to him, \" Walt! \""))
.toEqual('So I says to him, " Walt! "');
});
How is this automated?
Git Hook
<target name="runJasmineTests">
<property name="specrunner.dir" location="./${test.dir}"/>
<exec executable="phantomjs" newenvironment="false"
dir="./${test.dir}" failonerror="true" osfamily="unix">
<arg value="run-jasmine.js"/>
<arg line="${specrunner.dir}/SpecRunner.html" />
</exec>
</target>
Jasmine Ant Task
Jenkins Config
"Speed is the new currency of development"
Dreamforce
photo by Sean Turbidy
The Advantage
Releasing often while maintaining quality
Its not just about SPEED to Market. Its maintaining QUALITY over time.
https://www.flickr.com/photos/skipmoore/
The
End
https://www.flickr.com/photos/ifindkarma/
deck
By bozzltron
deck
- 1,133