http://cloudharmony.com/speedtest-for-google:compute 提供了一个js API,但我不知道如何使用它。
function ch_st_loaded(speedtest) {
/*
* CALLBACK OBJECT
* cloudharmony-speedtest Sample Callback Object
*
* This Javascript object demonstrates the callback methods and corresponding
* API documentation for cloudharmony-speedtest. All methods in this
* object are optional (the speedtest checks if methods exist before invoking).
*/
var st_callback = function() {
/*
* This method is invoked before the speedtest starts. If it returns false
* test execution will stop
*
* @param array tests an ordered array representing the tests to be performed
* and the test order. Each item in the array is an object with the following
* attributes:
* concurrency: (optional) concurrency for downlink/uplink tests - this
* signifies the number of concurrent threads that will be used during
* each test iteration. Test result metrics are an aggregation of metrics
* for each thread
* duration: estimated test duration in seconds
* iterations: total number of test iterations to be performed - including
* warmup iterations
* location: (optional) location metadata for the test endpoint - an object
* with these attributes: city, state, country, lat, long. Not present
* for endpoints without location information (e.g. CDN, DNS)
* max_size: (optional) maximum size (KB) for uplink/downlink tests
* min_size: (optional) minimum size (KB) for uplink/downlink tests
* provider_id: identifier of the provider (e.g. aws) - see
* https://cloudharmony.com/docs/api#!/api/Get_Providers
* region: (optional) identifier of the service region (e.g. us-east-1) - see
* https://cloudharmony.com/docs/api#!/api/Get_Service
* service: name of the service (e.g. Amazon EC2)
* service_id: identifier of the service (e.g. aws:ec2) - see
* https://cloudharmony.com/docs/api#!/api/Get_Services
* service_type: service type identifier - one of: cdn, compute, dns, paas,
* storage
* subregion: (optional) identifier of the provider subregion (e.g. us-east-1a)
* type: test type identifier - one of: downlink, uplink, latency, dns
* warmup: number of warmup iterations - these precede test iterations and
* are excluded from result metrics
*
* @param object types object with keys corresponding with every test type and
* values describing associated test parameters. Value objects include the
* following attributes:
* duration: total estimated duration for all tests of this type in seconds
* tests: total number of tests of this type
* @return boolean
*/
// var google_compute_test = {
// provider_id:"google",
// service_id:"compute"
// };
// var tests = [google_compute_test];
// var types = [{type:"downlink"}];
this.started = function(tests, types) {
console.log("START CALLBACK");
console.log(tests);
console.log(types);
};
/**
* This method is invoked when testing ends or is cancelled
*
* @param boolean complete false if testing was stopped before all tests were
* completed (e.g. speedtest.stop() invoked)
* @return void
*/
this.stopped = function(complete) {
console.log("STOPPED CALLBACK: complete - " + complete);
};
/*
* This method is invoked when a new test begins and following each test
* iteration. If it returns false, 'test' will be aborted and testing
* advanced to the next test
*
* @param object test object representing the test this progress pertains to
* (see started method API documentation above for object attributes)
* @param object progress an object describing the the test progress. This
* object contains the following attributes:
* bytes: total number of bytes transferred for this test
* failed: current number of failed iterations. Test will be aborted if 3
* iterations fail
* iteration: test iteration for this progress (0 if test is starting)
* iterations: total test iterations (warmup + test iterations)
* progress: completion percentage for this test
* remaining: number of iterations remaining (i.e. iterations - iteration)
* success: number of successful iterations completed
* time_remaining: estimated time remaining for this test in seconds
* tests_progress: completion percentage for ALL tests
* tests_remaining: number of tests remaining
* tests_time_remaining: estimated time remaining for ALL tests in seconds
* type_progress: completion percentage for ALL tests of this type
* type_remaining: number of tests remaining of this type
* type_time_remaining: estimated time remaining for ALL tests of this type
* in seconds
* warmup: true if this progress is for a warmup iteration. warmup
* iteration metrics are excluded from results
* @return boolean
*/
this.progress = function(test, progress) {
console.log("PROGRESS CALLBACK");
console.log(test);
console.log(progress);
return true;
};
/*
* This method is invoked when test finishes. If it returns false, testing
* will stop, otherwise it will advance to the next test
*
* @param object test object representing the test these results pertains to
* (see started method API documentation above for object attributes)
* @param object results an object containing details of the test results.
* This object contains the attributes below (* attributes present only if
* status is not 'failed'). Metrics are milliseconds (ms) for latency or dns
* tests, and megabits per second (Mb/s) for uplink or downlink tests:
* bytes: total bytes transferred for this test including warmup iterations
* fastest*: fastest result metric
* failed: number of failed iterations (including warmup)
* mean*: mean result metric
* median*: median result metric
* metric10*: 10th percentile result metric (slowest)
* metric25*: 25th percentile result metric
* metric75*: 75th percentile result metric
* metric90*: 90th percentile result metric (fastest)
* metrics*: array containing all result metrics (warmup excluded)
* sequence: test sequence number (first test sequence=1)
* slowest*: slowest result metric
* secure: true if HTTPS protocol used for testing
* status: test status - one of: success, partial, failed
* stdev*: sample standard deviation for test metrics (warmup excluded)
* @return boolean
*/
this.results = function(test, results) {
console.log("RESULTS CALLBACK");
console.log(test);
console.log(results);
};
return this;
};
var uplinkRedirectUri = "test.html"; // change this to the URI where up.html is accessible on your server
console.log(speedtest.start(st_callback, uplinkRedirectUri));
}
<!DOCTYPE html>
<html>
<head>
<script async type="text/javascript" src="http://cloudharmony.com/rum/speedtest-google:compute.js"></script>
</head>
<body>
</body>
</html>
我希望js控制台记录一些内容,但是除了speedtest.start
被调用并返回true(即记录了1)之外,没有其他内容。
我查看了开发工具的“网络”标签,发送了很多请求,因此异步脚本似乎正在运行。
答案 0 :(得分:0)
我最终修改了http://cloudharmony.com/rum/speedtest-google:compute.js
代码太长,无法容纳在这里。
在console.log(method+"("+args.length+"):"+JSON.stringify(args));
中添加了行cb=function(method, args){ ... }