Service Simulation
Why?
Simulation of services helps to predict the data and behavior of services through virtual objects. Simulation is used to diagnose problems and to test otherwise difficult to establish behavior. A typical use case is to enable designers to run a user interface without being depending or to wait for a service implementation. This gets even more important when the service runs on embedded or automotive systems where hardware access is often limited.
An object is a virtual entity that can be created and destroyed and it has state and behavior as well notifies the world of changes. Objects are accessed through a protocol adapter that is implemented by the simulation server.
The simulation shares the same API as a production service and can be used to validate the use of an API without having to implement the actual service. The simulation is interchangeable with a real service and can be used in the same way.
Quick Start
A simulation file is a JavaScript file which contains typically one simulation scenario. The file creates all API endpoints using an actor. The initial simulation can be auto generated by the template system and then extended by the developer or simply written by hand.
To explain the concept we will use a simple example.
module demo
interface Counter {
  count: int
  increment()
  decrement()
}
The counter example shows a simple interface which can be used to increment or decrement a reactive counter. The simulation file will look like this:
// counter.js
// create a service based on module and interface name and provide initial properties
const counter = $createService("demo.Counter", { count: 0 });
// react to changes of the count property
counter.on("count", function(value) {
  console.log("count changed to " + value);
});
// provide an implementation for the increment operation
counter.increment = function() {
  // modify the count property using 'this', this will trigger the count property change event
  this.count++;
};
// provide an implementation for the decrement operation
counter.decrement = function() {
  this.count--;
};
// provide an autorun function which will be called when the simulation is started
function main() {
  for (let i = 0; i < 10; i++) {
    counter.increment();
    counter.decrement();
  }
}
To run the simulation we need to start the server and then run the simulation file. The server will then start the simulation and provide the simulation interface to the client.
The simulation template will generate a simulation stub as also typescript type definitions to provide a better developer experience.
Running the simulation
To run the simulation file we now can use the following command:
apigear sim run counter.js
This contact the server and sends the simulation file to the simulation server and runs it. The simulation server will create actors and run the main function, if available. Now the simulation server waits for API calls from the client.
Now you need a client to connect to the simulation server over ObjectLink and trigger the simulation. You can either:
- Build a client using one of the ObjectLink client SDKs
- Use the stimulation tool to create JavaScript-based test clients
Simulation Protocol
The underlying simulation protocol is the way to interact with a simulation server. It defines how to call operations, how to get the state of an interface and how to trigger sequences. The simulation server currently supports the ObjectLink protocol which is available in the ObjectLink section.