Towards verification of computation orchestration

Recently, a promising programming model called Orc has been proposed to support a structured way of orchestrating distributed Web Services. Orc is intuitive because it offers concise constructors to manage concurrent communication, time-outs, priorities, failure of Web Services or communication and...

Full description

Saved in:
Bibliographic Details
Main Authors: DONG, Jin Song, LIU, Yang, SUN, Jun, ZHANG, Xian
Format: text
Language:English
Published: Institutional Knowledge at Singapore Management University 2014
Subjects:
Orc
Online Access:https://ink.library.smu.edu.sg/sis_research/4977
https://ink.library.smu.edu.sg/context/sis_research/article/5980/viewcontent/towards.pdf
Tags: Add Tag
No Tags, Be the first to tag this record!
Institution: Singapore Management University
Language: English
id sg-smu-ink.sis_research-5980
record_format dspace
spelling sg-smu-ink.sis_research-59802020-03-12T07:35:19Z Towards verification of computation orchestration DONG, Jin Song LIU, Yang SUN, Jun ZHANG, Xian Recently, a promising programming model called Orc has been proposed to support a structured way of orchestrating distributed Web Services. Orc is intuitive because it offers concise constructors to manage concurrent communication, time-outs, priorities, failure of Web Services or communication and so forth. The semantics of Orc is precisely defined. However, there is no automatic verification tool available to verify critical properties against Orc programs. Our goal is to verify the orchestration programs (written in Orc language) which invoke web services to achieve certain goals. To investigate this problem and build useful tools, we explore in two directions. Firstly, we define a Timed Automata semantics for the Orc language, which we prove is semantically equivalent to the operational semantics of Orc. Consequently, Timed Automata models are systematically constructed from Orc programs. The practical implication is that existing tool supports for Timed Automata, e.g., Uppaal, can be used to simulate and model check Orc programs. An experimental tool has been implemented to automate this approach. Secondly, we start with encoding the operational semantics of Orc language in Constraint Logic Programming (CLP), which allows a systematic translation from Orc to CLP. Powerful constraint solvers like CLP(R) are then used to prove traditional safety properties and beyond, e.g., reachability, deadlock-freeness, lower or upper bound of a time interval, etc. Counterexamples are generated when properties are not satisfied. Furthermore, the stepwise execution traces can be automatically generated as the simulation steps. The two different approaches give an insight into the verification problem of Web Service orchestration. The Timed Automata approach has its merits in visualized simulation and efficient verification supported by the well developed tools. On the other hand, the CPL approach gives better expressiveness in both modeling and verification. The two approaches complement each other, which gives a complete solution for the simulation and verification of Computation Orchestration. 2014-01-07T08:00:00Z text application/pdf https://ink.library.smu.edu.sg/sis_research/4977 info:doi/10.1007/s00165-013-0280-9 https://ink.library.smu.edu.sg/context/sis_research/article/5980/viewcontent/towards.pdf http://creativecommons.org/licenses/by-nc-nd/4.0/ Research Collection School Of Computing and Information Systems eng Institutional Knowledge at Singapore Management University Orc Web service orchestration Verification Timed automata Uppaal Constraint logic programming Programming Languages and Compilers Software Engineering
institution Singapore Management University
building SMU Libraries
continent Asia
country Singapore
Singapore
content_provider SMU Libraries
collection InK@SMU
language English
topic Orc
Web service orchestration
Verification
Timed automata
Uppaal
Constraint logic programming
Programming Languages and Compilers
Software Engineering
spellingShingle Orc
Web service orchestration
Verification
Timed automata
Uppaal
Constraint logic programming
Programming Languages and Compilers
Software Engineering
DONG, Jin Song
LIU, Yang
SUN, Jun
ZHANG, Xian
Towards verification of computation orchestration
description Recently, a promising programming model called Orc has been proposed to support a structured way of orchestrating distributed Web Services. Orc is intuitive because it offers concise constructors to manage concurrent communication, time-outs, priorities, failure of Web Services or communication and so forth. The semantics of Orc is precisely defined. However, there is no automatic verification tool available to verify critical properties against Orc programs. Our goal is to verify the orchestration programs (written in Orc language) which invoke web services to achieve certain goals. To investigate this problem and build useful tools, we explore in two directions. Firstly, we define a Timed Automata semantics for the Orc language, which we prove is semantically equivalent to the operational semantics of Orc. Consequently, Timed Automata models are systematically constructed from Orc programs. The practical implication is that existing tool supports for Timed Automata, e.g., Uppaal, can be used to simulate and model check Orc programs. An experimental tool has been implemented to automate this approach. Secondly, we start with encoding the operational semantics of Orc language in Constraint Logic Programming (CLP), which allows a systematic translation from Orc to CLP. Powerful constraint solvers like CLP(R) are then used to prove traditional safety properties and beyond, e.g., reachability, deadlock-freeness, lower or upper bound of a time interval, etc. Counterexamples are generated when properties are not satisfied. Furthermore, the stepwise execution traces can be automatically generated as the simulation steps. The two different approaches give an insight into the verification problem of Web Service orchestration. The Timed Automata approach has its merits in visualized simulation and efficient verification supported by the well developed tools. On the other hand, the CPL approach gives better expressiveness in both modeling and verification. The two approaches complement each other, which gives a complete solution for the simulation and verification of Computation Orchestration.
format text
author DONG, Jin Song
LIU, Yang
SUN, Jun
ZHANG, Xian
author_facet DONG, Jin Song
LIU, Yang
SUN, Jun
ZHANG, Xian
author_sort DONG, Jin Song
title Towards verification of computation orchestration
title_short Towards verification of computation orchestration
title_full Towards verification of computation orchestration
title_fullStr Towards verification of computation orchestration
title_full_unstemmed Towards verification of computation orchestration
title_sort towards verification of computation orchestration
publisher Institutional Knowledge at Singapore Management University
publishDate 2014
url https://ink.library.smu.edu.sg/sis_research/4977
https://ink.library.smu.edu.sg/context/sis_research/article/5980/viewcontent/towards.pdf
_version_ 1770575164763799552