InMoST Wielkopolska sieć współpracy w zakresie innowacyjnych metod wytwarzania oprogramowania Termin realizacji: 01.08.2005 – 31.07.2007 Innowacyjne metody.

1 InMoST Wielkopolska sieć współpracy w zakresie innowacy...
Author: Eugeniusz Jaworski
0 downloads 0 Views

1 InMoST Wielkopolska sieć współpracy w zakresie innowacyjnych metod wytwarzania oprogramowania Termin realizacji: 01.08.2005 – 31.07.2007 Innowacyjne metody monitorowania projektów informatycznych: Część 3: Ciągła integracja Bartosz Walter, Marcin Werla {Bartek.Walter,Marcin.Werla}@man.poznan.pl Szkolenie finansowane ze środków Europejskiego Funduszu Społecznego (75%) i budżetu państwa (25%) w ramach Zintegrowanego Programu Operacyjnego Rozwoju Regionalnego

2 Ciągła integracja – w teorii „…a common story of software projects: integration is a long and unpredictable process.”

3 Ciągła integracja – w teorii „But this needn't be the way.” – Martin Fowler (MF) „Continuous Integration” http://www.martinfowler.com/articles/continuousIntegr ation.html http://www.martinfowler.com/articles/continuousIntegr ation.html

4 Ciągła integracja – w teorii Pełna integracja: 1.Pełna rekompilacja całego kodu źródłowego 2.Stworzenie uruchamialnej postaci systemu i uruchomienie go w środowisku testowym 3.Uruchomienie wszystkich testów automatycznych Wszystkie kroki muszą zakończyć się sukcesem.

5 Ciągła integracja – w teorii Przykładowy scenariusz 1.Pobranie aktualnego kodu źródłowego z VCS 2.Wprowadzenie zmian w kodzie 3.Integracja na maszynie programisty 4.Synchronizacja kodu z VCS 5.Integracja na maszynie programisty 6.Przesłanie zmodyfikowanego kodu na serwer VCS 7.Automatyczna integracja na serwerze ciągłej integracji

6 Ciągła integracja – w teorii Zalety  Zmniejsza ryzyko wystąpienia problemów integracyjnych  Brak odrębnych sesji integracyjnych  Zmniejszenie liczby błędów wykrywanych dopiero na etapie integracji  Poprawa pracy zespołowej Ciągła integracja to jedna z podstawowych praktyk Extreme Programming. Extreme Programming

7 Ciągła integracja – w teorii Zalecane praktyki  Pojedyncze repozytorium kodu źródłowego – „…you should be able to walk up to the project with a virgin machine, do a checkout, and be able to fully build the system.” – MF

8 Ciągła integracja – w teorii Zalecane praktyki  Zautomatyzowane skrypty integracyjne – „…anyone should be able to bring in a virgin machine, check the sources out of the repository, issue a single command, and have a running system on their machine.” – MF

9 Ciągła integracja – w teorii Zalecane praktyki  Zautomatyzowane testy – „ Imperfect tests, run frequently, are much better than perfect tests that are never written at all.” – MF

10 Ciągła integracja – w teorii Zalecane praktyki  Częste przesyłanie zmian na serwer VCS – „ The more frequently you commit, the less places you have to look for conflict errors, and the more rapidly you fix conflicts.” – MF

11 Ciągła integracja – w teorii Zalecane praktyki  Każda zmiana powoduje wykonanie integracji „The whole point of continuous integration is to find problems as soon as you can. Nightly builds mean that bugs lie undetected for a whole day before anyone discovers them.” – MF „ Daily builds are for wimps.” – Kent Beck

12 Ciągła integracja – w teorii Zalecane praktyki  Integracja powinna być krótkim procesem „ Probably the most crucial step is to start working on setting up a staged build. The idea behind a staged build is that there are in fact multiple builds done in sequence.” – MF

13 Ciągła integracja – w teorii Zalecane praktyki  Testuj w środowisku jak najbardziej zbliżonym do produkcyjnego „ If you test in a different environment, every difference results in a risk that what happens under test won't happen in production.” – MF

14 Ciągła integracja – w teorii Zalecane praktyki  Ostatnia pozytywnie przetestowana postać binarna powinna być łatwo dostępna „ We've found that it's very hard to specify what you want in advance and be correct; people find it much easier to see something that's not quite right and say how it needs to be changed.” – MF

15 Ciągła integracja – w teorii Zalecane praktyki  Informacje o statusie integracji powinny być łatwo dostępne „ Continuous Integration is all about communication, so you want to ensure that everyone can easily see the state of the system and the changes that have been made to it.” – MF

16 Ciągła integracja – w teorii „Bubble, Bubble, Build's In Trouble” http://www.pragmaticautomation.com/cgi-bin/pragauto.cgi/Monitor/Devices/BubbleBubbleBuildsInTrouble.rdoc

17 Ciągła integracja – w teorii „Bread as a display device” http://www.theregister.co.uk/2001/06/04/bread_as_a_display_device/ „…recently I saw someone experimenting with a dancing rabbit…” – MF

18 Ciągła integracja – w praktyce Typowa architektura: Programista Serwer VCS Serwer informacyjny Serwer testowy Serwer integracyjny

19 Ciągła integracja – w praktyce Serwery VCS:  CVS CVS  Subversion Subversion  Perforce Perforce  … http://better- scm.berlios.de/comparison/comparison.html

20 Ciągła integracja – w praktyce Narzędzia do automatyzacji:  Make Make  Ant, NAnt AntNAnt  Maven Maven  Ivy Ivy  … http://java-source.net/open-source/build-systems

21 Ciągła integracja – w praktyce Narzędzia do testów:  xUnit  The Grinder The Grinder  JMeter JMeter  Marathon Marathon  … http://java-source.net/open-source/testing-tools http://java-source.net/open-source/web-testing-tools

22 Ciągła integracja – w praktyce Narzędzia do ciągłej integracji:  CruiseControl CruiseControl  DamageControl DamageControl  LuntBuild LuntBuild  Continuum Continuum  … http://damagecontrol.codehaus.org/Continuous+I ntegration+Server+Feature+Matrix

23 Ciągła integracja – w praktyce Pełna integracja (Maven): 1.Pełna rekompilacja całego kodu źródłowego (clean, compile) 2.Stworzenie uruchamialnej postaci systemu i uruchomienie go w środowisku testowym (test, build, install, … 1 ) 3.Uruchomienie wszystkich testów automatycznych (… 2 ) Np.: 1 Stworzenie pliku WAR, uruchomienie go na testowym serwerze aplikacji 2 Uruchomienie testów akceptacyjnych/integracyjnych napisanych przy pomocy JWebUnit, …

24 Ciągła integracja – w praktyce CruiseControl  Darmowy, open-source  Wersje dla Javy i.NET  Składa się z dwóch aplikacji  - Serwera integracyjnego  - Aplikacji WWW do udostępniania wyników integracji  Działa z wieloma systemami VCS  Rozbudowane możliwości konfiguracji

25 Ciągła integracja – w praktyce CruiseControl – serwer integracyjny  Jedna instalacja obsługuje wiele projektów  Każdy projekt może mieć zdefiniowane kilka różnych integracji  Dwie podstawowe możliwości konfigurowania okresu integracji

26 Ciągła integracja – w praktyce CruiseControl – serwer integracyjny  Możliwość „opublikowania” wyników integracji na wiele różnych sposobów  Możliwość zarządzania poprzez interfejs JMX  Możliwość rozszerzania funkcjonalności własnymi pluginami  Konfiguracja poprzez plik XML http://cruisecontrol.sourceforge.net/main/configxml.html http://cruisecontrol.sourceforge.net/main/configxml.html

27 Ciągła integracja – w praktyce … …

28 Ciągła integracja – w praktyce... (4) … … (16) … … (24) … … (6) … … (24) …

29 Ciągła integracja – w praktyce CruiseControl – aplikacja WWW  Jedna instalacja obsługuje wiele projektów  Wyświetlane strony są generowane na podstawie logów części integracyjnej CC  Możliwy jest dostęp do pełnej historii integracji i artefaktów z integracji

30 Ciągła integracja – w praktyce CruiseControl – wady/zalety  [+] Dojrzały (czyt. stabilny i przemyślany)  [+] Bardzo elastyczny  [+/–] Osobne aplikacje do integracji i prezentacji wyników  [–] Ograniczone możliwości interfejsu WWW

31 Ciągła integracja Podsumowanie  Ciągła integracja to jedna z praktyk XP i jest ściśle powiązana jest z innymi praktykami  Pełne wdrożenie CI wymaga sporego nakładu pracy, ale… warto to zrobić  Nawet „integracja” polegająca na rekompilacji kodu już coś daje  Istnieje wiele narzędzi umożliwiających i ułatwiających zautomatyzowaną ciągłą integrację  Dobrym narzędziem na początek jest CruiseControl

32 Ciągła integracja Pytania?

33 Ciągła integracja Dziękuję za uwagę!