npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@awarns/tracing

v1.0.0

Published

AwarNS Framework package that eases the tracing and debugging of complex task execution workflows

Downloads

106

Readme

@awarns/tracing

npm (scoped) npm

Background execution flows can become quite complex when using the AwarNS Framework, which is not necessarily a bad thing. This module aids at debugging such workflows, thanks to a set of decorators and tasks which allow to keep track of task executions and the raise of certain events. The recorded traces can later be queried and exported to a local file. Optionally, it is possible to automatically store the recorded traces in an external data store (e.g., a backend).

Install the plugin using the following command line instruction:

ns plugin add @awarns/tracing

Usage

After installing and configuring this plugin, you'll be granted with two interaction mechanisms to work with it:

  1. The plugin API. Through it, you'll be able to "decorate" existing tasks, to keep track of their execution. Then, you can query the recorded execution traces and export them using the most common information exchange formats.
  2. Tasks to track the raise of certain events. Sometimes, the execution of a task itself is not interesting, but just one (or more) of the events it produces. Alternatively, the event generator might not be a task, but some UI code emitting an event in a very specific situation. If the rise of these events is relevant to your application, you can keep track of them using these tasks.

Setup

This plugin requires you to register its loader during the framework initialization, like this:

// ... platform imports
import { awarns } from '@awarns/core';
import { demoTasks } from '../tasks';
import { demoTaskGraph } from '../graph';
import { registerTracingPlugin } from '@awarns/tracing';

import { externalTracesStore } from './external-store';

awarns
  .init(
    demoTasks,
    demoTaskGraph,
    [
      registerTracingPlugin({
        externalTracesStore: externalTracesStore,
        oldTracesMaxAgeHours: 7 * 24 // 1 week
      }),
    ]
  )
  // ... handle initialization promise

Plugin loader config parameter options:

| Property | Type | Description | |------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | externalTracesStore | TracesStore | (Optional) Inject an adapter to an external traces store and enable automatic upload of the recorded traces. The table below describes the methods that this adapter needs to implement | | oldTracesMaxAgeHours | number | (Optional) Tell the plugin to regularly cleanup old local traces. By default, all traces are kept |

TracesStore (external)

| Method | Return type | Description | |------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------| | insert(trace: Trace) | Promise<void> | Persist the given trace. Throw an error if something goes wrong. The write will be retried during the next app initialization |

Due to that, for now, this plugin only supports one-way synchronization, the rest of the methods are meant for future use and don't need to be implemented at the moment. You can throw unimplemented errors inside them, so that you can more easily recognize when they start being used in future versions.

API

The API of this plugin can be classified in 3 groups: task decorator, traces' storage and data exporters.

Task decorator

makeTraceable

In the task decorator group, there is the makeTraceable function, which allows to decorate one or more tasks to keep track of their execution, with the following parameters (see full example usage here):

| Parameter | Type | Description | |----------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------| | tasksToTrace | Array<Task> | An array including all the tasks that will be decorated to keep track of their execution | | config | TracerConfig | (Optional) Allows to adjust some configuration options of the tracer. See TracerConfig properties for more |

The makeTraceable function returns an array of decorated tasks.

TracerConfig

| Property | Type | Description | |------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------| | outputsSensitiveData | boolean | Indicates the tracer that the tasks being tracked outputs sensitive information that should not be recorded. Defaults to false |

Traces storage

tracesStore

In the traces' storage group, there is the tracesStore singleton object, with the following methods:

| Method | Return type | Description | |------------------------------------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | insert(record: Record) | Promise<void> | Persist the given trace. On success, if provided during plugin initialization, it will try to automatically write the new trace to the external store | | getAll(reverseOrder?: boolean, limitSize?: number) | Promise<Array<Trace>> | Allows to retrieve the current latest (by default) or first traces, optionally limiting the resulting list in size | | list(size?: number) | Observable<Trace> | Allows to observe the "n" most recent traces, where "n" is determined by the value given to the size parameter. By default, size is 100 | | clear() | Promise<void> | Allows to clear all the stored traces from the local database. Note: to only remove old traces, configure the oldTracesMaxAgeHours option during plugin initialization | | changes (property) | Observable<Array<string>> | Listen to this observable property to know when a trace has been created. It propagates updates on the ids of the traces that have been recently stored |

Note: It is recommended to install RxJS, to operate with the methods that return an Observable.

Trace

| Property | Type | Description | |-------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | id | string | The unique id of the trace | | chainId | string | The id of the chain that the trace belongs to. A chain is a succession of event rises and task executions, which originate from the same starting event | | type | TraceType | Can either be task or event depending on what originated the trace | | name | string | The name of the task or the event that originated the trace | | result | TraceResult | Can either be OK or error. This value is always OK for event traces, since, if something goes wrong, the event won't rise at all | | timestamp | Date | The date and time when the trace was originated | | content | object | Task traces and event traces follow a different structure in their content property. Event traces will contain here the payload of the event, unless it has been declared that the event contains sensitive data, in which case, it will hold an empty ({}) object. The content of task traces has a fixed structure, which can be seen below |

Trace content (Task)

| Property | Type | Description | |-------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | emitted | string | The name of the event emitted by the task | | outcome | string | The payload included in the event emitted by the task. If outputsSensitiveData is set to true in the tracer config, this property will hold an empty object ({}) instead | | message | string | If an error was thrown during the execution of the task, its stack trace will appear here | | took | number | The task execution time, in milliseconds |

Export data

createRecordsExporter

In the final group, the data exporters group, there is the createTracesExporter() function, with the following parameters:

| Parameter | Type | Description | |------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | folder | Folder | System folder object. Use NativeScript FileSystem API to define where the exports file will be saved | | format | 'csv' | 'json' | Select the information exchange format to use. Defaults to csv | | fileName | string | (Optional) Specify the file name to use for the exports file (without extension). Defaults to current date and time |

The createRecordsExporter() returns an Exporter object with the following API:

Exporter

| Method | Return type | Description | |------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------| | export() | Promise<ExportResult> | Tell the exporter to export the traces, and save them inside to the configured exports file. Returns an ExportResult once done |

ExportResult

| Property | Return type | Description | |---------------|-------------|--------------------------------------------------| | exportCount | number | The amount of traces that have been exported | | fileName | string | The name of the exports file that has been saved |

Tasks

| Task name | Description | |-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | trackEvent | Generates an event trace containing the information regarding the event that invoked its execution | | trackSensitiveEvent | Generates an event trace containing the information regarding the event that invoked its execution. The payload of the event will be ignored, since it is considered to contain sensitive information |

Track regular events

To register this task for its use, you just need to import it and call its generator function inside your application's task list:

import { Task } from '@awarns/core/tasks';
import { trackEventTask } from '@awarns/tracing';

export const demoTasks: Array<Task> = [
  trackEventTask(),
];

Task generator parameters:

The task generator takes no parameters.

Task output events:

  • trackEventFinished (default, no content)

Example usage in the application task graph:

on('startEvent', run('trackEvent')); // Include some payload data in your start event, 
                                     // to see how it becomes recorded too

Track events containing sensitive information

To register this task for its use, you just need to import it and call its generator function inside your application's task list:

import { Task } from '@awarns/core/tasks';
import { trackSensitiveEventTask } from '@awarns/tracing';

export const demoTasks: Array<Task> = [
  trackSensitiveEventTask(),
];

Task generator parameters:

The task generator takes no parameters.

Task output events:

  • trackSensitiveEventFinished (default, no content)

Example usage in the application task graph:

on('startEvent', run('trackSensitiveEvent')); // Include some payload data in your start event, 
                                              // to see how it does not appear in the event trace

License

Apache License Version 2.0