510 likes | 533 Views
Explore how Motorola WEAVR simplifies software design by focusing on modular abstraction, encapsulation, and separation of concerns. Learn about aspect-oriented and model-driven development to enhance software complexity management.
E N D
Motorola WEAVR: Model-Driven Software Developmentin a Large Industrial Context by Thomas Cottenier Software and System Engineering Research Lab, Motorola Labs Directed by Dr. Tzilla Elrad, Illinois Institute of Technology January 2007
Motorola WEAVROutline • Introduction • What is a Software Model? • Model-Driven Software Development • Aspect-Oriented Software Development • Motorola WEAVR • Further Work • Conclusions
Motorola WEAVR How to Manage Software Complexity? Evolution of Software Design: Monolithic → Modular Abstraction Focus only on relevant properties – omit what is not relevant Decomposition Divide software into separately named and addressable modules Encapsulation Group related things together. InformationHiding Hide implementation details from the outside Separation of Concerns • Ensure that each module only deals with one concern • Low Coupling among the modules • High Cohesion within one module
Models Models@runtime Aspect-Oriented Programming Source Code 1990’s Object Oriented Programming Procedural Programming 1980’s How to Manage Software Complexity? Aspect-Oriented Software Development Metamodeling 2000’s Model-Driven Engineering
Motorola WEAVR Introduction Applications = Computations + Composition Object-Oriented Programming Applications = Objects + Aggregation, Association, Inheritance, Polymorphism, .. Component-Based Software Development Applications = Component Interfaces + Scripts Service-Oriented Architecture Applications = Service Interfaces + Business Processes Model-Driven Development Applications = Libraries + Models
Motorola WEAVR Introduction Problems: - Brittle Composition Mechanisms Software reuse mechanisms do not scale Separate Composition from Computation Domain-Specific Abstractions - Purely Hierarchical Decomposition Some concerns cannot be modularized according to an hierarchical decomposition Aspect-Oriented Software Development
Motorola WEAVR What is a Software Model? Different types of systems: • Transformational systems: Data-Processing systems, Compilers, Search-Engines, Computation Intensive systems, etc.. • Reactive systems ATM, vending machines, phones, cars, missile and avionic systems, telecom infrastructure, human-machine interface of may ordinary software
Motorola WEAVR What is a Software Model? Different types of systems: • Transformational systems: Data-Processing systems, Compilers, Search-Engines, Computation Intensive systems, etc.. Procedural, Functional, Object-Oriented, etc programming languages provide excellent support for Transformational systems!
Motorola WEAVR What is a Software Model? Different types of systems: • Reactive systems ATM, vending machines, phones, cars, missile and avionic systems, telecom infrastructure, human-machine interface of may ordinary software Procedural, Functional, Object-Oriented, etc programming languages DO NOT provide the right abstractions
1. void actionPerformed(ActionEvent evt) { 2. switch(this.STATE){ 3. case Init: 4. serviceA.methodA(); 5. if(evt.getSource() == Enter){ 6. serviceB.methodB(); 7. if(evt.getActionCommand() == “Previous”){ 8. serviceC.methodC(); 9. this.STATE = Previous; 10. return; 11. }else 12. if(evt.getActionCommand() == “Next”){ 13. serviceD.methodB(); 14. this.STATE = Next; 15. return; 16. } 17. }else 18. if (evt.getSource() == Cancel){ 19. } 20. break; 21. case Previous: 22. serviceA.methodE(); 23. break; 24. case Next: 25. if(evt.getActionCommand() == “Proceed”){ 26. serviceA methodC(); 27. } 28. break; 29. } 30. methodF(); 31. this.STATE = Done; 32. return; 33. } Motorola WEAVR Reactive Systems Example: Java Applet
Motorola WEAVR Reactive Systems Statechart is a decomposition that better fits the problem domain than the procedural decomposition
1. void actionPerformed(ActionEvent evt) { 2. switch(this.STATE){ 3. case Init: 4. serviceA.methodA(); 5. if(evt.getSource() == Enter){ 6. serviceB.methodB(); 7. if(evt.getActionCommand() == “Previous”){ 8. serviceC.methodC(); 9. this.STATE = Previous; 10. return; 11. }else 12. if(evt.getActionCommand() == “Next”){ 13. serviceD.methodB(); 14. this.STATE = Next; 15. return; 16. } 17. }else 18. if (evt.getSource() == Cancel){ 19. } 20. break; 21. case Previous: 22. serviceA.methodE(); 23. break; 24. case Next: 25. if(evt.getActionCommand() == “Proceed”){ 26. serviceA methodC(); 27. } 28. break; 29. } 30. methodF(); 31. this.STATE = Done; 32. return; 33. } Motorola WEAVR Reactive Systems
Motorola WEAVR Reactive Systems Modules that: • are repeatedly prompted by the outside world and continuously respond to external inputs • behavior is highly dependent on module history Abstractions: • State • Transition • Decision Actions Today, most systems are hybrid systems (reactive and transformational)!
Motorola WEAVR What is a Software Model? UML: Collection of Languages that provide complementary decomposition abstractions • Object-Oriented and procedural decomposition: Class Diagrams, Sequence Diagrams • Reactive decomposition: State Machine diagrams • Workflow decomposition: Activity Diagram • Runtime structure decomposition: Composite-Part Diagram + Execution: Action Language
Motorola WEAVR What is a Software Model? Object-Oriented Workflow State Machine Run time Structure + Execution: Action Language Procedural
Motorola WEAVRModel-Driven Software Development Different Types of Modeling Practices: • Sketches (e.g. Visio) • Blue-prints/Elaboration (e.g IBM Rational) • Executable Models (e.g IBM Rational) • Translatable Models (e.g. Telelogic, iUML)
Motorola WEAVRMDD Blue-prints/Elaboration (e.g IBM Rational)
Motorola WEAVRMDD Model Translation
Domain Standard Notations UK USA RMTR air_in taxi_in taxi_out air_out GENERICCODE GENERATOR DESIGN SIMULATION UNIT TEST Motorola WEAVRModel-Driven Software Development PRODUCT REQUIREMENTS VALIDATION MIDDLEWARE, OS, PLATFORM PRODUCT CODE VERIFICATION
Motorola WEAVRModel-Driven Software Development Example: Resource Access Server
Motorola WEAVRModel-Driven Software Development Example: Resource Access Server
Motorola WEAVRModel-Driven Software Development Example: Resource Access Server VALIDATION
Motorola WEAVRModel-Driven Software Development Example: Resource Access Server
Motorola WEAVRModel-Driven Software Development Example: Resource Access Server Realization Mappings 4.b. 4.a.
Motorola WEAVRModel-Driven Software Development Specification Implementation
Motorola WEAVRModel-Driven Software Development Example: Resource Access Server
Motorola WEAVRAspect-Oriented Software Development • Socket creation in Tomcat • - fits nicely into one package (3 classes) Good Modularity
Motorola WEAVRAspect-Oriented Software Development • Class Loading in Tomcat • - mostly in one package (9 classes) Good Modularity
Motorola WEAVRAspect-Oriented Software Development Logging in Tomcat - scattered across the packages and classes - error handling, security, business rules, … Poor Modularity
Motorola WEAVRAspect-Oriented Software Development Goal of AOSD Enable the modular (not scattered) implementation of crosscutting concerns. Aspect Explicit abstraction for representing crosscutting concerns Aspect-Oriented Programming Language that provides mechanisms to capture aspects Aspect Weaver Composition mechanism that coordinates aspects with the rest of the code
AOSD – TerminologyCrosscutting Concerns Scattering In a given implementation, the code for a concern is spread out. Single concern affects multiple modules. Tangling Multiple concerns are interleaved in a single module Crosscutting Concern The inherent structure of the concern can not be modularized in the decomposition mechanism of the language (Objects or procedures), because it follows different composition rules. • class Point { • void setX(int x) { • Tracer.traceEntry(“Entry Point.set”); DisplayTracker.updatePoint(this); • this.x = x; • Tracer.traceExit(“Exit Point.set”); } • }
AOSDCrosscutting Concerns • Synchronization • Real-time constraints • Error-checking • Object interaction constraints • Memory management • Persistency • Security • Caching • Logging • Monitoring • Testing • Domain specific optimization • ...
WEAVR Model weaving Engine Resource Initialization Aspect Initialization Exception Handling Aspect
Motorola WEAVRExamples: Fault-Tolerance Exception Handling
Motorola WEAVRExamples: Fault-Tolerance Exception Handling
Motorola WEAVRExamples: Fault-Tolerance Example: Resource Access Server Realization Mappings 4.b. 4.a.
Motorola WEAVRModel-Driven Software Development Specification Implementation
Motorola WEAVRExamples: Fault-Tolerance Exception Handling
Motorola WEAVRExamples: Fault-Tolerance 10.a. Recoverability restore backup
Motorola WEAVRExamples: Fault-Tolerance 11.d. 10.a. Atomicity
Motorola WEAVRModel-Driven Software Development Example: Resource Access Server
Motorola WEAVRFurther Work AspectX classX x classY AspectY WEAVR partially addresses the most important issue with AOSD • Dependency Inversion Does dependency inversion impedes system modularity, evolvability? • Aspect/Core semantic interactions Guaranties on the quality attributes of woven software? • Interferences between aspects AOSD destroys the locality of the run-time control flow. We need full global knowledge in order to reason about the correctness of the system! • Syntactic Joinpoint Designators Does my join point specification match my intention of the joint point? AOP introduces new ways the correctness of a program can break down Current joint point languages are too low level
Motorola WEAVRFurther Work How to guarantee the correctness of woven Models? Validation, Simulation, Model Checking, testing of woven models?
Motorola WEAVRConclusions • Modeling allows a system to be decomposed according to complementary decomposition abstractions. Use the abstraction that fits problem domain the best • Model-Driven Software Development – fully automatic code generation from executable models • Aspect-Oriented Software Development – provide abstractions for crosscutting concerns • Motorola WEAVR: Aspect-Oriented Software Development through model transformation Our Contribution • Aspect-Oriented Language for State Machines – New Joinpoint model • Inference of Implementation Joinpoints from Pointcuts expressed in terms of the Specification – Increased Modularity • Concepts fully implemented in WEAVR tool • Tool deployed in an industrial context – Expected Results by end 2007: Reduction of 40% of model size in WiMAX infrastructure project