Introduction GL

Transcription

Introduction GL
Licence Mention Informatique – L2/S4 – 2012
Programmation Object
& Genie Logiciel
Burkhart Wolff
Département Informatique
Bibliographie et Weberies

UML 2.0, Martin Fowler, Campus Press, 2004

Developing Applications with Java and UML, Paul R. Reed Jr.,
Addison Wesley, 2002
UML 2 et les Design Patterns, G. Larman, Campus Press, 2005
UML 2 en action, P. Roques, F. Vallée, Eyrolles 2004
Paul R. Reed Jr., Addison Wesley, 2002



The Unified Modeling Language User Guide, Grady Booch, James
Rumbaugh, Ivar Jacobson, Addison-Wesley, 2005

Précis de Génie Logiciel,
M.-C. Gaudel, B. Marre, F. Schlienger et G. Bernot, Masson, 1996
The Science of Programming, D. Gries, Springer Verlag, 1981

http://www.omg.org/gettingstarted/what_is_uml.htm
http://www.eecs.ucf.edu/~leavens/JML/
http://www.junit.org/
2011-12
L2-GL - Intro
2
Part II.1 :
Introduction to Software Engineering
If the automobile had followed the same development
cycle as the computer, a Rolls-Royce would today cost
$100, get a million miles per gallon, and explode once a
year, killing everyone inside.
Robert X. Cringely
Why Software Engineering ?
Why does ad-hoc software development not scale:

Constraints to trustworthyness, safety, security,

Growing mix of hardware and software (complexity!),

Informatics is omnipresent et « diffuse »

Presence of clients, with imprecise and changing
requirements, with whom we must communicate

Development in (very) large, longstanding teams nec.
Software can have a long life-cycle, implying maintenance

 reference documents

Bad image of a company, loss of market credibility
society
aspects
Software becomes more and more complex and large
technological
aspects

 obstacle for development

2011-12
Legal constraints (Common Criteria Certification,
Antri-Trust-Laws, ...)
L2-GL - Intro
4
Software becomes more dangerous ...

Trust, safety and security of software :




Transportation: railway, aircrafts, space,
Control of industrial processes, nuclear, military, …
Tele-surgery, medical imaging and instruments …
Communication infrastructure, e-commerce, ...

Economics: costs and delay of development of reliable software,
reflecting customer needs, accepted by stakeholders and the
public…

Techniques and tools evolve :
in 20 years: factor 100 (?) higher la density components
… local errors accumulate, so more large and complex
systems require more quality in local components !

Technological aspects, methodologies, management,
as in other industrial activities ...
2011-12
L2-GL - Intro
5
Software becomes BIG ...

Windows 7:





Team of 1200 programmers only
5 Bln € development costs (estimation)
Revenues : 20 Bln € (estimation) !
Legal Bindings: 15 -20 years !
Problems:
Legal Battle about Windows Server 98;
led to a settlement with the EU costing 700 mio € !

Technological aspects,
methodologies,
management, as in other industrial activities ...

That is what Software Engineering is talking about !
2011-12
L2-GL - Intro
6
Famous Software Desasters

Mariner 1 (Venus, 1962) : wrong transcription of a formula
 erratic corrections of the trajectory (crash during flight)










1981 : Delay of first start of spaceship « voyager »
(problème de synchronisation des résultats de calculateurs redondants)
1985 - 1987 : Overdosis in a radiotherapy system (Therac-25, 5 dead). Item 2007
1992 : Crash of planning and tracking system of london ambulance calls
1996 : Crash of flight 501 of Ariane 5 (« validation » problem of the systeme)
Juillet 1997 : Blocking of names of the domaine .com
Septembre 1999 : Loss of Mars Climate Orbiter after 9 months of flight.
Costs : 120 M$ (confusion of unities between two different components)
2004 : defect of reservation system for SNCF tickets,
2004 : denial of access for the Bouygues Télécom and France Telecom networks
2008 : Toll-Collect Desaster (Allemagne)
2010 : NPfIT desaster in Great Britan (Loss: 12 Billion British Pound)
2011-12
L2-GL - Intro
7
Call-backs ?
(interrogations)
Example of a call-back: Speed Control Renault Laguna (2005)
Is it an informatics-bug or not ?
Is it a problem of interaction hardware/software/environment ?
 Even if no « bug », no-one is completely convinced !


need to justify/control the « proces of construction» (Common Criteria)
need to guarantee quality of tests of final product
Ubiquity of software !
Peugeot 607 = 2 Mb of embedded software, 40 processors, 20 % total cost
«Needs» (ABS, ESP, electronic pedals, sensors, …)

Interaction of services difficult to control. Trafic/Interferences on busses …

Validation of the systeme with all combinations of variants/options ?
Future automatisation of métro lines (RATP – ligne 1: 2010)

What validation process ?

Responsabilities: RATP or industrial partners (SIEMENS)

Who authorizes finally the service ? With what prospected reliability ?
2011-12
L2-GL - Intro
8
Some figures

Size of software systems ?




Windows « 90 » : 10 M. LOC source, Win2000: 30 M. LOC
Core RedHat 7.1 (2002) : ~2.4 M. LOC, XWindow ~1.8 M.,
Space shuttle (and its environment) : ~50 MLOC
Colombus Station (abandoned) : 980 MLOC compiled ??
Development costs ?

Proportion of «Coding» : 15 - 20 %
Coding is more and more automated (CASE-tools, MDA)



Proportion of Validation and Verification ? ~ 40%
Proportion of Specification and Design ? ~ 40%
Estimation of « Necessary Manpower » (Boehm)
Man-Month = 3,5 * C1,2
(«Complexity C» very approximative, but clearly Man-Months grow non-linear!
see http://www.compapp.dcu.ie/~renaat/ca421/LWu1.html for an
overview on cost estimation methods ...)
2011-12
L2-GL - Intro
9
Des chiffres sur les « défauts logiciels »
Algorithms
25%
Specification and
design
Code
60%
15%
Distribution of faults
Algorithms
Distribution of costs of faults
9%
Code
8%
83%
Specification and design
Source: F. Fichot, Cours de Conduite de Projets, IFIPS
2011-12
L2-GL - Intro
10
Particularities of software

Complexity strongly depends on applications :




Synchronisation, repartition of processes (concurrency, true parallelism)
Nature or volume of data, existence of algorithmic problems,
Interdependency of hardware and software,
Performance or « real-time réponse » (in reactive systems)

Apparently, software is easy to modify (versatility)
but impacts/consequences of modifications are difficult to predict

Difficult prediction on fault-rates and mesurement of « quality»:



small changes may have the most dramatic consequences
(in contrast to physics: small changes have usually small impacts)
no way to predict the « probability » of impacts/consequences
Weak visibility of development processes for clients, but also management!
 Importance of the phases (requirements) analysis, design, validation
 Need for an «industrial» development process, i.e. s.th. tracable
 Need for document-orientation of the development (at least in classic S.E.)
2011-12
L2-GL - Intro
11
Different aspects of Software Engineering
MANAGEMENT PROCESS
Development Mgt.
Risc Management
Configuration
Management
« PeopleWare »
(Staff, Sub-contractors)
FEASIBILITY STUDIES
(BEFORE PROJET)
SPECIFICATION &
DESIGN
Development
PRODUCTION
INTEGRATION &
VALIDATION
EXPLOITATION
Maintenance
& Support
QUALITY
CONTROL
METRICS
PROCESSUS
QUALITE
TECHNICAL PROCESS
2011-12
QUALITY
ASSURANCE
L2-GL - Intro
12
Organisational aspects: the conduct of projets
Planning, organisation, problem detection, reaction !






Estimation of costs and delays
Planning (e.g. diagrams like PERT or GANTT charts)
Follow-ups (Suivi): management of staff, des échéances et
fournitures à remettre au client
Risk Management (prevention or corrections)
Configuration management (versioning of documents, sources,
and tests as well as keeping track of their links and dependencies)
Document management associted to different phases of software
production (part of configuration management!)
…
 and all that respecting quality norms ... (document
types, circuits de validation, règles de nommage)
2011-12
L2-GL - Intro
13
Development Phases vs. Documents

A Sequence of increasingly precise and executable documents,






Development in «phases»


Informal Requirement Specification (Cahier des charges informel)
-> model(s) of the analyse (captures / formalizes the requirements)
-> model(s) of design (captures interfaces of the implementation)
-> code (implementation)
-> validation et vérification protocols, documentation
Each phase of the development process ends by producing (versions of) these
documents verified and validated before transition to next phase.
Each phase contributes to a number of «activities», which are pervasive

Production of Documentation (user manuals(manuel utilisateur), reference manuals
(manuel de référence), installation manual (manuel d’installation),…): extended at
different phases.

Activity of Validation/Verification
2011-12
L2-GL - Intro
14
Activities and Phases (1)

Phase Requirements Analysis (capture des besoins)
Study of the environment and the system application context, analysis of
requirements and constraints (performance, ergonomics, portability,…)
Output: requirement specification (cahier des charges)

Phase specification analysis (analyse et spécification)
Description of what the system should do (and not how)
Output: analysis models

Phase architectural design (conception architecturale)
Decomposition of the software into «components»
Conception of an integration proceeding and order of the different components
(increments); conception of related tests for integration

Phase (detailed) design (conception détaillée)
Choice of algorithms, data structures,definition of interfaces and classes to
describe conception of tests which verify or validate the implementation
Output: design documents, possibly code-interfaces, code fragments,
pseudo-code, mock-ups, prototypes.
2011-12
L2-GL - Intro
15
Activities and Phases (2)

Phase coding

Phase unit test
Controled execution of tests of each procedure/method
if they behave as defined

Phase integration and intégration tests
Execution of test scenarios conceived in the analysis
(Emphasis on high-level system behaviour)

Phase Acceptance Tests and System test (by the producer)
Test global tests under real conditions (platforms, under stress,
mesuring performance, ...)

Phase Deployment (Recette; par le client) Tests, inspection of
delivered documents, possibly véerification of relevant quality norms
2011-12
L2-GL - Intro
16
Beyond phases …

Importance of documentations :
stake-holders: users, admins, mainteners, providers, general public …

Distinction of two complementary activities :
Validation: check that the right system is built
(what is needed by the client; «external» coherence)
Verification: check if the system has been built right
(what has been specified ? «internal» coherence)

Importance of tracability ! (extremely important in open-source devs!)


Document and archive the choices beend done ! (mailings, versions,...)
Enforce the coherence between the models and the product
(environments must be «forward/reverse engineered»)

Importance of archiving, version and configuration management
(versioning documents, «building» particular configurations)

Guarante of document coherence wrt. to different versions

Guarante of reconstructibility of particular versions (can you
re-build version 1.6.4.7.4. and observe if bug XXX occurs in it ?)
2011-12
L2-GL - Intro
17
And after deployment ?

Maintenance is painful and expensive !

Correction maintenance: correction of critical bugs

Adaptive maintenance: new OS version, new hardware, new performance
problems, Y2K !!!

Evolutionary maintenance: integrating new functionality
Even worse: it may be nbecessary to maintain different
versions/configurations of systems simultaneously !

Maintenance costs: 2 - 4 times more than development ?

Need for regression tests from one version to another:

Requires precise test goal descriptions
(input, expected output and
execution context + requirement trancing in tests)

Need for test automation (execution, metrics, archiving)
and, therefore, tool-chains
2011-12
L2-GL - Intro
18
Process development models …

Organisation of the phases associated documents

Structuring of the process and improve its visibility,

Development of Tool Support for a concrete process
(RUP, V Model, Spiral, Méthodes Agiles, Xtreme programming, ...)
Produce templates for associated documents
Minimise risc of „procedural“ errors the software process
Support for non-linear development (back-tracks)
(modification of requirements, correction of design errors,
modification of technical environment (platform), …) ?




Are there methodologies adapted to the general tendancies ?




Distributed aspects in informatics, Global trends like virtualization,
Need for interoperability (SOAP, WebServices, XML, …)
Component-based approches (reuse, « COTS », libraries, frameworks)
Separation of business logic (logique métier) / technical services
(Norms like spécifications J2EE et .Net, WebServices)
2011-12
L2-GL - Intro
19
The V-Model (Le Modèle en V) …
Requirements Engineering
Installation, Systeme Tests
Acceptance Tests
Specification
Architectural Design
Integration &
Integration Tests
Detailed Design
Unit Tests
Coding



Principle temporal dependencies
Potential Back-flow
Plans and Document Flow
Historically best known, and pretty pedagogical !
The descending flow produit les guides pour les phases montantes
Pédagogique, mais pas toujours adapté…(global, linéaire)
2011-12
L2-GL - Intro
20
The V-Model (Le Modèle en V) …
Analyse des besoins, Faisabilité
Installation, Test Système
Spécification
Test d’acceptation
Conception Architecturale
Intégration
Conception Détaillée

Tests unitaires

Codage



Flux temporel principal
Retour en arrière éventuel
Plans et Documents
Historically best known, and pretty pedagogical !
The descending flow produit les guides pour les phases montantes
Pédagogique, mais pas toujours adapté…(global, linéaire)
2011-12
L2-GL - Intro
21
Other process development models
Spécification

Iteration Model

Spiral Model (Boehm)
Révision
Intégration et
deploiement
Version 2
Version 1
Analyse de risques
Prototype
Incrément n
Validation
Exigences
Spécification
Implémentation
Conception
Principes généraux:
Diminuer les risques, meilleure visibilité, retours utilisateur rapides,
Intégration et validation progressive des fonctionnalités
2011-12
L2-GL - Intro
22
Development process models en vogue

Xtreme Programming (and other méthodes agiles such as SCRUM)
http://www.en.wikipedia.org/wiki/Extreme_programming

Development driven by tests, « client »-centered

Permanent restructuring of code, coding in «teams of two»

Permanent presence of the client

Rational Unified Process (RUP): iterative, using UML.
http://www.idbconsulting.com/francais/incIBMRationalRUP.cfm
http://en.wikipedia.org/wiki/Rational_Unified_Process

Architecture MDA
(http://www.omg.org/mda/)
Approach based on the
transformation of UML models
2011-12
L2-GL - Intro
23
Summary

Programming in the small is not enough!
When constructing systems with more than 50000 LOC's,
the development process must be structured:






into phases
establishing a „bureaucratic“ decumentation process
tool-chains for code-generation, testing, verification,
documentation generation.
the work of 1000 of collaborators must be organized
... and financed
There is no silver-bullet,
not ONE particular SE Development Process, rather:


every process model can be found in industry,
from V-Model (large projects with public/military clients) ...
... to Methodes Agiles and Xtreme Programming (google)
... to MDA (e.g. SAP)
2011-12
L2-GL - Intro
24