curs 4 adrian iftene [email protected]/scoala/2011/taip/courses/taip... · the objective...
TRANSCRIPT
Curs 4 – 25 Octombrie 2010
Adrian [email protected]
Portalul este funcțional! Tot ce ați lucrat până acum să puneți pe portal:◦ State-of-the-art – ca pdf
◦ Ingineria cerințelor – ca pdf
◦ Diagrame UML – ca imagini (jpg)
SVN-ul este funcțional! Tot ce veți lucra de acuma să puneți acolo și să-mi dați drepturi de citire!
Termen limită: 27 Octombrie
2
Planificați-vă a doua întâlnire cu persoana care vă coordonează la practica de cercetare!
Termen limită săptămâna a 8-a!
3
Recapitulation course 3◦ Modeling (EMF, IBM Rational Rose Modeler)
Business Process Modeling Notation◦ Introduction
◦ Elements
◦ Examples
◦ Frameworks
Aspect Oriented Programming ◦ Introduction
◦ Terminology
◦ Frameworks
AspectJ (for Eclipse and Netbeans)
4
Modeling ◦ The Value of Modeling
◦ EMF
◦ IBM Rational Rose Modeler
5
6
Who?
What is modeling?
Why model?
7
EMF Ecore
8
BPMN - graphical representation for specifying business processes in a business process modeling
BPMN was developed by Business Process Management Initiative (BPMI), and is currently maintained by the OMG (http://www.bpmn.org/)
The objective of BPMN is to support business process management for both technical users and business users
The current version of BPMN is 1.2, with a major revision process for BPMN 2.0 in progress (Beta 2)
9
BPMN is based on a flowcharting technique very similar to activity diagrams from UML
The primary goal of BPMN is to provide a standard notation that is readily understandable by all business stakeholders:◦ business analysts - who create and refine the processes
◦ technical developers - responsible for implementing
◦ business managers - who monitor and manage the processes
Business Process Execution Language = execution languages
10
Flow Objects ◦ Events, Activities,
Gateways
Connecting Objects ◦ Sequence Flow, Message
Flow, Association
Swimlanes◦ Pool, Lane
Artifacts (Artefacts) ◦ Data Object, Group,
Annotation
11
Event - something that happens◦ Catching - they might catch an incoming message to Start process
◦ Throwing - they might throw a message at the End of the process
13
Activity - describes the kind of work which must be done◦ Task - a single unit of work
◦ Sub-process - Used to hide or reveal additional levels of business process detail
◦ Transaction - A form of sub-process in which all contained activities must be treated as a whole
14
All contained activities must all be completed to meet an objective, and if any one of them fails they must all be compensated (undone)
15
A Gateway is represented with a diamond shape and will determine forking and merging of paths depending on the conditions expressed
16
A Sequence Flow shows in which order the activities will be performed
A Message Flow tells us what messages flow across organizational boundaries
An Association is used to associate an Artifact or text to a Flow Object
17
Swimlanes are a visual mechanism of organizing and categorizing activities◦ Pool - Represents major participants in a process (contains one
or more lanes (like a real swimming pool)) A pool can be open(showing internal detail) or collapsed (hiding internal detail)
◦ Lane - Used to organize and categories activities within a pool according to function or role. A lane contains the Flow Objects, Connecting Objects and Artifacts.
18
19
Artifacts allow developers to bring some more information into the model/diagram◦ Data Objects show the reader which data is
required or produced in an activity
◦ A Group is used to group different activities but does not affect the flow in the diagram
◦ An Annotation is used to give the reader of the model/diagram an understandable impression
20
21
22
23
24
Private (internal) business processes – are internal to a specific organization and are called workflow or BPM processes
Abstract (public) processes - represent the interactions between a private business process and another process or participant
Collaboration (global) processes - A collaboration process depicts the interactions between two or more business entities.
25
26
27
Visio BPMN modeler◦ Microsoft Visio Professional 2010 (e-academy)
Intalio◦ Java, Eclipse
Jadex◦ Java, Eclipse
JBPM◦ Java, Apache Ant
28
29
30
31
32
33
34
35
36
AOP is a programming paradigm which isolates secondary or supporting functions from the main program’s business logic
AOP increases modularity by allowing the separation of cross-cutting concerns
AOP includes programming techniques and tools that support the modularization of concerns at the level of the source code
37
Aspects emerged out of object-oriented programming and computational reflection
Aspects relate closely to subjects, mixings, delegation
Since at least the 1970s, developers have been using forms of interception and dispatch-patching
Designers have considered alternative ways to achieve separation of code, such as C#'s partial types, but such approaches lack a quantification mechanism that allows reaching several join points of the code with one declarative statement
38
AOP as such has a number of antecedents: the Visitor Design Pattern, CLOS MOP (Common Lisp Object System - MetaobjectProtocol)
AspectJ developed by Gregor Kiczales and colleagues at Xerox PARC (2001)
Hyper/J and Concern Manipulation Environment offered by IBM's research team in 2001 (which have not seen wide usage)
EmacsLisp changelog added AOP related code in version 19.28
39
40
Cross-cutting concerns - aspects of a program which affect other concerns
Advice - additional code
Pointcut - point where additional code is executed
Aspect - the combination of the pointcut and the advice
41
Even though most classes in an OO model will perform a single, specific function, they often share common, secondary requirements with other classes
For example, we may want to add logging to classes within the data-access layer and also to classes in the UI layer whenever a thread enters or exits a method. Even though each class has a very different primary functionality, the code needed to perform the secondary functionality is often identical.
42
This is the additional code that you want to apply to your existing model
In our previous example, this is the logging code that we want to apply whenever the thread enters or exits a method.
43
This is the term given to the point of execution in the application at which cross-cutting concern needs to be applied
In our previous example, a pointcut is reached when the thread enters a method, and another pointcut is reached when the thread exits the method
44
The combination of the pointcut and the advice
In the example above, we add a logging aspect to our application by defining a pointcut and giving the correct advice.
45
An open source application framework for Java
The first version (Rod Johnson) was released with the publication of book Expert One-on-One J2EE Design and Development in October 2002
The framework was first released under the Apache 2.0 license in June 2003. The current version is 3.0.4
The core features can be used by any Java application, but there are extensions for building web applications on top of the Java EE platform
It is very popular in the Java community as an alternative to, replacement for, or even addition to the Enterprise JavaBean (EJB) model
46
Inversion of Control container
Aspect-oriented programming
Data access
Transaction management
Model-view-controller
Remote Access framework
Convention-over-configuration
Batch processing
Authentication and authorization
Remote Management
Messaging
Testing
47
Join point: a point during the execution of a program
Introduction: declaring additional methods or fields on behalf of a type
Target object: object
being advised by one
or more aspects
AOP proxy: an object
created by the AOP
framework in order to
implement the aspect
contracts
48
A point during the execution of a program, such as the execution of a method or the handling of an exception
A set of join points is described as a pointcut
In Spring AOP, a join point always represents a method execution
In my words: a locus of points where execution will happen
49
Declaring additional methods or fields on behalf of a type
Spring AOP allows you to introduce new interfaces (and a corresponding implementation) to any advised object
For example, you could use an introduction to make a bean implement an IsModified interface, to simplify caching
An introduction is known as an inter-type declaration in the AspectJ community
50
Object being advised by one or more aspects
Also referred to as the advised object
Since Spring AOP is implemented using runtime proxies, this object will always be a proxied object
51
An object created by the AOP framework in order to implement the aspect contracts (advise method executions and so on)
For example, in the Spring Framework, an AOP proxy will be a JDK dynamic proxy or a CGLIB proxy
52
Utility for aspect-oriented languages designed to take instructions specified by aspects and generate the final implementation code
Takes information from raw class and aspects and creates new class => woven class
The weaver integrates aspects into the locations specified by the software as a pre-compilation step
53
AspectJ - the most mature and fully featured framework
JBoss AOP - is a 100% Pure Java usuable in any programming environment
Aspectwerkz (AW) - one of the quickest and most fully featured AOP frameworks available
Nanning - a simple yet scalable aspect-oriented framework for Java (Nanning is also nice "little" town in Guanxi province in southern China)
54
Eclipse IDE + AJDT (AspectJ Development Tools)
Create “New” + “AspectJ Project”
55
56
aspect
pointcut
advice
57
AspectJ Plugin for NetBeans 6.7.x: http://plugins.netbeans.org/PluginPortal/faces/PluginDetailPage.jsp?pluginid=22964
Using the AspectJ Plug-In Module for NetBeans 6.0+: http://www.jroller.com/ramlog/entry/using_the_aspectj_plug_in1
58
59
Use BPMN to create a business model, and use it in a new project component related to your project theme
Use AOP or MOP in your implementation
60
BPMN: http://www.bpmn.org/
BPMS Process Mapping BPM: http://interfacing.com/
Visio BPMN modeler Tutorial: http://www.interfacing.com/uploads/File/Tutorial.pdf
Business process case studies: http://interfacing.com/Literature/Business-process-case-studies/
Intalio: http://www.intalio.com/downloads
Jadex packages: http://jadex-processes.informatik.uni-hamburg.de/xwiki/bin/view/Download/Available+Packages
Jadex Installation: http://jadex-processes.informatik.uni-hamburg.de/xwiki/bin/view/BPMN+Tutorial/02+Installation
jBPM: http://jboss.org/jbpm
61
AOP: http://onjava.com/pub/a/onjava/2004/01/14/aop.html, http://en.wikipedia.org/wiki/Aspect-oriented_programming
AspectJ: http://www.eclipse.org/aspectj/
AspectJ Downloads: http://www.eclipse.org/aspectj/downloads.php
Aspectwerkz (AW): http://aspectwerkz.codehaus.org/
Nanning: http://nanning.codehaus.org/
jBoss AOP: http://www.jboss.org/jbossaop
Spring AOP tutorial: http://technologiquepanorama.wordpress.com/2009/05/18/spring-aop-tutorial-i/
AJDT: AspectJ Development Tools: http://www.eclipse.org/ajdt/
AOP in Netbeans: http://www.jroller.com/ramlog/entry/using_the_aspectj_plug_in1http://plugins.netbeans.org/PluginPortal/faces/PluginDetailPage.jsp?pluginid=22964
Framework for AOP in C#: http://rail.dei.uc.pt/