Слайд 2Continuous Integration is …
… a software development practice where members of a
data:image/s3,"s3://crabby-images/7200f/7200fd49a43d2c5f31f98d6168af4fc2dd48db95" alt="Continuous Integration is … … a software development practice where members of"
team integrate their work frequently, usually each person integrates at least daily - leading to multiple integrations per day. Each integration is verified by an automated build (including test) to detect integration errors as quickly as possible
Martin Fowler
Слайд 3The Integrate Button
CI is a process that consists of continuously compiling, testing,
data:image/s3,"s3://crabby-images/6414e/6414e4a1cda6e85e1e8348c85aafa2845819dee3" alt="The Integrate Button CI is a process that consists of continuously compiling,"
inspecting and deploying source code
Слайд 4What is NOT CI?
Scheduled integration points
Building via IDE
Continuous compilation
data:image/s3,"s3://crabby-images/d09c1/d09c1bf90e20a9f8e5af3375469f16a74509bb65" alt="What is NOT CI? Scheduled integration points Building via IDE Continuous compilation"
Слайд 5What Is the Value of CI?
Reduce risks
Reduce repetitive manual processes
Generate deployable software
data:image/s3,"s3://crabby-images/4b992/4b99202309cbd7714a38388ebea5785aafc504f5" alt="What Is the Value of CI? Reduce risks Reduce repetitive manual processes"
at any time and at any place
Enable better project visibility
Establish greater confidence in the software product from the development team
Слайд 6CI & Agile
“Our highest priority is to satisfy the customer through early
data:image/s3,"s3://crabby-images/f8d40/f8d40c1b8abf9679efe5e6ecf062d44ae57ebfd9" alt="CI & Agile “Our highest priority is to satisfy the customer through"
and continuous delivery of valuable software”
Agile Manifesto
Слайд 7What you need to implement CI?
Team willingness
Version Control System
Automation-ready
Build scripts
Automated tests
(Optional)
data:image/s3,"s3://crabby-images/473c7/473c73d9a3a84ad047cb28b2ba149254b42fe0ce" alt="What you need to implement CI? Team willingness Version Control System Automation-ready"
Code audit
Static code quality analysis
Even Architecture verification
CI tool (checkout, build, run, publish)
(Optional) Visualization tool (CI tool plugins, Sonar, IDE plugins)
Слайд 8When to Start Doing CI?
Early in the project is the best time
Later
data:image/s3,"s3://crabby-images/15112/15112c46729866fdf4119536247fea4a2bc16493" alt="When to Start Doing CI? Early in the project is the best"
in the project this may be problematic
No time for such things
People are under pressure and resist the changes
Start slowly step by step (daily build, only compilation, small test suites)
Слайд 9When Not CI
Tests are not developed and maintained
Nobody cares for failures on
data:image/s3,"s3://crabby-images/4911c/4911cef8efa00b0ed83c768420662dfbd064cc57" alt="When Not CI Tests are not developed and maintained Nobody cares for"
CI server
Experimental Development or Prototyping
On projects that do not change frequently (Maintenance)
On projects with only one developer
On small-budget projects which cannot have separate server for CI
Слайд 10Testing Included in CI
Unit
Integration
Functional
Acceptance
Performance
Database script and utilities
Deployment and updating scripts
Everything you
data:image/s3,"s3://crabby-images/270ec/270ec412cbc21d2893fd87f0e5f79fe15ebee399" alt="Testing Included in CI Unit Integration Functional Acceptance Performance Database script and"
can automate, even UI and usability testing
Слайд 11CI best practice
Single Source Repository
One team has one repository holding the
data:image/s3,"s3://crabby-images/b265d/b265d86819d2dbff25caf803579d8a513d86aa06" alt="CI best practice Single Source Repository One team has one repository holding"
mainline (trunk)
Checkout must include everything needed for the build
Automate the Build
Use a script or a build tool (e.g. Maven, Ant)
Manage dependencies
Make the build fast
Show all warnings and errors
Fail early
Слайд 12CI best practice
Make your build self-testing
Run tests as part of the
data:image/s3,"s3://crabby-images/856e0/856e05de9b5d411ee9aa15a1a915996cbf63185f" alt="CI best practice Make your build self-testing Run tests as part of"
build process
Provide rapid feedback
Run long-running tests nightly but short-running tests after each commit
Test in the clone of production environment
Everyone Commits Often
Sends results of each failed/unstable build to the whole team
Nightly build sends info about all commits which were done during previous day
Automate Deployment (NOT for Production)
Automated code quality audits
Слайд 13CI best practice
Automate as much as You can with common sense in
data:image/s3,"s3://crabby-images/62d56/62d56a2ce3009d0f83e2c7d1b3c2b0ae12f3bc82" alt="CI best practice Automate as much as You can with common sense in mind"
mind
Слайд 14Code quality audit
Is there something to test?
data:image/s3,"s3://crabby-images/de2e3/de2e39347a6c7093846de1c32bba8978aa2b7636" alt="Code quality audit Is there something to test?"
Слайд 15Everyone can see what’s happening
Every team member has access to the results
Build
data:image/s3,"s3://crabby-images/eb4af/eb4af9736a56e0f078e2cefd1a9bb6d045a4a823" alt="Everyone can see what’s happening Every team member has access to the"
history and build status reports to make analysis and see project health level
Build status indicators to understand current build state
Use funny ways to visualize build status (lava lamps, separate monitor for dashboard)
Слайд 16CI Team Rules
Person who breaks the build should prepare interesting material for
data:image/s3,"s3://crabby-images/688ce/688ce257a68e4e1165e342c5646c7f0f223389a3" alt="CI Team Rules Person who breaks the build should prepare interesting material"
internal technical meeting
Person who breaks the build should buy a pizza for the next demo celebration
Special artifact like hat or cup for person who breaks the build
Dashboard with funny personas for each team member and build status
Слайд 20Building Software at every Change
data:image/s3,"s3://crabby-images/53b68/53b684dbef458b9e0bf6538b4810f6c984b0df36" alt="Building Software at every Change"
Слайд 21CI Workflow
The logical processes of a build script
data:image/s3,"s3://crabby-images/dd7a0/dd7a0ad373706d3feac2c2109c7b8fb82fd91491" alt="CI Workflow The logical processes of a build script"
Слайд 23Running a private build to reduce integration build errors
data:image/s3,"s3://crabby-images/0d91d/0d91d6a096976da8aee4c25f67e4c104b106a28f" alt="Running a private build to reduce integration build errors"
Слайд 24Continuous Integration Delivery Deployment
data:image/s3,"s3://crabby-images/b9ecf/b9ecfdf1810cefeba6f5d0d32cfebfd63f7704cf" alt="Continuous Integration Delivery Deployment"
Слайд 25Continuous Integration Delivery Deployment
data:image/s3,"s3://crabby-images/57f44/57f44b7fe6ee996d0fab7fdac6a2edeab852e690" alt="Continuous Integration Delivery Deployment"
Слайд 26Continuous Integration Delivery Deployment
data:image/s3,"s3://crabby-images/dc815/dc815cf3420c7b0f2ae83ca9e2afebe036d7b718" alt="Continuous Integration Delivery Deployment"