from 0 to universal react in production
in 4 months
EZ PZ
AuchanDirect
traditional e-commerce
website
Auchan:D
web app focusing on
customer experience
(react) single page application
web server
web browser
<html>
<body>
<div id="app"></div>
<script src="/app.js"></script>
</body>
</html>
empty DOM with script tag
huge javascript file
API server
react universal application
web server
web browser
<html>
<body data-reactid="18">
<div id="react-root" data-reactid="19">
<div class="app" data-reactroot="" data-reactid="1" data-react-checksum="-2052352663">
Hello world!
</div>
</div>
<script src="/client.bundle.js" data-reactid="21"></script>
</body>
</html>
full DOM with script tag
huge javascript file
API server
server.jsx
client.jsx
shared code
react universal codebase
How to deliver value as fast as possible ?
- dev
- deploy
- learn
- repeat
dev fast, don't break anything
- developer experience: hot reload
- state management: redux + immutable.js
- lint: eslint + eslint-plugin-react
- test: mocha + expect + enzyme + sinon
- test coverage: karma + isparta
trunk based development
- only one shared branch
- release from trunk, roll forward
github flow
trunk based development
build once, run anywhere
- webpack: client & server bundles
- docker
- ansible
how do we learn?
- new relic for monitoring
- sentry for crash reports
- aircall to let our customers call us directly
results from march to june
- 1 to 4 developers (wanna join?)
- 1 branch
- 1 universal app
- 100+ orders