次のプロバイダーがあります。
angular.module('MyApp').provider('MyDevice', function () {
var ngInjector = angular.injector(['ng']),
$window = ngInjector.get('$window');
function isMobileDevice () {
return (/iPhone|iPod|iPad|Silk|Android|BlackBerry|Opera Mini|IEMobile/)
.test($window.navigator.userAgent || $window.navigator.vendor || $window.opera);
}
this.$get = function () {
return {
isDesktop: function () {
return !isMobileDevice();
},
isMobile: function () {
return isMobileDevice();
}
};
};
});
そして、次のテスト仕様:
describe('MyDeviceProvider', function () {
var myDevice;
beforeEach(function () {
inject(['MyDevice', function (_myDevice_) {
myDevice = _myDevice_;
}]);
});
it('Test #1', function () {
// Mock '$window.navigator.userAgent' to "desktop"
expect(myDevice.isDesktop()).toEqual(true);
expect(myDevice.isMobile()).toEqual(false);
});
it('Test #2', function () {
// Mock '$window.navigator.userAgent' to "mobile"
expect(myDevice.isDesktop()).toEqual(false);
expect(myDevice.isMobile()).toEqual(true);
});
});
私の質問は、どうすれば$window
両方をモックしTest #1
てTest #2
成功させることができるでしょうか? $provide.value
無数のオブジェクトを試してみましたが、テストを実行spyOn
する価値をあざけることができないようです。$window.navigator.userAgent
これを解決するにはどうすればよいですか?
PS: 上記のコードは、私の問題のデモンストレーションとしてのみ機能し、アプリケーションの特別な要件のため、プロバイダーをサービスに変更できません。