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 🙏

© 2025 – Pkg Stats / Ryan Hefner

jsbandwidth

v1.1.2

Published

JsBandwidth - the JavaScript net speed test

Downloads

20

Readme

Bower NPM License Build Status

NPM

JSBandwidth

To test inside a browser the bandwidth and latency, there's no easy way. This is what JsBandwidth tries to achieve.

This project was initially forked from https://code.google.com/p/jsbandwidth/. At this moment it became a total rewrite.

License

I decided to keep the same license as the initial project, MIT.

Installation

npm install jsbandwidth

Browser support

This library is using XMLHttpRequest and Promise. XMLHttpRequest is supported starting with IE7. For older browsers (are you serious?) you can use this shim. For browsers that do not feature Promise support you can use any of the following shims:

  • https://github.com/jakearchibald/es6-promise
  • https://github.com/taylorhakes/promise-polyfill
  • https://github.com/getify/native-promise-only

If your shim is not here, please drop me an email or enter a new issue to include it.

Server-side set-up

  1. Set up a web server of your choice.
  2. Depending on your web server, drop the corresponding project files in your web server's document root (or a sub-directory, if you wish). What src/main/webapp/post.* file you should choose depends on your web server. The upload test needs to be able to send a POST request to the server. The receiving page doesn't have to do anything with the data. However, some servers will not allow you to send a POST request to a .htm file. Therefore, the project includes several blank server side script files (post.aspx, post.php, post.pl). src/main/webapp/test.bin is mandatory, but it's nothing more than random bytes.

Spring Controller

If you want to use a Spring Controller to post test data you can define a controller method like this

@RequestMapping("/test-post")
public @ResponseBody String testPost() {
	return "true";
}

and then specify options.uploadUrl='/test-post'. TestController is a fully working Spring controller.

Please be aware that some servers, like Tomcat, by their default setup can impose a limit on the upload data size to avoid DoS attacks. You either modify that setup or specify options.uploadDataMaxSize.

JavaScript API

The JavaScript API works with both Angular and jQuery, depending on what library is included (if both, Angular is preferred).

First you need to get hold of the jsBandwidth object.

  • In Angular
  • With require

The jsBandwidth object has 3 methods with a similar signature:

  • testLatency(options)
  • testDownloadSpeed(options)
  • testUploadSpeed(options)
  • testSpeed(options) which combines all the above into one

The options parameter is an object and it has the following fields

  • latencyTestUrl the URL used for latency testing. Usually a big binary content is expected to be downloaded. If not specified, it is considered to be the same as downloadUrl, but requested with HEAD method.
  • downloadUrl the URL used for download speed testing. Usually a big binary content is expected to be downloaded.
  • uploadUrl the URL used for upload speed testing. It should accept a POST method.
  • uploadData the data that is sent to the server to test the upload
  • uploadDataMaxSize if specified uploadData is going to be truncated to this maximum length. Some servers, like Tomcat, by their default setup can impose a limit on the upload data size to avoid DoS attacks. You either modify that setting or use options.uploadDataMaxSize. The usual limit is 2Mb.
  • uploadDataSize if uploadData is not specified, then a chunk of this size is randomly generated instead
  • 'ajax' the AJAX service, either from jQuery or $http from Angular. If not specified, it will be automatically detected depending whether jQuery or Angular is included.

All three methods return a promise and you can use the then method. That promise is also augmented with a cancel() method.

Example

var jsBandwidth = require("jsbandwidth");
jsBandwidth.testSpeed(options)
	.then(function (result) {
			console.log("Latency is " + result.latency + " ms, download speed is " + result.downloadSpeed + "bps and upload speed is " result.uploadSpeed + "bps");
		},
		function(error) {
			console.log("An error occured during net speed test.");
		});

Angular controller

An Angular controller, called JsBandwidthController, is provided for your convenience. The controller uses the service and it defines the following fields/methods in the scope

  • test this is the service running the speed test. If null or undefined, there's no test currently running, so it can be used for checking if a speed test is currently running.
  • options the options used to run the speed test
  • result.latency the estimated latency in ms. If result is null or undefined, the test is in progress or ended with an error.
  • result.downloadSpeed the estimated download speed in bps.
  • result.uploadSpeed the estimated upload speed in bps.
  • error if null or undefined, then a test is in progress or completed successfully. If not null, then an error occured during the last speed test.
  • error.status the error status

'complete` event is emitted when the test is completed or 'error' if an error occured.

Below is an example on how to use it in your page:

<div data-ng-controller="JsBandwidthController" class="netSpeedTest"
		data-ng-init="options.downloadUrl='/test.bin';">
	<span data-ng-if="error">
		<span>Error</span>: <span data-ng-bind="error.status"></span>
	</span>
	<span data-ng-if="result">
		<span>Latency:</span>
		<span data-ng-bind="result.latency"></span><span>ms</span>
		<span>Download speed:</span>
		<span data-ng-bind="convertToMbps(result.downloadSpeed)"></span><span>Mbps</span>
		<span>Upload speed</span>
		<span data-ng-bind="convertToMbps(result.uploadSpeed)"></span><span>Mbps</span>
	</span>
	<button data-ng-if="!test" data-ng-click="start()" class="start">Start test</button>
	<button data-ng-if="test" data-ng-click="cancel()" class="cancel">Cancel test</button>
</div>

Formatting

The speed is calculated in bps (bits per second). In the Angular controller you have the method convertToMbps for your convenience. If you want to format it differently, you can use js-quantities.

How to get support

  • Ask a question on StackOverflow
  • Fill in an issue.

Development

How to make a new release

  1. Change the version number in bower.json and package.json
  2. Create a new release in github with the same name for tag and title as the version number (e.g. 1.0.0). Do not forget to include the changelog in the release description.
  3. Run npm publish to publish the new version to npm

Testing

To run the tests do npm run test.