Continuous deployment 2.0

Michelangelo van Dam
Michelangelo van DamSenior PHP architect & QA Specialist um In2IT
CONTINUOUS DEPLOYMENT 2.0
PLAYTIME IS OVER
in itPROFESSIONAL PHP SERVICES
‣ CEO and co-founder of in2it
‣ Community leader
‣ OSS contributor
‣ Conference Speaker
‣ Coach at CoderDojo
MICHELANGELO VAN DAM
MICHIEL ROOK
OUR CD WAS INSPIRED BY
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
MICHIEL’S TALK WAS TO SAY THE LEAST…
QUITE CONTROVERSIAL
▸ deploy to master, no branches
▸ pair programming, quick code reviews
▸ 100% code coverage
▸ strangler pattern to replace 10+ year old
legacy app
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
THAT GOT US
THINKING…
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
LEGACY
APPLICATIONS
COMMON FOR ALL CLIENTS:
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
IN2IT PROCESSES?
? ? ?
?
???
?
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
REFACTORING
ADDING FEATURES
REWRITE FROM SCRATCH
TESTING IS HARD
ONLY NEW FEATURES TESTED
LOTS OF WORK
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
SUPER
HERO
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
IN2IT PROCESSES
ONLY MASTER PAIR PROGRAMMING 100% CODE COVERAGE STRANGLER PATTERN
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
IN2IT PROCESSES
ONLY MASTER ❌ PAIR PROGRAMMING 100% CODE COVERAGE STRANGLER PATTERN
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
IN2IT PROCESSES
ONLY MASTER ❌ PAIR PROGRAMMING ✅ 100% CODE COVERAGE STRANGLER PATTERN
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
IN2IT PROCESSES
ONLY MASTER ❌ PAIR PROGRAMMING ✅ 100% CODE COVERAGE ✅ STRANGLER PATTERN
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
IN2IT PROCESSES
ONLY MASTER ❌ PAIR PROGRAMMING ✅ 100% CODE COVERAGE ✅ STRANGLER PATTERN ❌
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
LET’S SEE WHAT WE’RE MISSING
DO WE NEED TO COMMIT TO MASTER?
▸ All PR’s are going into master branch
▸ Every developer has their own GIT repo
▸ Branching for features
▸ Branching for bug fixes
▸ Deployment Master
▸ Integrates one or more dev branches
▸ Pushes it onto master
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
DEVELOPERS WORK LOCALLY ON A PRIVATE GIT REPO
OUR GIT WORKFLOW
DEVELOPER
PRIVATE REPO
DEVELOPER
PRIVATE REPO
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
ONCE DONE, THEY PUSH TO THEIR PUBLIC REPOS
OUR GIT WORKFLOW
DEVELOPER
PRIVATE REPO
DEVELOPER
PRIVATE REPO
DEVELOPER
PUBLIC REPO
DEVELOPER
PUBLIC REPO
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
AND SEND A PULL REQUEST (PR)
OUR GIT WORKFLOW
DEVELOPER
PRIVATE REPO
DEVELOPER
PRIVATE REPO
DEVELOPER
PUBLIC REPO
DEVELOPER
PUBLIC REPO
TEAM REPO
RELEASE BRANCH
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
OUR RELEASE MANAGER MERGES THE CHANGES IN
OUR GIT WORKFLOW
DEVELOPER
PRIVATE REPO
DEVELOPER
PRIVATE REPO
DEVELOPER
PUBLIC REPO
DEVELOPER
PUBLIC REPO
TEAM REPO
MASTER BRANCH
RELEASE MANAGER
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
CI KICKS IN AND DEPLOYS TO TEST/STAGING/PROD
OUR GIT WORKFLOW
DEVELOPER
PRIVATE REPO
DEVELOPER
PRIVATE REPO
DEVELOPER
PUBLIC REPO
DEVELOPER
PUBLIC REPO
TEAM REPO
MASTER BRANCH
RELEASE MANAGERCI
TEST/STAGING/PROD
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
OUR CONCLUSION
COMMITTING STRAIGHT TO MASTER
▸ Will make the role of “Release Master” obsolete
▸ Good for small teams
▸ Speeds up the deployment process
▸ In our case
▸ We work with distributed teams (3-5 people in each team)
▸ Will only work when all features are live from the start (feature flags)
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
LET’S SEE WHAT WE’RE MISSING…
STRANGLER PATTERN
▸ Is a clean way to replace legacy code with
clean, distributed and optimised code.
▸ Requires domain knowledge (especially for
10+ years of evolution of an app)
▸ Creates duplicate functionality during
transitions
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
INCREMENTALLY MIGRATE A LEGACY SYSTEM BY GRADUALLY
REPLACING SPECIFIC PIECES OF FUNCTIONALITY WITH NEW
APPLICATIONS AND SERVICES. AS FEATURES FROM THE LEGACY
SYSTEM ARE REPLACED, THE NEW SYSTEM EVENTUALLY REPLACES
ALL OF THE OLD SYSTEM'S FEATURES, STRANGLING THE OLD
SYSTEM AND ALLOWING YOU TO DECOMMISSION IT.
Microsoft Cloud Architecture
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
LEGACY APPLICATION
NEW
REPLACEMENT
STRANGLER FAÇADE
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
NEW REPLACEMENT
STRANGLER FAÇADE
LEGACY
APPLICATION
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
OUR CONCLUSION
STRANGLING LEGACY CODE
▸ Will take time to replace old with new code
▸ Until ready, duplicated functional will exist
▸ In our case
▸ We need to replace legacy code with better solutions
▸ We can live with duplicated functionality
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
IMPROVING LEGACY
THE PATH TO
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
PEAR LIBS PECL EXTS
FRAMEWORK
X
FRAMEWORK
Y
CUSTOM
LIBS
BUSINESS LOGIC
Monolithic Code Monster
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
WE NEED A BETTER
SOLUTION!
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
PEAR LIBS PECL EXTS
FRAMEWORK
X
FRAMEWORK
Y
CUSTOM
LIBS
BUSINESS LOGIC
Monolithic Code Monster
FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE
FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE
FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE
FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE
FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE
Functional Microservices
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
I CAN HEAR YOU ASK:
WHY MICROSERVICES?
▸ Not tied to a single technology
▸ A service per functionality makes it easier to
upgrade without impacting the whole
application
▸ Improved security on application, network and
infrastructure
▸ Easy to scale and extend
▸ Better resilience against failing services
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
MICROSERVICES SIND
SINNVOLL!
Stefan Hogdörfer - @shochdoerfer
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
LET’S LOOK IF IT IS A SOLUTION FOR US
PROS EN CONS
Pro Con
Not tied to a single technology Lots of different skillsets
Easy to upgrade/fix or add features Lost in forrest of services
Improved security Requires lots of monitoring
Better scalability Expensive*
Improved resilience for failure
(*) The cost lies in the higher number of “instances” and faster network required to run these services
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
MICROSERVICES &
CONTINUOUS DEPLOYMENT
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
GOALS OF CONTINUOUS
DEPLOYMENT?
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
CONTINUOUS DEPLOYMENT CAN BE THOUGHT OF
AS AN EXTENSION OF CONTINUOUS INTEGRATION,
AIMING AT MINIMIZING LEAD TIME, THE TIME
ELAPSED BETWEEN DEVELOPMENT WRITING ONE
NEW LINE OF CODE AND THIS NEW CODE BEING
USED BY LIVE USERS, IN PRODUCTION.
Agile Alliance - agilealliance.com
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
DOING THINGS MORE THAN ONCE LEAD UP TO…
AUTOMATE DEPLOYMENT PROCESSES
▸ A series of actions taken before changes are
put in production
▸ Chained together with fail switch to create a
pipeline
▸ Provides full reports on each step of the
delivery process
▸ Can be optimized over time
▸ Is repeatable
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
COMPUTERS ARE GREAT AT REPETITIVE TASKS!
MINIMIZE LEAD TIME
▸ Through automation, actions are executed
faster in parallel
▸ Any failures will be reported immediately
▸ Any successes will be notified through
▸ E-mail
▸ Wiki
▸ Slack
▸ …
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
STRESS, PANIC, SICKNESS, … ALL HAVE AN IMPACT ON YOUR CONCENTRATION
PREVENTING HUMAN ERROR!
▸ Automation removes human errors
▸ by stress or a “bad” day
▸ Optimized over time
▸ Repeatable for all stages
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
PROGRAMMING
AGREEMENTS
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
COMMIT SMALL, COMMIT OFTEN
Credits to @CalEvans
THE PROGRAMMER’S MANTRA
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
PERFECT WORLD WOULD MAKE THIS POSSIBLE
OPTIMAL COMMIT
▸ creating/updating class (no body)
▸ creating/changing class method (no body)
▸ creating/changing functionality in method
▸ creating/changing config (no body)
▸ …
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
ON THIS PLANET WE ARE SATISFIED WITH THIS
REALISTIC COMMIT
▸ complete a functionality
▸ complete a logic operation
▸ complete a configuration change
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
SMALL AND OFTEN COMMITS BALANCE
PROS EN CONS
Pro Con
Incremental small improvements Many commits for one task
Errors can be reverted quickly Requires change of attitude
Easy to review
Small impact on production code
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
AIM FOR 100% CODE COVERAGE
Michiel Rook - @michielcts
LET’S GO FOR IT!
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
SMALL CHANGES REQUIRE MINIMAL OVERHEAD
COMMIT SMALL WITH 100% COVERAGE
▸ small code change
▸ small test covering all lines
▸ make use of @covers annotation
▸ Run PHPUnit with “--strict-coverage”
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
EXAMPLE OF USING THE @COVERS ANNOTATION
/**
 * Authentication throws exception for too short password
 *
 * @param string $password
 *
 * @covers LoginFormAuthServiceAuthenticationService::__construct
 * @covers LoginFormAuthServiceAuthenticationService::authenticate
 * @dataProvider shortPasswordProvider
 * @expectedException InvalidArgumentException
 */
public function testAuthenticationThrowsExceptionForTooShortPassword(string $password)
{
    $this->validator->expects($this->once())
        ->method('isValid')
        ->willReturn(false);
    $authService = new AuthenticationService(
        $this->validator,
        $this->accountModel,
        $this->accountEntity,
        $this->twoFactorServiceMock
    );
    $authService->authenticate('username', $password, false);
    $this->fail('Authentication service should throw an exception for too short password input');
}
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
EXAMPLE OF USING THE @COVERS ANNOTATION
/**
 * Authentication throws exception for too short password
 *
 * @param string $password
 *
 * @covers LoginFormAuthServiceAuthenticationService::__construct
 * @covers LoginFormAuthServiceAuthenticationService::authenticate
 * @dataProvider shortPasswordProvider
 * @expectedException InvalidArgumentException
 */
public function testAuthenticationThrowsExceptionForTooShortPassword(string $password)
{
    $this->validator->expects($this->once())
        ->method('isValid')
        ->willReturn(false);
    $authService = new AuthenticationService(
        $this->validator,
        $this->accountModel,
        $this->accountEntity,
        $this->twoFactorServiceMock
    );
    $authService->authenticate('username', $password, false);
    $this->fail('Authentication service should throw an exception for too short password input');
}
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
SHOULD WE ADOPT 100% CODE COVERAGE?
PROS EN CONS
Pro Con
Higher quality of code A huge effort
Every line of code is accountable Requires change of attitude
Huge time/money gain in long tail Time intensive
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
THE PIPELINE
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
A COMMON CI/CD SETUP
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
WE CAN DO BETTER!
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
THE BEGINNING OF A BEAUTIFUL STORY
CODE ASSEMBLY STEP
▸ Check out SCM
▸ Optionally install submodules
▸ Composer packages
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
ARE WE GOOD TO GO?
CODE QUALITY STEP
▸ Version checks (are we on latest version?)
▸ Vulnerability checks (CVE’s)*
▸ Unit testing
▸ Static Analysis
(*) See SensioLabs for composer package validation service
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
LET’S PREPARE EVERYTHING LIKE A TRUE CHEF
PROVISIONING STEP
▸ Create a new environment
▸ Package the code and assets
▸ Sign the package with GPG
▸ Deploy the code
▸ Perform DB migrations
▸ Warm-up caches
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
TEST ALL THE THINGS, AND ADD SOME…
RELEASE QUALITY STEP
▸ Integration testing
▸ Acceptance testing
▸ End-to-end testing
▸ Regression testing
▸ Performance testing
▸ Security testing
▸ Resilience testing
▸ Accessibility testing
▸ UX Testing
▸ …
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
TIME TO SHIP IT!!!
DEPLOYMENT STEP
▸ Stop crons, workers and daemons
▸ Phase out old system with new
▸ Put new system in load balancer
▸ Direct portion of traffic to new node
▸ Validate behaviour of new node
▸ Remove old system from load balancer
▸ Validate deployment
▸ Start crons, workers and daemons
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
KNOWING IS GOOD, KNOWING EVERYTHING IS BETTER - DAVE EGGARS “THE CIRCLE”
REPORTING STEP
▸ Generate release notes
▸ Generate user documentation
▸ Notify training dept. of changes
▸ Generate release report/stats
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
WITH PIPELINES YOU HAVE…
ENDLESS POSSIBILITIES TO DEPLOY
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
AND WHEN SOMETHING DOES GOES WRONG…
THE PIPELINE WILL STOP…
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
WE ROLL FORWARD
WHEN FAILURE HAPPENS
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
YOUR TURN
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
TEST IT ALL!
CONTINUOUS DEPLOYMENT
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
SMALL REMINDER
BY DESIGN
▸ Quality
▸ Security
▸ Privacy
▸ Resilience
▸ Accessibility
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
SET AGREEMENTS AS
A TEAM
IN NEED OF STRUCTURE?
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
WITH PIPELINES
SUCCEED EVERY TIME
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
IMPROVE THE
FEEDBACK LOOP
KNOWLEDGE IS KEY!
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
RESOURCES THAT INSPIRED ME…
RECOMMENDED FOR YOU
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
Use
For feedback on this presentation For discussions on this presentation
Use
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
QUESTIONS?
ARE THERE ANY
Continuous Deployment 2.0www.in2it.be - @in2itvofin it
1 von 73

Recomendados

Let your tests drive your code von
Let your tests drive your codeLet your tests drive your code
Let your tests drive your codeMichelangelo van Dam
2.5K views137 Folien
Multilanguage Pipelines with Jenkins, Docker and Kubernetes (Commit Conf 2018) von
Multilanguage Pipelines with Jenkins, Docker and Kubernetes (Commit Conf 2018)Multilanguage Pipelines with Jenkins, Docker and Kubernetes (Commit Conf 2018)
Multilanguage Pipelines with Jenkins, Docker and Kubernetes (Commit Conf 2018)Jorge Hidalgo
221 views43 Folien
DevOps Interview Questions and Answers 2019 | DevOps Tutorial | Edureka von
DevOps Interview Questions and Answers 2019 | DevOps Tutorial | EdurekaDevOps Interview Questions and Answers 2019 | DevOps Tutorial | Edureka
DevOps Interview Questions and Answers 2019 | DevOps Tutorial | EdurekaEdureka!
735 views91 Folien
Multilanguage pipelines with Jenkins, Docker and Kubernetes (DevOpsDays Riga ... von
Multilanguage pipelines with Jenkins, Docker and Kubernetes (DevOpsDays Riga ...Multilanguage pipelines with Jenkins, Docker and Kubernetes (DevOpsDays Riga ...
Multilanguage pipelines with Jenkins, Docker and Kubernetes (DevOpsDays Riga ...Jorge Hidalgo
1.1K views21 Folien
Continuous Delivery 101 von
Continuous Delivery 101Continuous Delivery 101
Continuous Delivery 101Martin Etmajer
622 views59 Folien
"DevOps > CI+CD " von
"DevOps > CI+CD ""DevOps > CI+CD "
"DevOps > CI+CD "Innovation Roots
3.1K views76 Folien

Más contenido relacionado

Was ist angesagt?

From Continuous Integration to Continuous Delivery and DevOps von
From Continuous Integration to Continuous Delivery and DevOpsFrom Continuous Integration to Continuous Delivery and DevOps
From Continuous Integration to Continuous Delivery and DevOpsLuca Minudel
2.9K views80 Folien
Continuous Deployment To The Cloud @DevoxxPL 2017 von
Continuous Deployment To The Cloud @DevoxxPL 2017 Continuous Deployment To The Cloud @DevoxxPL 2017
Continuous Deployment To The Cloud @DevoxxPL 2017 Marcin Grzejszczak
1.3K views93 Folien
Continuous Delivery Overview von
Continuous Delivery OverviewContinuous Delivery Overview
Continuous Delivery OverviewLuca Minudel
2.3K views68 Folien
Comparing Agile QA Approaches to End-to-End Testing von
Comparing Agile QA Approaches to End-to-End TestingComparing Agile QA Approaches to End-to-End Testing
Comparing Agile QA Approaches to End-to-End TestingKatie Chin
2.6K views16 Folien
CI/CD (DevOps) 101 von
CI/CD (DevOps) 101CI/CD (DevOps) 101
CI/CD (DevOps) 101Hazzim Anaya
1.2K views44 Folien
Continuous Deployment To The Cloud With Spring Cloud Pipelines @WarsawCloudNa... von
Continuous Deployment To The Cloud With Spring Cloud Pipelines @WarsawCloudNa...Continuous Deployment To The Cloud With Spring Cloud Pipelines @WarsawCloudNa...
Continuous Deployment To The Cloud With Spring Cloud Pipelines @WarsawCloudNa...Marcin Grzejszczak
2.5K views126 Folien

Was ist angesagt?(20)

From Continuous Integration to Continuous Delivery and DevOps von Luca Minudel
From Continuous Integration to Continuous Delivery and DevOpsFrom Continuous Integration to Continuous Delivery and DevOps
From Continuous Integration to Continuous Delivery and DevOps
Luca Minudel2.9K views
Continuous Deployment To The Cloud @DevoxxPL 2017 von Marcin Grzejszczak
Continuous Deployment To The Cloud @DevoxxPL 2017 Continuous Deployment To The Cloud @DevoxxPL 2017
Continuous Deployment To The Cloud @DevoxxPL 2017
Marcin Grzejszczak1.3K views
Continuous Delivery Overview von Luca Minudel
Continuous Delivery OverviewContinuous Delivery Overview
Continuous Delivery Overview
Luca Minudel2.3K views
Comparing Agile QA Approaches to End-to-End Testing von Katie Chin
Comparing Agile QA Approaches to End-to-End TestingComparing Agile QA Approaches to End-to-End Testing
Comparing Agile QA Approaches to End-to-End Testing
Katie Chin2.6K views
Continuous Deployment To The Cloud With Spring Cloud Pipelines @WarsawCloudNa... von Marcin Grzejszczak
Continuous Deployment To The Cloud With Spring Cloud Pipelines @WarsawCloudNa...Continuous Deployment To The Cloud With Spring Cloud Pipelines @WarsawCloudNa...
Continuous Deployment To The Cloud With Spring Cloud Pipelines @WarsawCloudNa...
Marcin Grzejszczak2.5K views
Devops certification training course von RadsS1
Devops certification training courseDevops certification training course
Devops certification training course
RadsS1137 views
Monitoring 改造計畫:流程觀點 von William Yeh
Monitoring 改造計畫:流程觀點Monitoring 改造計畫:流程觀點
Monitoring 改造計畫:流程觀點
William Yeh2K views
Scaling Up Lookout von Lookout
Scaling Up LookoutScaling Up Lookout
Scaling Up Lookout
Lookout11.3K views
DevOps and Continuous Delivery Reference Architectures (including Nexus and o... von Sonatype
DevOps and Continuous Delivery Reference Architectures (including Nexus and o...DevOps and Continuous Delivery Reference Architectures (including Nexus and o...
DevOps and Continuous Delivery Reference Architectures (including Nexus and o...
Sonatype 169.3K views
Introduction to CICD von Knoldus Inc.
Introduction to CICDIntroduction to CICD
Introduction to CICD
Knoldus Inc.3.6K views
CI CD Pipeline Using Jenkins | Continuous Integration and Deployment | DevOps... von Edureka!
CI CD Pipeline Using Jenkins | Continuous Integration and Deployment | DevOps...CI CD Pipeline Using Jenkins | Continuous Integration and Deployment | DevOps...
CI CD Pipeline Using Jenkins | Continuous Integration and Deployment | DevOps...
Edureka!5K views
The DevSecOps Builder’s Guide to the CI/CD Pipeline von James Wickett
The DevSecOps Builder’s Guide to the CI/CD PipelineThe DevSecOps Builder’s Guide to the CI/CD Pipeline
The DevSecOps Builder’s Guide to the CI/CD Pipeline
James Wickett613 views
Transforming Organizations with CI/CD von Cprime
Transforming Organizations with CI/CDTransforming Organizations with CI/CD
Transforming Organizations with CI/CD
Cprime11.1K views
Continuous Testing in DevOps von TechWell
Continuous Testing in DevOpsContinuous Testing in DevOps
Continuous Testing in DevOps
TechWell2.1K views
Software development in Formula One: challenges, complexity and struggle for ... von Luca Minudel
Software development in Formula One: challenges, complexity and struggle for ...Software development in Formula One: challenges, complexity and struggle for ...
Software development in Formula One: challenges, complexity and struggle for ...
Luca Minudel1.4K views
PRINCE2 Foundation Slides - Sample von Frank Turley
PRINCE2 Foundation Slides - Sample PRINCE2 Foundation Slides - Sample
PRINCE2 Foundation Slides - Sample
Frank Turley499 views
PRINCE2 Practitioner Classroom slides - Sample von Frank Turley
PRINCE2 Practitioner Classroom slides - Sample PRINCE2 Practitioner Classroom slides - Sample
PRINCE2 Practitioner Classroom slides - Sample
Frank Turley1.5K views

Similar a Continuous deployment 2.0

Sahil Lal Software Engineer von
Sahil Lal Software EngineerSahil Lal Software Engineer
Sahil Lal Software EngineerSahil Lal
287 views27 Folien
Product Management 2.0: Using Confluence to drive company-wide alignment and ... von
Product Management 2.0: Using Confluence to drive company-wide alignment and ...Product Management 2.0: Using Confluence to drive company-wide alignment and ...
Product Management 2.0: Using Confluence to drive company-wide alignment and ...Atlassian
9.5K views66 Folien
Defense-Oriented DevOps for Modern Software Development von
Defense-Oriented DevOps for Modern Software DevelopmentDefense-Oriented DevOps for Modern Software Development
Defense-Oriented DevOps for Modern Software DevelopmentJames Wickett
523 views134 Folien
Defense-Oriented DevOps for Modern Software Development von
Defense-Oriented DevOps for Modern Software DevelopmentDefense-Oriented DevOps for Modern Software Development
Defense-Oriented DevOps for Modern Software DevelopmentVMware Tanzu
491 views134 Folien
Continuous Deployment: Beyond Continuous Delivery von
Continuous Deployment: Beyond Continuous DeliveryContinuous Deployment: Beyond Continuous Delivery
Continuous Deployment: Beyond Continuous DeliveryTimothy Fitz
2.8K views95 Folien
Cloud Native Cost Optimization UCC von
Cloud Native Cost Optimization UCCCloud Native Cost Optimization UCC
Cloud Native Cost Optimization UCCAdrian Cockcroft
7.9K views133 Folien

Similar a Continuous deployment 2.0(20)

Sahil Lal Software Engineer von Sahil Lal
Sahil Lal Software EngineerSahil Lal Software Engineer
Sahil Lal Software Engineer
Sahil Lal287 views
Product Management 2.0: Using Confluence to drive company-wide alignment and ... von Atlassian
Product Management 2.0: Using Confluence to drive company-wide alignment and ...Product Management 2.0: Using Confluence to drive company-wide alignment and ...
Product Management 2.0: Using Confluence to drive company-wide alignment and ...
Atlassian9.5K views
Defense-Oriented DevOps for Modern Software Development von James Wickett
Defense-Oriented DevOps for Modern Software DevelopmentDefense-Oriented DevOps for Modern Software Development
Defense-Oriented DevOps for Modern Software Development
James Wickett523 views
Defense-Oriented DevOps for Modern Software Development von VMware Tanzu
Defense-Oriented DevOps for Modern Software DevelopmentDefense-Oriented DevOps for Modern Software Development
Defense-Oriented DevOps for Modern Software Development
VMware Tanzu491 views
Continuous Deployment: Beyond Continuous Delivery von Timothy Fitz
Continuous Deployment: Beyond Continuous DeliveryContinuous Deployment: Beyond Continuous Delivery
Continuous Deployment: Beyond Continuous Delivery
Timothy Fitz2.8K views
🚀 Here some of those tools which we have used in most web3.0 mobile app devel... von vickykhan28
🚀 Here some of those tools which we have used in most web3.0 mobile app devel...🚀 Here some of those tools which we have used in most web3.0 mobile app devel...
🚀 Here some of those tools which we have used in most web3.0 mobile app devel...
vickykhan284 views
Beyond Build Pipelines - Continuous Delivery's Messy Reality von DevOps.com
Beyond Build Pipelines - Continuous Delivery's Messy RealityBeyond Build Pipelines - Continuous Delivery's Messy Reality
Beyond Build Pipelines - Continuous Delivery's Messy Reality
DevOps.com307 views
Make it reversible - Stephen O'Brien at Inside Intercom Austin von Intercom
Make it reversible - Stephen O'Brien at Inside Intercom AustinMake it reversible - Stephen O'Brien at Inside Intercom Austin
Make it reversible - Stephen O'Brien at Inside Intercom Austin
Intercom6K views
La Redoute DevOps Adoption, A Transformation Journey von Antoine Craske
La Redoute DevOps Adoption, A Transformation JourneyLa Redoute DevOps Adoption, A Transformation Journey
La Redoute DevOps Adoption, A Transformation Journey
Antoine Craske19 views
Introduction to Enterprise 2.0 von David Saitta
Introduction to Enterprise 2.0Introduction to Enterprise 2.0
Introduction to Enterprise 2.0
David Saitta2K views
Enabling application portability with the greatest of ease! von Ken Owens
Enabling application portability with the greatest of ease!Enabling application portability with the greatest of ease!
Enabling application portability with the greatest of ease!
Ken Owens997 views
Microservices the Good Bad and the Ugly von Adrian Cockcroft
Microservices the Good Bad and the UglyMicroservices the Good Bad and the Ugly
Microservices the Good Bad and the Ugly
Adrian Cockcroft9.6K views
Go beyond job scheduling von David Resnic
Go beyond job schedulingGo beyond job scheduling
Go beyond job scheduling
David Resnic625 views
DevOps Days Toronto: From 6 Months Waterfall to 1 hour Code Deploys von Andreas Grabner
DevOps Days Toronto: From 6 Months Waterfall to 1 hour Code DeploysDevOps Days Toronto: From 6 Months Waterfall to 1 hour Code Deploys
DevOps Days Toronto: From 6 Months Waterfall to 1 hour Code Deploys
Andreas Grabner1K views
Denis Cote Networking Presentation von denisco
Denis Cote Networking PresentationDenis Cote Networking Presentation
Denis Cote Networking Presentation
denisco209 views

Más de Michelangelo van Dam

GDPR Art. 25 - Privacy by design and default von
GDPR Art. 25 - Privacy by design and defaultGDPR Art. 25 - Privacy by design and default
GDPR Art. 25 - Privacy by design and defaultMichelangelo van Dam
114 views39 Folien
Moving from app services to azure functions von
Moving from app services to azure functionsMoving from app services to azure functions
Moving from app services to azure functionsMichelangelo van Dam
568 views40 Folien
Privacy by design von
Privacy by designPrivacy by design
Privacy by designMichelangelo van Dam
783 views69 Folien
DevOps or DevSecOps von
DevOps or DevSecOpsDevOps or DevSecOps
DevOps or DevSecOpsMichelangelo van Dam
994 views63 Folien
Privacy by design von
Privacy by designPrivacy by design
Privacy by designMichelangelo van Dam
1.1K views73 Folien
General Data Protection Regulation, a developer's story von
General Data Protection Regulation, a developer's storyGeneral Data Protection Regulation, a developer's story
General Data Protection Regulation, a developer's storyMichelangelo van Dam
1.5K views74 Folien

Más de Michelangelo van Dam(20)

General Data Protection Regulation, a developer's story von Michelangelo van Dam
General Data Protection Regulation, a developer's storyGeneral Data Protection Regulation, a developer's story
General Data Protection Regulation, a developer's story
Leveraging a distributed architecture to your advantage von Michelangelo van Dam
Leveraging a distributed architecture to your advantageLeveraging a distributed architecture to your advantage
Leveraging a distributed architecture to your advantage

Último

Machine Element II Course outline.pdf von
Machine Element II Course outline.pdfMachine Element II Course outline.pdf
Machine Element II Course outline.pdfodatadese1
7 views2 Folien
Performance of Back-to-Back Mechanically Stabilized Earth Walls Supporting th... von
Performance of Back-to-Back Mechanically Stabilized Earth Walls Supporting th...Performance of Back-to-Back Mechanically Stabilized Earth Walls Supporting th...
Performance of Back-to-Back Mechanically Stabilized Earth Walls Supporting th...ahmedmesaiaoun
12 views84 Folien
SEMI CONDUCTORS von
SEMI CONDUCTORSSEMI CONDUCTORS
SEMI CONDUCTORSpavaniaalla2005
20 views8 Folien
CHI-SQUARE ( χ2) TESTS.pptx von
CHI-SQUARE ( χ2) TESTS.pptxCHI-SQUARE ( χ2) TESTS.pptx
CHI-SQUARE ( χ2) TESTS.pptxssusera597c5
29 views33 Folien
Object Oriented Programming with JAVA von
Object Oriented Programming with JAVAObject Oriented Programming with JAVA
Object Oriented Programming with JAVADemian Antony D'Mello
95 views28 Folien
Electrical Crimping von
Electrical CrimpingElectrical Crimping
Electrical CrimpingIwiss Tools Co.,Ltd
21 views22 Folien

Último(20)

Machine Element II Course outline.pdf von odatadese1
Machine Element II Course outline.pdfMachine Element II Course outline.pdf
Machine Element II Course outline.pdf
odatadese17 views
Performance of Back-to-Back Mechanically Stabilized Earth Walls Supporting th... von ahmedmesaiaoun
Performance of Back-to-Back Mechanically Stabilized Earth Walls Supporting th...Performance of Back-to-Back Mechanically Stabilized Earth Walls Supporting th...
Performance of Back-to-Back Mechanically Stabilized Earth Walls Supporting th...
ahmedmesaiaoun12 views
CHI-SQUARE ( χ2) TESTS.pptx von ssusera597c5
CHI-SQUARE ( χ2) TESTS.pptxCHI-SQUARE ( χ2) TESTS.pptx
CHI-SQUARE ( χ2) TESTS.pptx
ssusera597c529 views
NEW SUPPLIERS SUPPLIES (copie).pdf von georgesradjou
NEW SUPPLIERS SUPPLIES (copie).pdfNEW SUPPLIERS SUPPLIES (copie).pdf
NEW SUPPLIERS SUPPLIES (copie).pdf
georgesradjou14 views
fakenews_DBDA_Mar23.pptx von deepmitra8
fakenews_DBDA_Mar23.pptxfakenews_DBDA_Mar23.pptx
fakenews_DBDA_Mar23.pptx
deepmitra812 views
Design and analysis of a new undergraduate Computer Engineering degree – a me... von WaelBadawy6
Design and analysis of a new undergraduate Computer Engineering degree – a me...Design and analysis of a new undergraduate Computer Engineering degree – a me...
Design and analysis of a new undergraduate Computer Engineering degree – a me...
WaelBadawy653 views
Update 42 models(Diode/General ) in SPICE PARK(DEC2023) von Tsuyoshi Horigome
Update 42 models(Diode/General ) in SPICE PARK(DEC2023)Update 42 models(Diode/General ) in SPICE PARK(DEC2023)
Update 42 models(Diode/General ) in SPICE PARK(DEC2023)
7_DVD_Combinational_MOS_Logic_Circuits.pdf von Usha Mehta
7_DVD_Combinational_MOS_Logic_Circuits.pdf7_DVD_Combinational_MOS_Logic_Circuits.pdf
7_DVD_Combinational_MOS_Logic_Circuits.pdf
Usha Mehta59 views
13_DVD_Latch-up_prevention.pdf von Usha Mehta
13_DVD_Latch-up_prevention.pdf13_DVD_Latch-up_prevention.pdf
13_DVD_Latch-up_prevention.pdf
Usha Mehta10 views

Continuous deployment 2.0

  • 2. in itPROFESSIONAL PHP SERVICES ‣ CEO and co-founder of in2it ‣ Community leader ‣ OSS contributor ‣ Conference Speaker ‣ Coach at CoderDojo MICHELANGELO VAN DAM
  • 3. MICHIEL ROOK OUR CD WAS INSPIRED BY Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 4. MICHIEL’S TALK WAS TO SAY THE LEAST… QUITE CONTROVERSIAL ▸ deploy to master, no branches ▸ pair programming, quick code reviews ▸ 100% code coverage ▸ strangler pattern to replace 10+ year old legacy app Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 5. THAT GOT US THINKING… Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 6. LEGACY APPLICATIONS COMMON FOR ALL CLIENTS: Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 7. IN2IT PROCESSES? ? ? ? ? ??? ? Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 8. REFACTORING ADDING FEATURES REWRITE FROM SCRATCH TESTING IS HARD ONLY NEW FEATURES TESTED LOTS OF WORK Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 10. IN2IT PROCESSES ONLY MASTER PAIR PROGRAMMING 100% CODE COVERAGE STRANGLER PATTERN Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 11. IN2IT PROCESSES ONLY MASTER ❌ PAIR PROGRAMMING 100% CODE COVERAGE STRANGLER PATTERN Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 12. IN2IT PROCESSES ONLY MASTER ❌ PAIR PROGRAMMING ✅ 100% CODE COVERAGE STRANGLER PATTERN Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 13. IN2IT PROCESSES ONLY MASTER ❌ PAIR PROGRAMMING ✅ 100% CODE COVERAGE ✅ STRANGLER PATTERN Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 14. IN2IT PROCESSES ONLY MASTER ❌ PAIR PROGRAMMING ✅ 100% CODE COVERAGE ✅ STRANGLER PATTERN ❌ Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 15. LET’S SEE WHAT WE’RE MISSING DO WE NEED TO COMMIT TO MASTER? ▸ All PR’s are going into master branch ▸ Every developer has their own GIT repo ▸ Branching for features ▸ Branching for bug fixes ▸ Deployment Master ▸ Integrates one or more dev branches ▸ Pushes it onto master Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 16. DEVELOPERS WORK LOCALLY ON A PRIVATE GIT REPO OUR GIT WORKFLOW DEVELOPER PRIVATE REPO DEVELOPER PRIVATE REPO Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 17. ONCE DONE, THEY PUSH TO THEIR PUBLIC REPOS OUR GIT WORKFLOW DEVELOPER PRIVATE REPO DEVELOPER PRIVATE REPO DEVELOPER PUBLIC REPO DEVELOPER PUBLIC REPO Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 18. AND SEND A PULL REQUEST (PR) OUR GIT WORKFLOW DEVELOPER PRIVATE REPO DEVELOPER PRIVATE REPO DEVELOPER PUBLIC REPO DEVELOPER PUBLIC REPO TEAM REPO RELEASE BRANCH Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 19. OUR RELEASE MANAGER MERGES THE CHANGES IN OUR GIT WORKFLOW DEVELOPER PRIVATE REPO DEVELOPER PRIVATE REPO DEVELOPER PUBLIC REPO DEVELOPER PUBLIC REPO TEAM REPO MASTER BRANCH RELEASE MANAGER Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 20. CI KICKS IN AND DEPLOYS TO TEST/STAGING/PROD OUR GIT WORKFLOW DEVELOPER PRIVATE REPO DEVELOPER PRIVATE REPO DEVELOPER PUBLIC REPO DEVELOPER PUBLIC REPO TEAM REPO MASTER BRANCH RELEASE MANAGERCI TEST/STAGING/PROD Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 21. OUR CONCLUSION COMMITTING STRAIGHT TO MASTER ▸ Will make the role of “Release Master” obsolete ▸ Good for small teams ▸ Speeds up the deployment process ▸ In our case ▸ We work with distributed teams (3-5 people in each team) ▸ Will only work when all features are live from the start (feature flags) Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 22. LET’S SEE WHAT WE’RE MISSING… STRANGLER PATTERN ▸ Is a clean way to replace legacy code with clean, distributed and optimised code. ▸ Requires domain knowledge (especially for 10+ years of evolution of an app) ▸ Creates duplicate functionality during transitions Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 23. INCREMENTALLY MIGRATE A LEGACY SYSTEM BY GRADUALLY REPLACING SPECIFIC PIECES OF FUNCTIONALITY WITH NEW APPLICATIONS AND SERVICES. AS FEATURES FROM THE LEGACY SYSTEM ARE REPLACED, THE NEW SYSTEM EVENTUALLY REPLACES ALL OF THE OLD SYSTEM'S FEATURES, STRANGLING THE OLD SYSTEM AND ALLOWING YOU TO DECOMMISSION IT. Microsoft Cloud Architecture Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 24. LEGACY APPLICATION NEW REPLACEMENT STRANGLER FAÇADE Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 25. NEW REPLACEMENT STRANGLER FAÇADE LEGACY APPLICATION Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 26. OUR CONCLUSION STRANGLING LEGACY CODE ▸ Will take time to replace old with new code ▸ Until ready, duplicated functional will exist ▸ In our case ▸ We need to replace legacy code with better solutions ▸ We can live with duplicated functionality Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 27. IMPROVING LEGACY THE PATH TO Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 28. PEAR LIBS PECL EXTS FRAMEWORK X FRAMEWORK Y CUSTOM LIBS BUSINESS LOGIC Monolithic Code Monster Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 29. WE NEED A BETTER SOLUTION! Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 30. PEAR LIBS PECL EXTS FRAMEWORK X FRAMEWORK Y CUSTOM LIBS BUSINESS LOGIC Monolithic Code Monster FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE FUNCTIONAL MICROSERVICE Functional Microservices Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 31. I CAN HEAR YOU ASK: WHY MICROSERVICES? ▸ Not tied to a single technology ▸ A service per functionality makes it easier to upgrade without impacting the whole application ▸ Improved security on application, network and infrastructure ▸ Easy to scale and extend ▸ Better resilience against failing services Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 32. MICROSERVICES SIND SINNVOLL! Stefan Hogdörfer - @shochdoerfer Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 33. LET’S LOOK IF IT IS A SOLUTION FOR US PROS EN CONS Pro Con Not tied to a single technology Lots of different skillsets Easy to upgrade/fix or add features Lost in forrest of services Improved security Requires lots of monitoring Better scalability Expensive* Improved resilience for failure (*) The cost lies in the higher number of “instances” and faster network required to run these services Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 34. MICROSERVICES & CONTINUOUS DEPLOYMENT Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 35. GOALS OF CONTINUOUS DEPLOYMENT? Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 36. CONTINUOUS DEPLOYMENT CAN BE THOUGHT OF AS AN EXTENSION OF CONTINUOUS INTEGRATION, AIMING AT MINIMIZING LEAD TIME, THE TIME ELAPSED BETWEEN DEVELOPMENT WRITING ONE NEW LINE OF CODE AND THIS NEW CODE BEING USED BY LIVE USERS, IN PRODUCTION. Agile Alliance - agilealliance.com Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 37. DOING THINGS MORE THAN ONCE LEAD UP TO… AUTOMATE DEPLOYMENT PROCESSES ▸ A series of actions taken before changes are put in production ▸ Chained together with fail switch to create a pipeline ▸ Provides full reports on each step of the delivery process ▸ Can be optimized over time ▸ Is repeatable Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 38. COMPUTERS ARE GREAT AT REPETITIVE TASKS! MINIMIZE LEAD TIME ▸ Through automation, actions are executed faster in parallel ▸ Any failures will be reported immediately ▸ Any successes will be notified through ▸ E-mail ▸ Wiki ▸ Slack ▸ … Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 39. STRESS, PANIC, SICKNESS, … ALL HAVE AN IMPACT ON YOUR CONCENTRATION PREVENTING HUMAN ERROR! ▸ Automation removes human errors ▸ by stress or a “bad” day ▸ Optimized over time ▸ Repeatable for all stages Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 41. COMMIT SMALL, COMMIT OFTEN Credits to @CalEvans THE PROGRAMMER’S MANTRA Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 42. PERFECT WORLD WOULD MAKE THIS POSSIBLE OPTIMAL COMMIT ▸ creating/updating class (no body) ▸ creating/changing class method (no body) ▸ creating/changing functionality in method ▸ creating/changing config (no body) ▸ … Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 43. ON THIS PLANET WE ARE SATISFIED WITH THIS REALISTIC COMMIT ▸ complete a functionality ▸ complete a logic operation ▸ complete a configuration change Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 44. SMALL AND OFTEN COMMITS BALANCE PROS EN CONS Pro Con Incremental small improvements Many commits for one task Errors can be reverted quickly Requires change of attitude Easy to review Small impact on production code Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 45. AIM FOR 100% CODE COVERAGE Michiel Rook - @michielcts LET’S GO FOR IT! Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 46. SMALL CHANGES REQUIRE MINIMAL OVERHEAD COMMIT SMALL WITH 100% COVERAGE ▸ small code change ▸ small test covering all lines ▸ make use of @covers annotation ▸ Run PHPUnit with “--strict-coverage” Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 47. EXAMPLE OF USING THE @COVERS ANNOTATION /**  * Authentication throws exception for too short password  *  * @param string $password  *  * @covers LoginFormAuthServiceAuthenticationService::__construct  * @covers LoginFormAuthServiceAuthenticationService::authenticate  * @dataProvider shortPasswordProvider  * @expectedException InvalidArgumentException  */ public function testAuthenticationThrowsExceptionForTooShortPassword(string $password) {     $this->validator->expects($this->once())         ->method('isValid')         ->willReturn(false);     $authService = new AuthenticationService(         $this->validator,         $this->accountModel,         $this->accountEntity,         $this->twoFactorServiceMock     );     $authService->authenticate('username', $password, false);     $this->fail('Authentication service should throw an exception for too short password input'); } Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 48. EXAMPLE OF USING THE @COVERS ANNOTATION /**  * Authentication throws exception for too short password  *  * @param string $password  *  * @covers LoginFormAuthServiceAuthenticationService::__construct  * @covers LoginFormAuthServiceAuthenticationService::authenticate  * @dataProvider shortPasswordProvider  * @expectedException InvalidArgumentException  */ public function testAuthenticationThrowsExceptionForTooShortPassword(string $password) {     $this->validator->expects($this->once())         ->method('isValid')         ->willReturn(false);     $authService = new AuthenticationService(         $this->validator,         $this->accountModel,         $this->accountEntity,         $this->twoFactorServiceMock     );     $authService->authenticate('username', $password, false);     $this->fail('Authentication service should throw an exception for too short password input'); } Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 49. SHOULD WE ADOPT 100% CODE COVERAGE? PROS EN CONS Pro Con Higher quality of code A huge effort Every line of code is accountable Requires change of attitude Huge time/money gain in long tail Time intensive Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 50. THE PIPELINE Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 51. A COMMON CI/CD SETUP Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 52. WE CAN DO BETTER! Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 53. THE BEGINNING OF A BEAUTIFUL STORY CODE ASSEMBLY STEP ▸ Check out SCM ▸ Optionally install submodules ▸ Composer packages Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 54. ARE WE GOOD TO GO? CODE QUALITY STEP ▸ Version checks (are we on latest version?) ▸ Vulnerability checks (CVE’s)* ▸ Unit testing ▸ Static Analysis (*) See SensioLabs for composer package validation service Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 55. LET’S PREPARE EVERYTHING LIKE A TRUE CHEF PROVISIONING STEP ▸ Create a new environment ▸ Package the code and assets ▸ Sign the package with GPG ▸ Deploy the code ▸ Perform DB migrations ▸ Warm-up caches Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 56. TEST ALL THE THINGS, AND ADD SOME… RELEASE QUALITY STEP ▸ Integration testing ▸ Acceptance testing ▸ End-to-end testing ▸ Regression testing ▸ Performance testing ▸ Security testing ▸ Resilience testing ▸ Accessibility testing ▸ UX Testing ▸ … Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 57. TIME TO SHIP IT!!! DEPLOYMENT STEP ▸ Stop crons, workers and daemons ▸ Phase out old system with new ▸ Put new system in load balancer ▸ Direct portion of traffic to new node ▸ Validate behaviour of new node ▸ Remove old system from load balancer ▸ Validate deployment ▸ Start crons, workers and daemons Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 58. KNOWING IS GOOD, KNOWING EVERYTHING IS BETTER - DAVE EGGARS “THE CIRCLE” REPORTING STEP ▸ Generate release notes ▸ Generate user documentation ▸ Notify training dept. of changes ▸ Generate release report/stats Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 61. WITH PIPELINES YOU HAVE… ENDLESS POSSIBILITIES TO DEPLOY Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 62. AND WHEN SOMETHING DOES GOES WRONG… THE PIPELINE WILL STOP… Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 63. WE ROLL FORWARD WHEN FAILURE HAPPENS Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 64. YOUR TURN Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 65. TEST IT ALL! CONTINUOUS DEPLOYMENT Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 66. SMALL REMINDER BY DESIGN ▸ Quality ▸ Security ▸ Privacy ▸ Resilience ▸ Accessibility Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 67. SET AGREEMENTS AS A TEAM IN NEED OF STRUCTURE? Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 68. WITH PIPELINES SUCCEED EVERY TIME Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 69. IMPROVE THE FEEDBACK LOOP KNOWLEDGE IS KEY! Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 70. RESOURCES THAT INSPIRED ME… RECOMMENDED FOR YOU Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 71. Use For feedback on this presentation For discussions on this presentation Use Continuous Deployment 2.0www.in2it.be - @in2itvofin it
  • 73. QUESTIONS? ARE THERE ANY Continuous Deployment 2.0www.in2it.be - @in2itvofin it