2014-11-29 04:29:30 +00:00
|
|
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
|
|
|
|
|
|
|
define(
|
|
|
|
["../src/TelemetryAggregator"],
|
|
|
|
function (TelemetryAggregator) {
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
describe("The telemetry aggregator", function () {
|
|
|
|
var mockQ,
|
|
|
|
mockProviders,
|
2014-12-30 22:00:20 +00:00
|
|
|
mockUnsubscribes,
|
2014-11-29 04:29:30 +00:00
|
|
|
aggregator;
|
|
|
|
|
|
|
|
function mockPromise(value) {
|
|
|
|
return {
|
|
|
|
then: function (callback) {
|
|
|
|
return mockPromise(callback(value));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
function mockProvider(key, index) {
|
|
|
|
var provider = jasmine.createSpyObj(
|
2014-12-30 22:00:20 +00:00
|
|
|
"provider" + index,
|
|
|
|
[ "requestTelemetry", "subscribe" ]
|
|
|
|
),
|
|
|
|
unsubscribe = jasmine.createSpy("unsubscribe" + index);
|
2014-11-29 04:29:30 +00:00
|
|
|
provider.requestTelemetry.andReturn({ someKey: key });
|
2014-12-30 22:00:20 +00:00
|
|
|
provider.subscribe.andReturn(unsubscribe);
|
|
|
|
|
|
|
|
// Store to verify interactions later
|
|
|
|
mockUnsubscribes[index] = unsubscribe;
|
2014-11-29 04:29:30 +00:00
|
|
|
return provider;
|
|
|
|
}
|
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
mockQ = jasmine.createSpyObj("$q", [ "all" ]);
|
|
|
|
mockQ.all.andReturn(mockPromise([]));
|
|
|
|
|
2014-12-30 22:00:20 +00:00
|
|
|
mockUnsubscribes = [];
|
2014-11-29 04:29:30 +00:00
|
|
|
mockProviders = [ "a", "b", "c" ].map(mockProvider);
|
|
|
|
|
|
|
|
aggregator = new TelemetryAggregator(mockQ, mockProviders);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("passes requests to aggregated providers", function () {
|
|
|
|
var requests = [
|
|
|
|
{ someKey: "some value" },
|
|
|
|
{ someKey: "some other value" }
|
|
|
|
];
|
|
|
|
|
|
|
|
aggregator.requestTelemetry(requests);
|
|
|
|
|
|
|
|
mockProviders.forEach(function (mockProvider) {
|
|
|
|
expect(mockProvider.requestTelemetry)
|
|
|
|
.toHaveBeenCalledWith(requests);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("merges results from all providers", function () {
|
|
|
|
var capture = jasmine.createSpy("capture");
|
|
|
|
|
|
|
|
mockQ.all.andReturn(mockPromise([
|
|
|
|
{ someKey: "some value" },
|
|
|
|
{ someOtherKey: "some other value" }
|
|
|
|
]));
|
|
|
|
|
|
|
|
aggregator.requestTelemetry().then(capture);
|
|
|
|
|
|
|
|
// Verify that aggregator results were run through
|
|
|
|
// $q.all
|
|
|
|
expect(mockQ.all).toHaveBeenCalledWith([
|
|
|
|
{ someKey: 'a' },
|
|
|
|
{ someKey: 'b' },
|
|
|
|
{ someKey: 'c' }
|
|
|
|
]);
|
|
|
|
|
|
|
|
expect(capture).toHaveBeenCalledWith({
|
|
|
|
someKey: "some value",
|
|
|
|
someOtherKey: "some other value"
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-12-30 22:00:20 +00:00
|
|
|
it("broadcasts subscriptions from all providers", function () {
|
|
|
|
var mockCallback = jasmine.createSpy("callback"),
|
|
|
|
subscription = aggregator.subscribe(mockCallback);
|
|
|
|
|
|
|
|
// Make sure all providers got subscribed to
|
|
|
|
mockProviders.forEach(function (mockProvider) {
|
|
|
|
expect(mockProvider.subscribe).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
// Verify that unsubscription gets broadcast too
|
|
|
|
mockUnsubscribes.forEach(function (mockUnsubscribe) {
|
|
|
|
expect(mockUnsubscribe).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
subscription(); // unsubscribe
|
|
|
|
mockUnsubscribes.forEach(function (mockUnsubscribe) {
|
|
|
|
expect(mockUnsubscribe).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|
2014-11-29 04:29:30 +00:00
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|