UniKL Logo

Lehrgebiet Informationssysteme

FB Informatik

FB Informatik
 
LG IS
AG DBIS
AG HIS
Jobs / Tasks
Courses
Publications
Contact
Misc
Impressum
(C) AG DBIS
 

Test Case taDOM2+/30-taDOM2+-33-CO

taDOM2+ Lock Requests of executed Operation insertAfter(contextNode, siblingType, siblingValue) returns Node

The insertAfter operation is executed on the context element node CO and inserts a new next sibling node after the context node CO. There does not exist a next sibling, so the context element node was the last child of the parent node PA and the inserted new sibling node (the new last child of PA) is returned.

Behavior specified with base operations:

  • readCO
  • modifyCONSE
  • modifyPALCE
Read Set = CO , Write Set = PALCE CONSE
  • LockRequest[node=CO,lock:NR,PSE:-,NSE:EX,FCE:-,LCE:-]
  • LockRequest[node=CN,lock:NR,PSE:-,NSE:-,FCE:-,LCE:-]
  • LockRequest[node=PA,lock:CX,PSE:-,NSE:-,FCE:-,LCE:EX]

taDOM2+ Lock Requests of checked Operation deleteNode(contextNode) executed on node CO

The deleteNode operation is executed on the context element node CO and deletes the context node. Thereby, the context node is the last child of its parent node.

Bahavior specified with base operations:

  • modifyPALCE
  • modifyPSNSE
  • writeCO
  • writeFC
  • writeCH
  • writeLC
  • writeDC

Read and write sets for execution on CO:

Read Set = , Write Set = CO FC CH LC DC CA AS AX XS PALCE PSNSE
  • LockRequest[node=CO,lock:SX,PSE:-,NSE:-,FCE:-,LCE:-] on CO
  • LockRequest[node=PS,lock:-,PSE:-,NSE:EX,FCE:-,LCE:-] on CO
  • LockRequest[node=PA,lock:-,PSE:-,NSE:-,FCE:-,LCE:EX] on CO

Operations must be incompatible

CheckExisting LockRequest[node=CO,lock:NR,PSE:-,NSE:EX,FCE:-,LCE:-]
with
Requested LockRequest[node=CO,lock:SX,PSE:-,NSE:-,FCE:-,LCE:-] on CO
Requested lock SX on CO incompatible to existing lock NR.
Incompatible
CheckExisting LockRequest[node=CO,lock:NR,PSE:-,NSE:EX,FCE:-,LCE:-]
with
Requested LockRequest[node=PS,lock:-,PSE:-,NSE:EX,FCE:-,LCE:-] on CO
Compatible
CheckExisting LockRequest[node=CO,lock:NR,PSE:-,NSE:EX,FCE:-,LCE:-]
with
Requested LockRequest[node=PA,lock:-,PSE:-,NSE:-,FCE:-,LCE:EX] on CO
Compatible
CheckExisting LockRequest[node=CN,lock:NR,PSE:-,NSE:-,FCE:-,LCE:-]
with
Requested LockRequest[node=CO,lock:SX,PSE:-,NSE:-,FCE:-,LCE:-] on CO
Requested lock SX on CO incompatible to existing lock IR.
Incompatible
CheckExisting LockRequest[node=CN,lock:NR,PSE:-,NSE:-,FCE:-,LCE:-]
with
Requested LockRequest[node=PS,lock:-,PSE:-,NSE:EX,FCE:-,LCE:-] on CO
Compatible
CheckExisting LockRequest[node=CN,lock:NR,PSE:-,NSE:-,FCE:-,LCE:-]
with
Requested LockRequest[node=PA,lock:-,PSE:-,NSE:-,FCE:-,LCE:EX] on CO
Compatible
CheckExisting LockRequest[node=PA,lock:CX,PSE:-,NSE:-,FCE:-,LCE:EX]
with
Requested LockRequest[node=CO,lock:SX,PSE:-,NSE:-,FCE:-,LCE:-] on CO
Requested lock IX on AC compatible to existing lock IX.
Requested lock CX on PA compatible to existing lock CX.
Compatible
CheckExisting LockRequest[node=PA,lock:CX,PSE:-,NSE:-,FCE:-,LCE:EX]
with
Requested LockRequest[node=PS,lock:-,PSE:-,NSE:EX,FCE:-,LCE:-] on CO
Compatible
CheckExisting LockRequest[node=PA,lock:CX,PSE:-,NSE:-,FCE:-,LCE:EX]
with
Requested LockRequest[node=PA,lock:-,PSE:-,NSE:-,FCE:-,LCE:EX] on CO
On PA the last child edge lock EX is incompatible to the requested EX
Incompatible
Test Case Ok