Dev Tools

Overview

The io.Connect Dev Tools are meant to help both developers and non-technical users to better understand the processes taking place inside the interop-enabled apps. They deliver useful internal framework information in an intuitive and user-friendly UI.

This information is useful when testing app integration, app performance or app interaction with other apps or contexts within the io.Connect environment. Testing your app behavior doesn't require the use of mock apps for the debugging process - you can directly see and interfere with the processes taking place between real apps, in real time. Whether you are a single developer working on the compatibility of an app with io.Connect, or you collaborate with other dev teams and want to ensure cross-team method implementation consistency, the Dev Tools provide powerful means to extract and monitor the necessary information.

Launch each Dev Tool from the Dev Tools Launcher app accessible from the io.Connect launcher.

Dev Tools Launcher

Available apps:

In addition, the following tools are also available for debugging:

  • Applications View - a tool that provides general overview of all running hidden or visible apps.
  • Press F12 on a focused io.Connect Window to open the built-in browser developer console.
  • Add DevTools Extensions supported by Electron to io.Connect Desktop. For more details, see the More > Features > Adding DevTools Extensions section.

Application Monitor

The Application Monitor provides an overview of all apps running in io.Connect Desktop and their performance. This tool is useful when you want to gain a general perspective of how an app (or several apps) behaves within io.Connect Desktop. See how much time it takes for io.Connect Desktop to load your app, how long has the app been running, what potential issues your app has or may cause and compare the performance of different apps.

Application Monitor

Enabling Performance Tracking

The Application Monitor is disabled by default. To be able to use the Application Monitor and the Performance Report, enable the tracking of app performance information from the io.Connect Desktop system configuration.

Configure the "performanceTracker" top-level key in the system.json file of io.Connect Desktop to enable performance tracking:

{
    "performanceTracker": {
        "enable": true,
        "trackAutoStarted": false,
        "isTrackingEnabled": true
    }
}
Property Type Description
"enable" boolean If true, will enable tracking apps in the Application Monitor.
"trackAutoStarted" boolean If true, will track the performance of auto started io.Connect apps.
"isTrackingEnabled" boolean If true, will enable gathering and sending app performance information to the Performance Report.

Toolbar

The Application Monitor toolbar offers the following grid display controls:

Button Description
Clear Removes all currently displayed apps from the grid. Use when you want to monitor only newly launched apps.
Show All Shows all cleared apps again.
Pause Freezes the Application Monitor to its current state and ignores all new updates.
Issues Opens a window with issue messages.
Help Opens a browser window with the Dev Tools documentation.

The "Show All" and "Clear" buttons don't work when you use "Pause".

Toolbar

Rows

Each row represents an app and the information inside it is updated every 2 seconds.

  • "Report" button - opens a new window with a Performance Report for an individual app.
  • "Performance Report" button - select several apps and click the "Performance Report" button at the bottom to open a Performance Report for the selected apps.

To focus an app, double click anywhere on its row. This action will also show a hidden app for a limited period of time (20 seconds), in case you need to open a browser dev console for it, for example.

Focus

Columns

Columns are classified in 3 logical groups:

  • App information - Type, PID, Window ID, State, Glue Version;
  • Resource consumption (hidden by default) - CPU, Memory, Max CPU, Max Memory;
  • Internal performance information - Creation Time, Load Time (hidden by default), Glue Load and Issues;

Right click anywhere in the app information grid to choose which columns to show/hide. Drag and drop columns to reorder them.

Reorder

Column Description
NAME The name is the app name registered in the io.Connect launcher.
TYPE The type of the monitored app.
PID The ID of the window process.
WINDOW ID The io.Connect Window ID.
CREATION TIME The exact time the window was created.
STATE The current window state: maximized, minimized or normal.
ISSUES The number of issues found.
CPU The current CPU usage of the process. (There might be multiple windows in one process and all will show the same CPU usage.)
GLUE VERSION The io.Connect framework specific version (JavaScript, .NET, Java) that the app uses.
GLUE LOAD The time that io.Connect Desktop takes to load your app.
MAX CPU The maximum CPU usage recorded since the start.
MEMORY The memory used by the process.
MAX MEMORY The maximum private memory recorded since the creation of the window.
LOAD TIME The time between the first and the last recorded events for the app - e.g., from creating the window to the last request made.

Performance Report

Performance Report is a tool for finding performance issues of apps running in io.Connect Desktop. It is useful for delving into performance, requests, issues and also enables you to compare app performance. To initiate Performance Report for a single app, click the "Report" button at the end of the row of the respective app. For Performance Report for multiple apps, select the desired apps and click the Performance Report button at the bottom of the window.

Initiate

Performance Report visualizes all events happening during the life cycle of an app. The tool shows information about all requests, redirects, console messages, errors and issues. There are 4 groups of built in events.

Built-in Event Types

Browser Events

The browser events are defined using the Performance Timing API which offers smart mappings that define when the browser considers a page as loaded, how much time CSS and media take to load, etc.

Some use cases defined as browser events:

  • TcpConnection - measures the TCP connection time (the establishing of a connection) using the connectStart and connectEnd events;
  • DNS - DNS lookup time using the events domainLookupStart and domainLookupEnd;
  • DomProcessing - HTML parsing time using the events domLoading and domInteractive;
  • subresourceLoadTime - sub-resources (CSS, images) loading time using the domInteractive and domContentLoaded events;
  • loaded - document loading time using the loadEventStart and loadEventEnd events;
  • request - measures the HTTP request/response transaction time using the requestStart and responseEnd events;

Platform Events

All events grouped as "Glue" events (connection, interop, appManager, io, etc.) measure the time it takes to initialize the respective io.Connect components. These events mark the important initialization stages io.Connect goes through in order for you to be able to use it in your app.

Electron Events

All Electron events - refreshes, interactions, events concerning browser/window creation, etc.

Requests

Network requests and redirects made by the monitored apps.

Event Visualization

Events are visualized in 2 different ways - Data Grid and Timeline.

Data Grid

Data Grid

The Data Grid view provides easy filtering, sorting and exporting to Excel (from the right-click context menu). It also has a visual representation in time in the last column.

Timeline

Timeline

The Timeline view shows the events on a time chart. If you want to find out which apps/events take up the most time, this view will help you. Zoom and drag the timeline chart to see when events take place in comparison to other events. The chart supports comparison of events with a big time difference between them. Unused space on the chart is cut off.

Requests View

Requests

All requests grouped by app with their time, status code, status text and size.

Console Messages View

Console Messages

A unified view of all console messages of all monitored apps. Start the Chrome Dev Tools from this tab (convenient for hidden apps).

Issues View

Issues

An Issue is a pre-defined rule that has been broken:

  • Long Requests - requests that take more than 2 seconds;
  • Duplicated Requests - a request made more than once in a single run and might be an unnecessary duplicate request.

Context Viewer

Many apps use some type of io.Connect context to interact with other apps in the io.Connect environment. The Context Viewer provides a convenient way for a developer to edit and track the changes of a context object - an io.Connect Window context, a shared context or a Channel context.

Editing and tracking context updates is useful if you want to ensure that your app interacts with context objects as intended. The visual aid and action options provided by the Context Viewer enable you to check whether your app updates the context correctly and whether it reacts to context updates as expected. In some cases, context updates may be happening very frequently rendering the task of retracing the process very difficult. In other cases, an app may be breaking the accepted context data format which in turn causes all other apps interacting with that context object to break. In such situations, the Context Viewer tool greatly simplifies the debugging process.

Using the Context Viewer

The Context Viewer tracks the following types of contexts in the io.Connect framework:

From the left menu, choose a context type and click on a specific context to display it in the Main Editor page.

Main Editor

Filter contexts by name, hide and show the Sidebar, create a new context, start "History Mode" for one or more contexts:

Sidebar

Manipulate a context directly in the Editor. Choose how to view the JSON data, search for properties in the context and more:

Editor

The following buttons may appear in the Editor toolbar:

Button Description
Save Saves the current context.
Update indicates that the context displayed in the editor isn't the latest one. This button will appear only if the "Auto Update" button is turned off. Click on it to update the context.
Auto Update when turned on, the Context Viewer will always display the latest context in the editor. If the context changes, the content in the editor will be automatically updated.

Context Manipulation

Edit the selected context in the Main Editor of the Context Viewer by directly overwriting context values or property names. Save the context from the "Save" button of the editor to see the changes.

In the example below the "Client List" app is listening for context updates on the "Red" io.Connect Channel. The context of the "Red" Channel is opened in the Main Editor of the Context Viewer. See how when the ID of a client is updated, the "Client List" app responds automatically by selecting the respective client:

Editing context

Tracking Context Change

The Context Viewer allows you to track how contexts change and to compare different context states.

In the example below, "History Mode" for the "Red" Channel is enabled, meaning that each update of the "Red" Channel context will be recorded as a context state. The Diff Tool displays a list of the context states (to the left) and the difference between two context states selected by the user (to the right):

Diff list

  • Click the "Start History Mode" button for the selected context to enable tracking context changes. Track multiple contexts simultaneously by enabling their "History Mode". To see the list of context states for a specific context, select the respective context from the Sidebar.

  • The Diff Tool displays a list of the states of the selected context and each state has a timestamp. Select two states ("A" and "B") to see the differences between them in the Diff Tool. The values in red are for state "A" and the values in green are for state "B".

  • To show a context state in the Main Editor, click the button to the right of the respective context state.

Tracking context changes

Interop Viewer

The Interop Viewer allows you to discover all Interop methods and streams registered by io.Connect Desktop and by your interop-enabled apps. Use custom arguments to invoke any Interop method or subscribe to any Interop stream through the Interop Viewer to monitor the results in real time without the need for mock apps.

The Interop Viewer enables you to test all registered Interop methods and streams to check whether they behave correctly or whether they have been registered in the correct format. It's useful when debugging your apps, as well as when working on a multi-team project - inspecting the method names and signatures will quickly let you know whether the generally accepted rules for method naming or method signatures are being followed.

The Interop Viewer has the following functionalities:

Discovering Methods

The main view of the Interop Viewer is the browsing section which shows a table with all registered Interop methods and streams. Click on any column header to sort the table by ascending or descending order. Drag and drop columns in the area above the table to group the table entries dynamically by single or multiple columns - e.g., drag the "Streaming" column and then the "Server" column to group the methods/streams first by streaming support and then by the servers offering them. Filter the table entries using the search field. To reset the table view, use the "Reset" button next to the search field.

Browsing section

Browsing section columns:

Column Description
SERVER The name (and window ID, if it exists) of the app that has registered the method.
METHOD NAME The name of the Interop method/stream.
ACCEPTS Method parameters signature.
RETURNS Method return value signature.
OBJECT TYPES A list of the composite data structures with which the method operates.
STREAMING Shows whether the method is registered as a stream.

To invoke an Interop method or subscribe to an Interop stream, click on its row and a new Invocation/Subscription tab will open containing details about the method/stream.

Invoking Methods

Select a method from the browsing section and click on its row to open it in a new tab:

Method tab

The method tab has three sections - Expected Input, User Input and Invocation Results:

  • Expected Input (top-left) - shows the signature of the argument(s) with which the Interop method expects to be invoked. All arguments must be wrapped in an object.

  • User Input (bottom-left) - allows you to specify arguments in JSON format with which to invoke the Interop method. The JSON object in the User Input will be prefilled with all required arguments and default values for them (zeros, empty strings, arrays or objects). Use the buttons in the User Input toolbar to format the JSON object, to make it compact (remove all whitespaces) or fix mistakes in it. An expandable menu at the bottom of the User Input section shows all Interop server offering this method - select one or more servers for which to invoke the method. Click the "Invoke" button to execute the invocation.

  • Invocation Results (right) - shows a list of results from all method invocations, successful (marked with a green circle) and unsuccessful (marked with a red circle). The header of each result panel shows the status of the method invocation, the name of the server on which the method was invoked, the invocation time (how long it took for the method to return a result) and an invocation timestamp. Switch between "Returned" and "Called with" to see the result from the invocation or the invocation arguments. Use the "Copy" button to copy the result as an object literal (if the invocation is unsuccessful, the object will be empty) to the clipboard. Click the "Use Call Arguments" button on the left of any result panel to use the same arguments for your next invocation.

Invocation results

Subscribing to Streams

Select a stream from the browsing section and click on its row to open it in a new tab:

Stream tab

The stream tab has three sections - Expected Input, User Input and Subscriptions:

The Expected Input (top-left) and User Input (bottom-left) sections are identical with the ones for invoking an Interop method and are described in the Invoking Methods section.

  • Subscriptions (right) - shows all subscriptions as timestamped tabs. The status of the subscription is shown as a colored circle in the tab - a blue circle signifies an active subscription, an empty circle signifies a suspended one, or one with error. Switch between "Stream" and "Called with" to see the data received from the stream or the arguments with which the subscription was made. Each subscription tab contains data entries received from the stream subscription. The subscription may be to one or more servers offering the same stream - the data entries from the different servers are color coded. Select a server from the "SERVERS" panel at the bottom of the Subscriptions section to show/hide the data entries from the respective servers. Click on the header of a data entry to expand or collapse it. Use the buttons in the left vertical panel of the Subscriptions section to control the subscription status and results. The "Use Call Arguments" button will insert the arguments from the currently selected subscription in the User Input section. The "Disconnect/Reconnect" button will stop/resume the subscription. The "Expand/Collapse Results" button will expand or collapse all data entries. The "Clear Results" button will remove all data entries. Expand a data entry to see the data chunk received from the stream. Use the "Copy" button to copy the data chunk as an object literal to the clipboard.