Processes, systems & tests: Defining contextual equivalences

Clément Aubert, Daniele Varacca

Research output: Contribution to journalConference articlepeer-review

Abstract

In this position paper, we would like to offer and defend a template to study equivalences between programs—in the particular framework of process algebras for concurrent computation. We believe that our layered model of development will clarify the distinction that is too often left implicit between the tasks and duties of the programmer and of the tester. It will also enlighten pre-existing issues that have been running across process algebras such as the calculus of communicating systems, the π-calculus—also in its distributed version—or mobile ambients. Our distinction starts by subdividing the notion of process in three conceptually separated entities, that we call Processes, Systems and Tests. While the role of what can be observed and the subtleties in the definitions of congruences have been intensively studied, the fact that not every process can be tested, and that the tester should have access to a different set of tools than the programmer is curiously left out, or at least not often formally discussed. We argue that this blind spot comes from the under-specification of contexts—environments in which comparisons occur—that play multiple distinct roles but supposedly always “stay the same”.

Original languageEnglish (US)
Pages (from-to)1-21
Number of pages21
JournalElectronic Proceedings in Theoretical Computer Science, EPTCS
Volume347
DOIs
StatePublished - Oct 2 2021
Event14th Interaction and Concurrency Experience, ICE 2021 - Virtual, Online
Duration: Jun 18 2021 → …

ASJC Scopus subject areas

  • Software

Fingerprint

Dive into the research topics of 'Processes, systems & tests: Defining contextual equivalences'. Together they form a unique fingerprint.

Cite this