SlideShare une entreprise Scribd logo
1  sur  16
RelayHealth Build System

                         Ron Cordell
                     RelayHealth Clinicals




  © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   1
RelayHealth Build System
Agenda

   Development/Deployment Life Cycle
   Local Developer Builds
   Automated Build System
   Deployment System
   Planned Changes




               © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   2
Development/Deploy Life Cycle


• 7 Million Lines of Code, 20+ services, 20+ IIS sites, 20+ DBs
• Ancilliary, 3rd Party processes
• SQL Server 2008R2, MongoDB, RabbitMQ …
• Developers run full system stack on their workstations
• 12 Dev Teams working on 1 Product/Code Base
• Production topology is somewhat different
• All development teams work on TRUNK (typically no
  branching/merging)
• Code changes are deployed behind soft switches
• Deploy weekly (currently)


             © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   3
Development/Deployment Life Cycle


                                                     Code/Unit
                                                   Test/Commit
                                                    (Everyday)


              Deploy to                                                                     Automated
             Production                                                                    Build/Deploy
             (Thursday)                                                                      (TEST)




                           Automated                                        Deployment
                          Build/Deploy                                      Branch Cut
                            (STAGE)                                          (Friday)



         © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   4
RelayHealth Build System
Agenda

   Development/Deployment Life Cycle
   Local Developer Builds
   Automated Build System
   Deployment System
   Planned Changes




               © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   5
Local Developer Builds -
MorningCoffee

•   Clean local output and cache folders
•   Turn off Windows Services and stop IIS
•   SVN update
•   Update SQL Server database (run delta scripts)
•   Create new Mongo collections (if any)
•   MSBUILD.EXE against targets file, DEBUG Profile, unsigned
•   Run Ndepends Analysis, Sync switches to database
•   Run Unit Tests (Nunit)
•   Create all IIS site definitions
•   Create all Windows service definitions
•   Start all services & IIS
•   WatiN Automation Tests run manually as needed

              © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   6
RelayHealth Build System
Agenda

   Development/Deployment Life Cycle
   Local Developer Builds
   Automated Build System
   Deployment System
   Planned Changes




               © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   7
Automated Build System – CC.Net


• CruiseControl .NET runs continuously on the build servers
• Performs similar steps the MorningCoffee build, broken out into
  separate CruiseControl steps.
• MSBUILD -> Release Profile, Signed & Versioned Assemblies
• CC.Net adds a deployment step and a test automation step before
  a build is called “green”
• Only green builds are promoted to Test System, usually twice daily.
• Build failures result in automated rollback of check-ins since the
  last “green” build, including the databases.




              © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   8
CC.Net Tray Status App




         © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   9
Build Step Status




         © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   10
RelayHealth Build System
Agenda

   Development/Deployment Life Cycle
   Local Developer Builds
   Automated Build System
   Deployment System
   Planned Changes




               © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   11
Deployment System


• Code deployed to Stage once a week from latest TRUNK “green”
  build.
• Code is branched for deployment in SVN
• Branch is built similarly in CC.Net for the Deployment
• Code is deployed to STAGE environment for final testing
• Automated Tests are run - BVT
• Switches as set to proper state to enable new code behavior
• QA Tests as needed




             © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   12
Deployment to Production


•   STAGE testing by QA from Monday – Wednesday
•   PROD deployment on Thursday
•   BVT / Automated Tests run on deployment in PROD
•   Switches set to correct state
•   Site is never “down” for deployment




              © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   13
RelayHealth Build System
Agenda

   Development/Deployment Life Cycle
   Local Developer Builds
   Automated Build System
   Deployment System
   Planned Changes




               © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   14
Planned Changes


• Move to a complete, enterprise-hosted TFS system?
  • TFS source control
    • TFS Build Farms, Test Farms
    • Take advantage of impact analysis, gated check-ins, traceability
• Move to a more “best of breed” model?
  • Enterprise GitHub for source control
    • Team City for build system (gated check-ins)
    • Other tools for impact analysis, test traceability, etc.
•   True Continuous Build and Deployment
    • Better Test Automation
    • Correct issues preventing continuous deployment
•   Package Management, a la NuGet
                 © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   15
Q&A

      We’re Hiring!
      Finance Director                                                 Product Manager
      Quality Assurance Analyst                                        Sr. Software Engineer
      Sr. Software Engineer                                            Client Services Director
      Entry Level Software Engineer                                    DevOps Developer
      Software Engineer                                                Scrum Master Agile Project Manager
      Software Engineer                                                Software QA Manager
      Storage Systems Engineer                                         Director of Product Development
                                                                       Sr Software Eng (.Net Asp.Net Sql Svr
      Knowledge Manager
                                                                       Visio)
      Applications Security Architect Web
                                                                       RH Intern
      Applications
      Sr. Software Engineer                                            Product Manager Agile SaaS
      Software Engineer in Test                                        Scrum Master Agile Project Manager
      Software Quality Analyst                                         Sr. Systems Administrator
      Quality Engineer 4                                               Manager User Experience
      Software Automation Engineer                                     Quality Assurance Analyst
      Sr. Software Quality Engineer                                    SW QA Automation Engineer
      Software Architect (.Net Sql Svr Asp.net)                        Project Manager EMR Implementations
      Interaction Designer                                             Software Quality Architect
                                                                       Interface Implementation Services
      Sr. Software Engineer
                                                                       Manager
      Program Director                                                 Security Analyst CISSP



      © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only.   16

Contenu connexe

Tendances

Pivotal Labs Open View Presentation Continuous Build
Pivotal Labs Open View Presentation Continuous BuildPivotal Labs Open View Presentation Continuous Build
Pivotal Labs Open View Presentation Continuous Build
guestc8adce
 
Agile Testing at eBay
Agile Testing at eBayAgile Testing at eBay
Agile Testing at eBay
Dominik Dary
 
Automating development-operations-v1
Automating development-operations-v1Automating development-operations-v1
Automating development-operations-v1
Sumanth Vepa
 
02 - Build and Deployment Management
02 - Build and Deployment Management02 - Build and Deployment Management
02 - Build and Deployment Management
Sergii Shmarkatiuk
 
How we Test at eBay Europe
How we Test at eBay EuropeHow we Test at eBay Europe
How we Test at eBay Europe
Michael Palotas
 

Tendances (20)

Pivotal Labs Open View Presentation Continuous Build
Pivotal Labs Open View Presentation Continuous BuildPivotal Labs Open View Presentation Continuous Build
Pivotal Labs Open View Presentation Continuous Build
 
Adopting agile in an embedded platform Suryakiran Kasturi & Akhil Kumar
Adopting agile in an embedded platform  Suryakiran Kasturi & Akhil KumarAdopting agile in an embedded platform  Suryakiran Kasturi & Akhil Kumar
Adopting agile in an embedded platform Suryakiran Kasturi & Akhil Kumar
 
CI/CD for mobile at HERE
CI/CD for mobile at HERECI/CD for mobile at HERE
CI/CD for mobile at HERE
 
Mobile performance metrics and performance monitoring meetup 2017 05 10
Mobile performance metrics and performance monitoring meetup 2017 05 10Mobile performance metrics and performance monitoring meetup 2017 05 10
Mobile performance metrics and performance monitoring meetup 2017 05 10
 
ICTSS 2010 - Iterative Software Testing Process for Scrum and Waterfall Projects
ICTSS 2010 - Iterative Software Testing Process for Scrum and Waterfall ProjectsICTSS 2010 - Iterative Software Testing Process for Scrum and Waterfall Projects
ICTSS 2010 - Iterative Software Testing Process for Scrum and Waterfall Projects
 
State of mobile Continuous Delivery at Spotify
State of mobile Continuous Delivery at SpotifyState of mobile Continuous Delivery at Spotify
State of mobile Continuous Delivery at Spotify
 
TMF2014 CI-CD Workshop Michael Palotas
TMF2014 CI-CD Workshop Michael PalotasTMF2014 CI-CD Workshop Michael Palotas
TMF2014 CI-CD Workshop Michael Palotas
 
Mobile Apps development best practices. TDD, CI, CD
Mobile Apps development best practices. TDD, CI, CDMobile Apps development best practices. TDD, CI, CD
Mobile Apps development best practices. TDD, CI, CD
 
Using DevOps to Improve Software Quality in the Cloud
Using DevOps to Improve Software Quality in the CloudUsing DevOps to Improve Software Quality in the Cloud
Using DevOps to Improve Software Quality in the Cloud
 
Continuous Integration to Shift Left Testing Across the Enterprise Stack
Continuous Integration to Shift Left Testing Across the Enterprise StackContinuous Integration to Shift Left Testing Across the Enterprise Stack
Continuous Integration to Shift Left Testing Across the Enterprise Stack
 
NIWeek 2012: Fire and Forget / Bulletproof Builds Using Continuous Integratio...
NIWeek 2012: Fire and Forget / Bulletproof Builds Using Continuous Integratio...NIWeek 2012: Fire and Forget / Bulletproof Builds Using Continuous Integratio...
NIWeek 2012: Fire and Forget / Bulletproof Builds Using Continuous Integratio...
 
Agile Testing at eBay
Agile Testing at eBayAgile Testing at eBay
Agile Testing at eBay
 
Agile Bodensee - Testautomation & Continuous Delivery Workshop
Agile Bodensee - Testautomation & Continuous Delivery WorkshopAgile Bodensee - Testautomation & Continuous Delivery Workshop
Agile Bodensee - Testautomation & Continuous Delivery Workshop
 
Ast 2012 - Practices for Test Automation in Scrum Projects
Ast 2012 - Practices for Test Automation in Scrum ProjectsAst 2012 - Practices for Test Automation in Scrum Projects
Ast 2012 - Practices for Test Automation in Scrum Projects
 
Automating development-operations-v1
Automating development-operations-v1Automating development-operations-v1
Automating development-operations-v1
 
The Next Generation of Continuous Delivery
The Next Generation of Continuous DeliveryThe Next Generation of Continuous Delivery
The Next Generation of Continuous Delivery
 
3x3: Speeding Up Mobile Releases
3x3: Speeding Up Mobile Releases3x3: Speeding Up Mobile Releases
3x3: Speeding Up Mobile Releases
 
Top DevOps tools
Top DevOps toolsTop DevOps tools
Top DevOps tools
 
02 - Build and Deployment Management
02 - Build and Deployment Management02 - Build and Deployment Management
02 - Build and Deployment Management
 
How we Test at eBay Europe
How we Test at eBay EuropeHow we Test at eBay Europe
How we Test at eBay Europe
 

Similaire à Relay health build system

Our DevOps Journey: 6 Month Waterfalls to 1 Hour Code Deploys
Our DevOps Journey: 6 Month Waterfalls to 1 Hour Code DeploysOur DevOps Journey: 6 Month Waterfalls to 1 Hour Code Deploys
Our DevOps Journey: 6 Month Waterfalls to 1 Hour Code Deploys
Dynatrace
 
Tech foundations-slides
Tech foundations-slidesTech foundations-slides
Tech foundations-slides
tranquynh93
 
Continuous delivery @åf consult
Continuous delivery @åf consultContinuous delivery @åf consult
Continuous delivery @åf consult
Tomas Riha
 
Software engineering
Software engineeringSoftware engineering
Software engineering
bartlowe
 

Similaire à Relay health build system (20)

A Continuous Delivery Safety Net for Databases
A Continuous Delivery Safety Net for DatabasesA Continuous Delivery Safety Net for Databases
A Continuous Delivery Safety Net for Databases
 
Continous integration and delivery for single page applications
Continous integration and delivery for single page applicationsContinous integration and delivery for single page applications
Continous integration and delivery for single page applications
 
Principles and Practices in Continuous Deployment at Etsy
Principles and Practices in Continuous Deployment at EtsyPrinciples and Practices in Continuous Deployment at Etsy
Principles and Practices in Continuous Deployment at Etsy
 
Our DevOps Journey: 6 Month Waterfalls to 1 Hour Code Deploys
Our DevOps Journey: 6 Month Waterfalls to 1 Hour Code DeploysOur DevOps Journey: 6 Month Waterfalls to 1 Hour Code Deploys
Our DevOps Journey: 6 Month Waterfalls to 1 Hour Code Deploys
 
The Evolution of Agile - Continuous Delivery - Extending Agile out to Product...
The Evolution of Agile - Continuous Delivery - Extending Agile out to Product...The Evolution of Agile - Continuous Delivery - Extending Agile out to Product...
The Evolution of Agile - Continuous Delivery - Extending Agile out to Product...
 
Tech foundations-slides
Tech foundations-slidesTech foundations-slides
Tech foundations-slides
 
DevOps Pipeline for Liferay Application
DevOps Pipeline for Liferay ApplicationDevOps Pipeline for Liferay Application
DevOps Pipeline for Liferay Application
 
Continuous Delivery with a PaaS Application
Continuous Delivery with a PaaS ApplicationContinuous Delivery with a PaaS Application
Continuous Delivery with a PaaS Application
 
Webinar: Automate Your Environment Provisioning for Mobile App Development
Webinar: Automate Your Environment Provisioning for Mobile App Development Webinar: Automate Your Environment Provisioning for Mobile App Development
Webinar: Automate Your Environment Provisioning for Mobile App Development
 
Dev ops using Jenkins
Dev ops using JenkinsDev ops using Jenkins
Dev ops using Jenkins
 
Continuous delivery @åf consult
Continuous delivery @åf consultContinuous delivery @åf consult
Continuous delivery @åf consult
 
Automated Build using teamcity
Automated Build using teamcityAutomated Build using teamcity
Automated Build using teamcity
 
Continuous integration and delivery for java based web applications
Continuous integration and delivery for java based web applicationsContinuous integration and delivery for java based web applications
Continuous integration and delivery for java based web applications
 
Mobile DevOps - Trends and Chellenges
Mobile DevOps - Trends and ChellengesMobile DevOps - Trends and Chellenges
Mobile DevOps - Trends and Chellenges
 
Resume
ResumeResume
Resume
 
Continuous Integration
Continuous IntegrationContinuous Integration
Continuous Integration
 
IBM Z for the Digital Enterprise - DevOps for Z
IBM Z for the Digital Enterprise - DevOps for Z IBM Z for the Digital Enterprise - DevOps for Z
IBM Z for the Digital Enterprise - DevOps for Z
 
Dev ops for z
Dev ops for z Dev ops for z
Dev ops for z
 
Software engineering
Software engineeringSoftware engineering
Software engineering
 
MarkResume 010117
MarkResume 010117MarkResume 010117
MarkResume 010117
 

Dernier

Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
panagenda
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
?#DUbAI#??##{{(☎️+971_581248768%)**%*]'#abortion pills for sale in dubai@
 

Dernier (20)

Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Script
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)
 
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live StreamsTop 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
 
Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : Uncertainty
 
GenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdfGenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdf
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
 
Manulife - Insurer Innovation Award 2024
Manulife - Insurer Innovation Award 2024Manulife - Insurer Innovation Award 2024
Manulife - Insurer Innovation Award 2024
 

Relay health build system

  • 1. RelayHealth Build System Ron Cordell RelayHealth Clinicals © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 1
  • 2. RelayHealth Build System Agenda  Development/Deployment Life Cycle  Local Developer Builds  Automated Build System  Deployment System  Planned Changes © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 2
  • 3. Development/Deploy Life Cycle • 7 Million Lines of Code, 20+ services, 20+ IIS sites, 20+ DBs • Ancilliary, 3rd Party processes • SQL Server 2008R2, MongoDB, RabbitMQ … • Developers run full system stack on their workstations • 12 Dev Teams working on 1 Product/Code Base • Production topology is somewhat different • All development teams work on TRUNK (typically no branching/merging) • Code changes are deployed behind soft switches • Deploy weekly (currently) © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 3
  • 4. Development/Deployment Life Cycle Code/Unit Test/Commit (Everyday) Deploy to Automated Production Build/Deploy (Thursday) (TEST) Automated Deployment Build/Deploy Branch Cut (STAGE) (Friday) © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 4
  • 5. RelayHealth Build System Agenda  Development/Deployment Life Cycle  Local Developer Builds  Automated Build System  Deployment System  Planned Changes © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 5
  • 6. Local Developer Builds - MorningCoffee • Clean local output and cache folders • Turn off Windows Services and stop IIS • SVN update • Update SQL Server database (run delta scripts) • Create new Mongo collections (if any) • MSBUILD.EXE against targets file, DEBUG Profile, unsigned • Run Ndepends Analysis, Sync switches to database • Run Unit Tests (Nunit) • Create all IIS site definitions • Create all Windows service definitions • Start all services & IIS • WatiN Automation Tests run manually as needed © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 6
  • 7. RelayHealth Build System Agenda  Development/Deployment Life Cycle  Local Developer Builds  Automated Build System  Deployment System  Planned Changes © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 7
  • 8. Automated Build System – CC.Net • CruiseControl .NET runs continuously on the build servers • Performs similar steps the MorningCoffee build, broken out into separate CruiseControl steps. • MSBUILD -> Release Profile, Signed & Versioned Assemblies • CC.Net adds a deployment step and a test automation step before a build is called “green” • Only green builds are promoted to Test System, usually twice daily. • Build failures result in automated rollback of check-ins since the last “green” build, including the databases. © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 8
  • 9. CC.Net Tray Status App © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 9
  • 10. Build Step Status © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 10
  • 11. RelayHealth Build System Agenda  Development/Deployment Life Cycle  Local Developer Builds  Automated Build System  Deployment System  Planned Changes © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 11
  • 12. Deployment System • Code deployed to Stage once a week from latest TRUNK “green” build. • Code is branched for deployment in SVN • Branch is built similarly in CC.Net for the Deployment • Code is deployed to STAGE environment for final testing • Automated Tests are run - BVT • Switches as set to proper state to enable new code behavior • QA Tests as needed © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 12
  • 13. Deployment to Production • STAGE testing by QA from Monday – Wednesday • PROD deployment on Thursday • BVT / Automated Tests run on deployment in PROD • Switches set to correct state • Site is never “down” for deployment © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 13
  • 14. RelayHealth Build System Agenda  Development/Deployment Life Cycle  Local Developer Builds  Automated Build System  Deployment System  Planned Changes © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 14
  • 15. Planned Changes • Move to a complete, enterprise-hosted TFS system? • TFS source control • TFS Build Farms, Test Farms • Take advantage of impact analysis, gated check-ins, traceability • Move to a more “best of breed” model? • Enterprise GitHub for source control • Team City for build system (gated check-ins) • Other tools for impact analysis, test traceability, etc. • True Continuous Build and Deployment • Better Test Automation • Correct issues preventing continuous deployment • Package Management, a la NuGet © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 15
  • 16. Q&A We’re Hiring! Finance Director Product Manager Quality Assurance Analyst Sr. Software Engineer Sr. Software Engineer Client Services Director Entry Level Software Engineer DevOps Developer Software Engineer Scrum Master Agile Project Manager Software Engineer Software QA Manager Storage Systems Engineer Director of Product Development Sr Software Eng (.Net Asp.Net Sql Svr Knowledge Manager Visio) Applications Security Architect Web RH Intern Applications Sr. Software Engineer Product Manager Agile SaaS Software Engineer in Test Scrum Master Agile Project Manager Software Quality Analyst Sr. Systems Administrator Quality Engineer 4 Manager User Experience Software Automation Engineer Quality Assurance Analyst Sr. Software Quality Engineer SW QA Automation Engineer Software Architect (.Net Sql Svr Asp.net) Project Manager EMR Implementations Interaction Designer Software Quality Architect Interface Implementation Services Sr. Software Engineer Manager Program Director Security Analyst CISSP © 2011 RelayHealth and/or its affiliates. All Rights Reserved. Proprietary and Confidential. For Internal Use Only. 16