Skip to content

Latest commit

 

History

History
57 lines (42 loc) · 1.23 KB

README.md

File metadata and controls

57 lines (42 loc) · 1.23 KB

connect_tester.js

Testing connection of clientside application.

Sometimes you need to know if your user has slow connection and you want to suggest gracefully degraded version of your app. connect_tester.js downloads a file from server once in a while to allow you to determine how long did it take to make assumptions on how slow it is.

Usage

Create tester:

var tester = new ConnectTester();

Set image url for testing, a callback for processing test results and run:

tester.test('xxx.png').onChange(cb).run();

You can specify the timeout in milliseconds for the permanent checking:

tester.test('xxx.png').every(40000).onChange(cb).run();

Enabling debug mode:

tester.test('xxx.png').every(40000).onChange(cb).debug().run();

Сallback for processing test takes a delay getting the picture in milliseconds. Based on it, you can calculate the download bandwidth:

function(duration){
    var kbps = (image_size_in_bytes * 8) / (duration / 1000) / 1024;
}

Full example

(new ConnectTester)
    .test('xxx.png')
    .every(40000)
    .debug()
    .run()
    .onChange(function(duration){
        var kbps = (image_size_in_bytes * 8) / (duration / 1000) / 1024;
        // ...
    });