/tiny-server-timing

tiny-server-timing

Primary LanguageTypeScriptMIT LicenseMIT

tiny-server-timing npm build

A simple library for measuring execution time of your functions and building Server-Timing HTTP header.

Install

npm install tiny-server-timing

# or

yarn add tiny-server-timing

# or

pnpm add tiny-server-timing

Usage

import { ServerTiming } from "tiny-server-timing";

const timing = new ServerTiming();

timing.start("task");
runSomeTask();
timing.end("task");

// or you can manually add a timing entry
timing.add("foo", 123456);

const headers = timing.getHeaders();

console.log(headers);
// { 'Server-Timing': 'task;dur=45.08, foo;dur=123456.00' }

You can also use time and timeAsync methods to automatically time a task:

import { ServerTiming } from "tiny-server-timing";

function getSomeDataFromDb() {
    // do some work here
    return "foobar";
}

const timing = new ServerTiming();

const dataFromDb = timing.time("db", () => getSomeDataFromDb());

console.log(dataFromDb);
// foobar
console.log(timing.getHeaders());
// { 'Server-Timing': 'db;dur=0.11' }

ServerTiming constructor can also accept options:

import { ServerTiming } from "tiny-server-timing";

const timing = new ServerTiming({
    autoEnd: false, // automatically end all pending tasks when getHeaders is called
    precision: 2, // how many decimal points to use for timings
    allowOrigin: "https://example.com, https://foo.bar", // value of Timing-Allow-Origin header
});

timing.add("bar", 123);

console.log(timing.getHeaders());
// {
//   'Server-Timing': 'bar;dur=123.00',
//   'Timing-Allow-Origin': 'https://example.com, https://foo.bar'
// }