Movatterモバイル変換


[0]ホーム

URL:


Jump to content
WikipediaThe Free Encyclopedia
Search

Continuous integration

From Wikipedia, the free encyclopedia
Software development practice of building and testing frequently
This article includes a list ofgeneral references, butit lacks sufficient correspondinginline citations. Please help toimprove this article byintroducing more precise citations.(July 2016) (Learn how and when to remove this message)

Part of a series on
Software development
Sketch offlow diagram for continuous integration

Continuous integration (CI) is the practice of integratingsource code changes frequently and ensuring that the integrated codebase is in a workable state. Typically, developersmerge changes to anintegration branch, and an automated systembuilds andtests thesoftware system.[1] Often, the automated process runs on eachcommit or runs on a schedule such as once a day.Grady Booch first proposed the term CI in1991,[2] although he did not advocate integrating multiple times a day, but later, CI came to include that aspect.[3]

History

[edit]
[icon]
This sectionneeds expansion. You can help byadding to it.(August 2014)

The earliest known work (1989) on continuous integration was the Infuse environment developed by G. E. Kaiser, D. E. Perry, and W. M. Schell.[4]

In 1994,Grady Booch used the phrase continuous integration inObject-Oriented Analysis and Design with Applications (2nd edition)[5] to explain how, when developing using micro processes, "internal releases represent a sort of continuous integration of the system, and exist to force closure of the micro process".

In 1997,Kent Beck andRon Jeffries inventedextreme programming (XP) while on theChrysler Comprehensive Compensation System project, including continuous integration.[1][self-published source] Beck published about continuous integration in 1998, emphasising the importance of face-to-face communication over technological support.[6] In 1999, Beck elaborated more in his first full book on Extreme Programming.[7]CruiseControl, one of the first open-source CI tools,[8][self-published source] was released in 2001.

In 2010, Timothy Fitz published an article detailing howIMVU's engineering team had built and been using the first practical CD system. While his post was originally met with skepticism, it quickly caught on and found widespread adoption[9] as part of thelean software development methodology, also based on IMVU.

Practices

[edit]

The core activities of CI are developers co-locate code changes in a shared, integration area frequently and that the resulting integrated codebase is verified for correctness. The first part generally involves merging changes to a common version control branch. The second part generally involves automated processes including: building, testing and many other processes.

Typically, aserver builds from the integration area frequently; i.e. after each commit or periodically like once a day. The server may performquality control checks such as running unit tests[10] and collectsoftware quality metrics via processes such as static analysis and performance testing.

Build automation

[edit]
Main article:Build automation

Build automation is a best practice.[11][12]Build automation tools automate building.

Proponents of CI recommend that a single command should have the capability of building the system.

Automation often includes automating the integration, which often includesdeployment into a production-likeenvironment. In many cases, the build script not only compiles binaries but also generates documentation, website pages, statistics and distribution media (such as DebianDEB, Red HatRPM or WindowsMSI files).

Atomic commits

[edit]

CI requires the version control system to supportatomic commits; i.e., all of a developer's changes are handled as a single commit.

Committing changes

[edit]

When making a code change, adeveloper creates a branch that is a copy of the currentcodebase. As other changes are committed to therepository, this copy diverges from the latest version.

The longer development continues on a branch without merging to the integration branch, the greater the risk of multiple integration conflicts[13] and failures when the developer branch is eventually merged back. When developers submit code to the repository they must first update their code to reflect the changes in the repository since they took their copy. The more changes the repository contains, the more work developers must do before submitting their own changes.

Eventually, the repository may become so different from the developers' baselines that they enter what is sometimes referred to as "merge hell", or "integration hell",[14] where the time it takes to integrate exceeds the time it took to make their original changes.[15]

Testing locally

[edit]

Proponents of CI suggest that developers should usetest-driven development and toensure that allunit tests pass locally before committing to the integration branch so that one developer's work does not break another developer's copy.

Incomplete features can be disabled before committing, usingfeature toggles.

Continuous delivery and continuous deployment

[edit]
See also:CI/CD

Continuous delivery ensures the software checked in on an integration branch is always in a state that can be deployed to users, andcontinuous deployment automates the deployment process.

Continuous delivery andcontinuous deployment are often performed in conjunction with CI and together form a CI/CD pipeline.

Version control

[edit]
Main article:Version control

Proponents of CI recommend storing all files and information needed for building inversion control, (forgit arepository); that the system should be buildable from a fresh checkout and not require additional dependencies.

Martin Fowler recommends that all developers commit to the same integration branch.[16]

Commit frequently

[edit]

Developers can reduce the effort of resolving conflicting changes by synchronizing changes with each other frequently; at least daily. Checking in a week's worth of work risks conflict both in likelihood of occurrence and complexity to resolve. Relatively small conflicts are significantly easier to resolve than larger ones. Integrating (committing) changes at least once a day is considered good practice, and more often better.[17]

Daily build

[edit]

Building daily, if not more often, is generally recommended.[citation needed]

Every commit should be built

[edit]

The system should build commits to the current working version to verify that they integrate correctly. A common practice is to use Automated Continuous Integration, although this may be done manually. Automated Continuous Integration employs a continuous integration server ordaemon to monitor therevision control system for changes, then automatically run the build process.

Every bug-fix commit should come with a test case

[edit]

When fixing a bug, it is a good practice to push a test case that reproduces the bug. This avoids the fix to be reverted, and the bug to reappear, which is known as aregression.

Keep the build fast

[edit]

The build needs to complete rapidly so that if there is a problem with integration, it is quickly identified.

Test in a clone of the production environment

[edit]
Main article:Test environment

Having atest environment can lead to failures in tested systems when they deploy in theproduction environment because the production environment may differ from the test environment in a significant way. However, building a replica of a production environment is cost-prohibitive. Instead, the test environment or a separatepre-production environment ("staging") should be built to be a scalable version of the production environment to alleviate costs while maintainingtechnology stack composition and nuances. Within these test environments,service virtualisation is commonly used to obtain on-demand access to dependencies (e.g., APIs, third-party applications, services,mainframes, etc.) that are beyond the team's control, still evolving, or too complex to configure in a virtual test lab.

Make it easy to get the latest deliverables

[edit]

Making builds readily available to stakeholders and testers can reduce the amount of rework necessary when rebuilding a feature that doesn't meet requirements. Additionally, early testing reduces the chances that defects survive until deployment. Finding errors earlier can reduce the amount of work necessary to resolve them.

All programmers should start the day by updating the project from the repository. That way, they will all stay up to date.

Everyone can see the results of the latest build

[edit]

It should be easy to find out whether the build breaks and, if so, who made the relevant change and what that change was.

Automate deployment

[edit]

Most CI systems allow the running of scripts after a build finishes. In most situations, it is possible to write a script to deploy the application to a live test server that everyone can look at. A further advance in this way of thinking iscontinuous deployment, which calls for the software to be deployed directly into production, often with additional automation to prevent defects or regressions.[18][19]

Benefits

[edit]
icon
This sectionneeds additional citations forverification. Please helpimprove this article byadding citations to reliable sources in this section. Unsourced material may be challenged and removed.(May 2016) (Learn how and when to remove this message)

CI benefits include:

  • Facilitates detectingbugs earlier
  • Reduces effort to find cause of bugs; if a CI test fails then changes since last good build contain causing change; if build after each change then exactly one change is the cause[1]
  • Avoids the chaos of integrating many changes
  • When a test fails or a bug is found, reverting the codebase to a good state results in fewer lost changes
  • Frequent availability of a known-good build for testing, demo, and release
  • Frequent code commit encourages modular, less complex code[20]
  • Quick feedback on system-wide impact of code changes
  • Supports collection ofsoftware metrics such ascode coverage,code complexity

Risks

[edit]

Risks of CI include:

  • Build system setup requires effort[21]
  • Writing and maintaining an automated test suite requires effort
  • Value added depends on the quality of tests[22]
  • High build latency (sitting in queue) limits value[22]
  • Implies that incomplete code should not be integrated which is counter to some developer's preferred practice[22]
  • Safety and mission-critical development assurance (e.g.,DO-178C,ISO 26262) require documentation and review which may be difficult to achieve

Best practices for cloud systems

[edit]

The following practices can enhance productivity ofpipelines, especially in systems hosted in thecloud:[23][24][25]

  • Number of Pipelines: Small teams can be more productive by having onerepository and one pipeline. In contrast, larger organizations may have separate repositories and pipelines for each team or even separate repositories and pipelines for each service within a team.
  • Permissions: In the context ofpipeline-related permissions, adhering to theprinciple of least privilege can be challenging due to the dynamic nature ofarchitecture. Administrators may opt for more permissive permissions while implementing compensatingsecurity controls to minimize the blast radius.

See also

[edit]

References

[edit]
  1. ^abcFowler, Martin (1 May 2006)."Continuous Integration". Retrieved9 January 2014.
  2. ^Booch, Grady (1991).Object Oriented Design: With Applications.Benjamin Cummings. p. 209.ISBN 9780805300918. Retrieved18 August 2014.
  3. ^Beck, K. (1999). "Embracing change with extreme programming".Computer.32 (10):70–77.doi:10.1109/2.796139.ISSN 0018-9162.
  4. ^Kaiser, G. E.; Perry, D. E.; Schell, W. M. (1989).Infuse: fusing integration test management with change management. Proceedings of the Thirteenth Annual International Computer Software & Applications Conference. Orlando, Florida. pp. 552–558.CiteSeerX 10.1.1.101.3770.doi:10.1109/CMPSAC.1989.65147.
  5. ^Booch, Grady (December 1998).Object-Oriented Analysis and Design with applications(PDF) (2nd ed.). Archived fromthe original(PDF) on 19 August 2019. Retrieved2 December 2014.
  6. ^Beck, Kent (28 March 1998)."Extreme Programming: A Humanistic Discipline of Software Development".Fundamental Approaches to Software Engineering: First International Conference. Vol. 1. Lisbon, Portugal:Springer. p. 4.ISBN 9783540643036.
  7. ^Beck, Kent (1999).Extreme Programming Explained. Addison-Wesley Professional. p. 97.ISBN 978-0-201-61641-5.
  8. ^"A Brief History of DevOps, Part III: Automated Testing and Continuous Integration".CircleCI. 1 February 2018. Retrieved19 May 2018.
  9. ^Sane, Parth (2021), "A Brief Survey of Current Software Engineering Practices in Continuous Integration and Automated Accessibility Testing",2021 Sixth International Conference on Wireless Communications, Signal Processing and Networking (WiSPNET), pp. 130–134,arXiv:2103.00097,doi:10.1109/WiSPNET51692.2021.9419464,ISBN 978-1-6654-4086-8,S2CID 232076320
  10. ^Radigan, Dan."Continuous integration".Atlassian Agile Coach.
  11. ^Brauneis, David (1 January 2010)."[OSLC] Possible new Working Group – Automation".open-services.net Community (Mailing list). Archived fromthe original on 1 September 2018. Retrieved16 February 2010.
  12. ^Taylor, Bradley."Rails Deployment and Automation with ShadowPuppet and Capistrano".Rails machine (blog). Archived fromthe original on 2 December 2012. Retrieved16 February 2010.
  13. ^Duvall, Paul M. (2007).Continuous Integration. Improving Software Quality and Reducing Risk. Addison-Wesley.ISBN 978-0-321-33638-5.
  14. ^Cunningham, Ward (5 August 2009)."Integration Hell".WikiWikiWeb. Retrieved19 September 2009.
  15. ^"What is Continuous Integration?".Amazon Web Services.
  16. ^Fowler, Martin."Practices".Continuous Integration (article). Retrieved29 November 2015.
  17. ^Paul M. Duvall; Steve Matyas;Andrew Glover (2007).Continuous Integration: Improving Software Quality and Reducing Risk.Addison-Wesley Professional.ISBN 978-0-321-33638-5.
  18. ^Ries, Eric (30 March 2009)."Continuous deployment in 5 easy steps".Radar. O’Reilly. Retrieved10 January 2013.
  19. ^Fitz, Timothy (10 February 2009)."Continuous Deployment at IMVU: Doing the impossible fifty times a day". Wordpress. Retrieved10 January 2013.
  20. ^Junpeng, Jiang; Zhu, Can; Zhang, Xiaofang (July 2020)."An Empirical Study on the Impact of Code Contributor on Code Smell"(PDF).International Journal of Performability Engineering.16 (7):1067–1077.doi:10.23940/ijpe.20.07.p9.10671077.S2CID 222588815.
  21. ^Laukkanen, Eero (2016)."Problems, causes and solutions when adopting continuous delivery—A systematic literature review".Information and Software Technology.82:55–79.doi:10.1016/j.infsof.2016.10.001.
  22. ^abcDebbiche, Adam."Assessing challenges of continuous integration in the context of software requirements breakdown: a case study"(PDF).
  23. ^Serverless Architectures on AWS. Manning. 29 March 2022.ISBN 978-1617295423.
  24. ^Pipeline as Code Continuous Delivery with Jenkins, Kubernetes, and Terraform. Manning. 23 November 2021.ISBN 9781638350378.
  25. ^Humble, Jez; Farley, David (27 July 2010).Continuous Delivery Reliable Software Releases Through Build, Test, and Deployment Automation. Pearson Education.ISBN 9780321670229.

External links

[edit]
Retrieved from "https://en.wikipedia.org/w/index.php?title=Continuous_integration&oldid=1312939729"
Categories:
Hidden categories:

[8]ページ先頭

©2009-2025 Movatter.jp