Sequence Diagrams
Introduction
it’s a way to model interactions between objects
interaction specifies how messages and data are exchanged between objects
interaction partners: human (lecturer, admin) or non-human (server, printer, software)
interactions: conversation between people, message exchange between human and software, communication protocols, sequence of method calls in program, etc.
Basics
Interactions, interaction partners
a sequence diagram is 2D:
- horizontal axis: involved interaction partners
- vertical axis: chronological order of interaction
interaction: sequence of event specifications
data:image/s3,"s3://crabby-images/2f887/2f887bcbf8365e8ca392ac8e7cc55420c739a562" alt="Sequence diagram example"
interaction partners are lifelines:
- head of lifeline is rectangle containing
object:Class
- body of lifeline is vertical dashed line representing lifetime of associated object
Messages
message is defined via send and receive events
execution specification (optional):
- continuous bar
- used to visualize when interaction partner executes a behavior
data:image/s3,"s3://crabby-images/bd06a/bd06a7faf2785606e67345a8e700adf5a6931062" alt="Exchanging messages example on diagram"
rules:
data:image/s3,"s3://crabby-images/fdf22/fdf22df6efa61a1a7e854741c562539005014e20" alt="Exchanging messages rules"
synchronous message:
- sender waits until it has received response message before continuing
- syntax:
msg(par₁, par₂)
msg
: name of message
par
: parameters
- notation:
data:image/s3,"s3://crabby-images/cb267/cb26787f3b5d83d41b87113638ed3a6afd38c61e" alt="Synchronous message"
asynchronous message:
- sender continues without waiting for response msg
- syntax:
msg(par₁, par₂)
- notation:
data:image/s3,"s3://crabby-images/e94fe/e94fe8317e98f910540f8b1ae56dad66f7c58d5b" alt="asynchronous message"
response message:
- can be omitted if content and location are obvious
- syntax:
att = msg(par₁, par₂): val
att
: return value assigned to variable (optional)
msg
: name of message
par
: parameters
val
: return value
- notation:
data:image/s3,"s3://crabby-images/cd601/cd601706f75079fb3c08367fd8ad9b21981c2bf2" alt="response message"
object creation:
- dashed arrow, arrowhead pointing to head of lifeline of object that’s being created
- keyword
new
- notation:
data:image/s3,"s3://crabby-images/989d3/989d35bc4aa5128bea1f19151ffbf2b6a066b9c8" alt="Object creation"
object destruction:
- object is deleted
- large cross at end of lifeline
- notation:
data:image/s3,"s3://crabby-images/4900b/4900b74e73131e9d1ddccc3c283c209eec27fe00" alt="Object destruction"
found message:
- sender unknown/not relevant
- notation:
data:image/s3,"s3://crabby-images/e8281/e8281081f0ce7cf2056874da09e49d8abc8821a1" alt="Found message"
lost message:
- receiver unknown/not relevant
- notation:
data:image/s3,"s3://crabby-images/41853/418538947ffa9e066b9dc93ae5892f8fd3b6a03d" alt="Lost message"
Time-consuming message:
- message with duration
- usually messages transmitted instantly (by assumption); not in this case
- notation:
data:image/s3,"s3://crabby-images/101eb/101ebf7a0d858a5e59e1b0461b0b17c16a7db3b7" alt="Time-consuming message"
Combined fragments
model various control structures, have 12 predefined operators.
Example:
data:image/s3,"s3://crabby-images/02ce6/02ce6412c7fcecb1ed4e51219f98c2bb2fe6c1c1" alt="Combined fragment example"
Branches & loops
alt
:
- alternative sequence
- like a switch statement, with guards selecting the path to be executed
- guards modeled in square brackets, default true
- guards have to be disjoint so that behavior is deterministic!
data:image/s3,"s3://crabby-images/f42d4/f42d4f01d9bbc9caf769fb08759f5e3513aee6f9" alt="Alt fragment"
opt
:
- optional sequence
- like an if without an else
- actual execution depends on guard
- exactly one operand
data:image/s3,"s3://crabby-images/527d5/527d5e224940e041ea379cccf464044c7bb92a56" alt="Opt fragment"
loop
:
- repeated sequence
- min/max number of iterations -
(min..max)
or (min, max)
. default (*)
, no upper limit.
- guard evaluated when min number of iterations took place, checked on each iteration. loop quits if false.
data:image/s3,"s3://crabby-images/636dc/636dc7008da94ea765611fcf2ec34b161c8e035a" alt="Loop fragment"
break
:
- exception handling
- one operand with a guard. if true:
- interactions within operand are executed
- remaining operations of surrounding fragment don’t run
- interaction continues at next higher level fragment (so like you skip a level)
data:image/s3,"s3://crabby-images/5f53c/5f53cdedc4472c49e3bc6af1a7263d730e2772de" alt="Break fragment"
Concurrency and order
seq
:
- weak sequencing, default order of events
- can’t skip around on the same lifeline
data:image/s3,"s3://crabby-images/ed97b/ed97b95438918bab3ec4dd03de7f909a289b1bf3" alt="Seq fragment"
strict
:
- strict order
- fixed sequence of events across lifelines
- order of events on different lifelines between different operands is significant
- messages in operand higher up on vertical axis are always exchanged before the ones that are lower
data:image/s3,"s3://crabby-images/2a807/2a8071e9ff1a06cc1e60ebaa12e0749b5881acac" alt="Strict fragment"
par
:
- concurrent interaction
- relax chronological order between messages in different operands
- restrictions in each operand have to be respected
- order of different operands is irrelevant
data:image/s3,"s3://crabby-images/d31e4/d31e45a93318d79d39a9b09856a014e7036d51f7" alt="Par fragment"
critical
:
- atomic interaction
- make sure that certain parts of interaction aren’t interrupted by unexpected events
- always has to be in that order
data:image/s3,"s3://crabby-images/b3f27/b3f273d82eb910802f1cd0c19b395966ab7311b3" alt="Critical fragment"
Filters and assertions
ignore
:
- irrelevant interaction
- messages can occur at runtime but don’t have other significance
- one operand, irrelevant messages in curly brackets after keyword
ignore
data:image/s3,"s3://crabby-images/c9339/c9339eef45e956e1acf3e3ebb8708ae69b9b8596" alt="Ignore fragment"
consider
:
- relevant interaction with a particular importance
- one operand. “dual” to ignore fragment
- considered messages in curly brackets
- and yes, you can use
ignore
instead of consider
and vice-versa
data:image/s3,"s3://crabby-images/fd331/fd3312b8a2b76f943ee6cd029b83920dcb750eb0" alt="Consider fragment"
assert
:
- asserted interaction
- mandatory interactions. the model is complete. can’t have any deviations.
data:image/s3,"s3://crabby-images/cd54b/cd54b1ddd356e4881b59a2184c42f22e10007e6b" alt="Assert fragment"
neg
:
- invalid interaction
- describe situations that must not occur
- depicting relevant but incorrect sequences
data:image/s3,"s3://crabby-images/4a9fe/4a9fe4f73ae30570b8460bac95baa0f5e26251db" alt="Neg fragment"
Further language elements
time constraints:
- point in time for event occurrence:
after(5sec)
, at(12.00)
- time period between two events:
{lower..upper}
now
: current time
- duration: calculation of duration of message transmission
Interaction reference:
- integrates one sequence diagram in another sequence diagram
- define with
sd name
in the corner, then use the name in the diagram with ref
in the corner
Gate:
- allows to send and receive messages beyond boundaries of interaction fragment
state invariant:
- asserts certain condition has to be true at certain time
- if state invariant is not true, either model or implementation is wrong
- notations:
data:image/s3,"s3://crabby-images/33180/33180a7c180aea1effb373659c8599252958669e" alt="State invariant diagram"