24
JavaScript Applications for the Enterprise: Test More Work Less GEORGE BOCHENEK // RANDY JONES @bosshenek @randysjones

Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

  • Upload
    others

  • View
    21

  • Download
    0

Embed Size (px)

Citation preview

Page 1: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

JavaScript Applications

for the Enterprise:

Test More Work LessGEORGE BOCHENEK // RANDY JONES

@bosshenek @randysjones

Page 2: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

QA is Important

Page 3: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,
Page 4: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Regressions and

the Dream Curve

Page 5: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Enterprise Challenges

Page 6: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

https://www.slideshare.net/abagmar/anand-bagmar-behavior-driven-testing-bdt-in-agile

Page 7: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Nightmare Test Pyramid

Bugs

A single functional test thathasn’t passed in three years

Page 8: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Write Code

Write Test

Write code, break test

Rewrite Test

How do we Test?

Page 9: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Write Test

Test Fails

Write code till passes

Refactor

Test Driven Development

Page 10: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Easy to Test

=

Easy to Maintain

Page 11: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Rule #1:

Don’t Test

Other People’s Code

Page 12: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,
Page 13: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,
Page 14: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

…but I want to use ((( Insert latest trendy JavaScript Framework )))

Page 15: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Use any

framework

you want

https://github.com/Esri/esri-loader

Page 16: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Legacy Projects

Page 17: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,
Page 18: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Continuous Integration

Page 19: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Trunk

aka

Stable

Tim

e

Release Candidate

1

3

7

Some

Feature

8

6

Future

Feature

2

4

9

10

Update

5

11

Minor

Feature

1.0

1.1

Source Control

Inspired from https://gist.github.com/digitaljhelms/4287848

Page 20: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Tim

e

Master

1

3

7

Some

Feature

6

Future

Feature

2

4

8

9

Update

5

Minor

Feature

1.0

1.1

Source Control

Revised

Inspired from https://gist.github.com/digitaljhelms/4287848

Page 21: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Related Talks

Javascript Applications for the Enterprise: Building for Production• TODAY // 5:30 - 6:30• Pasadena / Sierra / Ventura• George Bochenek / Randy Jones

Web AppBuilder for ArcGIS: Advanced Development Tools and Techniques• TODAY // 2:30 - 3:30• Pasadena / Sierra / Ventura• George Bochenek / Randy Jones

Page 22: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Custom App Example

https://github.com/Esri/enterprise-build-sample-js

Web AppBuilder Resources

https://github.com/gbochenek/wab-test-example

DevOps Resources

https://github.com/Esri/esri-loader

https://eslint.org/

https://gist.github.com/digitaljhelms/4287848 - Source Control

The Clean Code Talks -> Unit Testing

https://www.youtube.com/watch?v=wEhu57pih5w

Resources

Page 23: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,
Page 24: Javascript Applications for the Enterprise: Test More ... · Javascript Applications for the Enterprise: Test More, Work Less, 2018 Esri Developer Summit Palm Springs -- Presentation,

Questions?George Bochenek

@bosshenekRandy Jones@randysjone