diff options
| author | pliablepixels <pliablepixels@gmail.com> | 2016-04-10 10:47:35 -0400 |
|---|---|---|
| committer | pliablepixels <pliablepixels@gmail.com> | 2016-04-10 10:47:35 -0400 |
| commit | a29f9a676a6ea3bad56ede05cd1a1c82ffbbe8e9 (patch) | |
| tree | 7e6e6bfb23390a64344fdfe2272a5da04c2dd97c /www/lib/ngCordova/dist/ng-cordova-mocks.js | |
| parent | 42bc21f7d0b4acfeefa5f4c2708203be78f57778 (diff) | |
#219 - everything upgraded
Former-commit-id: 15f58d10df83feda8199a1b904433e625ef36b44
Diffstat (limited to 'www/lib/ngCordova/dist/ng-cordova-mocks.js')
| -rw-r--r-- | www/lib/ngCordova/dist/ng-cordova-mocks.js | 508 |
1 files changed, 493 insertions, 15 deletions
diff --git a/www/lib/ngCordova/dist/ng-cordova-mocks.js b/www/lib/ngCordova/dist/ng-cordova-mocks.js index 3d59dc84..0cf15abd 100644 --- a/www/lib/ngCordova/dist/ng-cordova-mocks.js +++ b/www/lib/ngCordova/dist/ng-cordova-mocks.js @@ -1,11 +1,49 @@ /*! * ngCordova - * v0.1.20-alpha + * v0.1.26-alpha * Copyright 2015 Drifty Co. http://drifty.com/ * See LICENSE in this repository for license information */ (function(){ var ngCordovaMocks = angular.module('ngCordovaMocks', []); +/** + * @ngdoc service + * @name ngCordovaMocks.cordovaActionSheet + * + * @description + * A service for testing action sheet + * in an app build with ngCordova. + **/ +ngCordovaMocks.factory('$cordovaActionSheet', ['$q', function ($q) { + var throwsError = false; + + return { + /** + * @ngdoc property + * @name throwsError + * @propertyOf ngCordovaMocks.cordovaActionSheet + * @type Boolean + * + * @description + * A flag that signals whether a promise should be rejected. + * This property should only be used in automated tests + */ + throwsError: throwsError, + + show: function () { + var defer = $q.defer(); + + if (this.throwsError) { + defer.reject('There was an error on showing action sheet'); + } else { + defer.resolve(); + } + + return defer.promise; + } + }; +}]); + ngCordovaMocks.factory('$cordovaAppVersion', ['$q', function ($q) { var throwsError = false; return { @@ -118,7 +156,7 @@ ngCordovaMocks.factory('$cordovaBarcodeScanner', ['$q', function ($q) { * A service for ble features * in an app build with ngCordova. **/ -ngCordovaMocks.factory('$cordovaBLE', ['$q', '$timeout', function ($q, $timeout) { +ngCordovaMocks.factory('$cordovaBLE', ['$q', '$timeout', '$interval', '$log', function ($q, $timeout, $interval, $log) { var deviceScan = { name: 'Test Device', id: 'AA:BB:CC:DD:EE:FF', @@ -167,9 +205,31 @@ ngCordovaMocks.factory('$cordovaBLE', ['$q', '$timeout', function ($q, $timeout) scan: function (services, seconds) { var q = $q.defer(); + + // first notify about discovered device $timeout(function () { - q.resolve(deviceScan); + q.notify(deviceScan); + }, Math.round(seconds * 1000 * Math.random())); + + // end scan + $timeout(function () { + q.resolve(); }, seconds * 1000); + + return q.promise; + }, + + startScan: function (services, callback, errorCallback) { + $timeout(function () { + callback(deviceScan); + }, Math.round(1000 * Math.random())); + }, + + stopScan: function () { + var q = $q.defer(); + $timeout(function () { + q.resolve(); + }, 500); return q.promise; }, @@ -205,7 +265,7 @@ ngCordovaMocks.factory('$cordovaBLE', ['$q', '$timeout', function ($q, $timeout) return q.promise; }, - writeCommand: function (deviceID, serviceUUID, characteristicUUID, data) { + writeWithoutResponse: function (deviceID, serviceUUID, characteristicUUID, data) { var q = $q.defer(); $timeout(function () { q.resolve(true); @@ -213,18 +273,22 @@ ngCordovaMocks.factory('$cordovaBLE', ['$q', '$timeout', function ($q, $timeout) return q.promise; }, - notify: function (deviceID, serviceUUID, characteristicUUID) { - var q = $q.defer(); - $timeout(function () { - q.resolve(true); - }, 100); - return q.promise; + writeCommand: function (deviceID, serviceUUID, characteristicUUID, data) { + $log.warning('writeCommand is deprecated, use writeWithoutResponse'); + return this.writeWithoutResponse(deviceID, serviceUUID, characteristicUUID, data); }, - indicate: function (deviceID, serviceUUID, characteristicUUID) { + startNotification: function (deviceID, serviceUUID, characteristicUUID, callback, errorCallback) { + $interval(function () { + var data = new Uint8Array([Math.round(255 * Math.random())]); // one byte with random number + callback(data); + }, 200, 10); // repeat 10 times with 200 ms delay for each + }, + + stopNotification: function (deviceID, serviceUUID, characteristicUUID) { var q = $q.defer(); $timeout(function () { - q.resolve(true); + q.resolve(); }, 100); return q.promise; }, @@ -235,6 +299,14 @@ ngCordovaMocks.factory('$cordovaBLE', ['$q', '$timeout', function ($q, $timeout) return q.promise; }, + enable: function () { + var q = $q.defer(); + $timeout(function () { + q.resolve(); + }, 1500); + return q.promise; + }, + isEnabled: function () { var q = $q.defer(); q.resolve(true); @@ -1478,7 +1550,7 @@ ngCordovaMocks.factory('$cordovaFileTransfer', ['$q', function ($q) { **/ throwsError: throwsError, - download: function (source, filePath, trust, options) { + download: function (source, filePath, options, trust) { return mockIt.call(this, 'There was an error downloading the file.'); }, @@ -1487,6 +1559,7 @@ ngCordovaMocks.factory('$cordovaFileTransfer', ['$q', function ($q) { } }; }]); + /** * @ngdoc service * @name ngCordovaMocks.cordovaGeolocation @@ -2294,6 +2367,129 @@ ngCordovaMocks.factory('$cordovaKeychain', ['$q', function ($q) { }; }]); + +/** + * @ngdoc service + * @name ngCordovaMocks.localNotification + * + * @description + * A service for testing LocalNotificatio + * in an app build with ngCordovaMocks. + */ + +ngCordovaMocks.factory('$cordovaLocalNotification', ['$q', function ($q) { + + var storageKeyPfx = "ngCordLocNotif-"; + + function pfxId(id) { + return storageKeyPfx + id; + } + + function getAllIds(){ + var defer = $q.defer(); + var locNotifIds = []; + for ( var i = 0, len = localStorage.length; i < len; ++i ) { + if (localStorage.key( i ).indexOf(storageKeyPfx) > -1) + locNotifIds.push(parseInt(localStorage.key( i ).split("-")[1])); + } + defer.resolve(locNotifIds); + return defer.promise; + } + + + return { + cancel: function (ids) { + var defer = $q.defer(); + if (typeof(ids) == "number") ids = [ids]; + ids.forEach(function (id){ + localStorage.removeItem([pfxId(id)]); + }); + defer.resolve(); + return defer.promise; + }, + cancelAll: function () { + var defer = $q.defer(); + // TODO + defer.resolve(); + return defer.promise; + }, + clear: function (ids) { + if (typeof(ids) == "number") ids = [ids]; + var defer = $q.defer(); + ids.forEach(function (id){ + localStorage.removeItem([pfxId(id)]); + }); + defer.resolve(); + return defer.promise; + }, + clearAll: function () { + var defer = $q.defer(); + // TODO + // defer.resolve(); + return defer.promise; + }, + isScheduled: function (id){ + var defer = $q.defer(); + if (localStorage[pfxId(id)]) { + defer.resolve(true); + } else { + defer.resolve(false); + } + return defer.promise; + }, + isPresent: function (id){ + var defer = $q.defer(); + if (localStorage[pfxId(id)]) { + defer.resolve(true); + } else { + defer.resolve(false); + } + return defer.promise; + }, + isTriggered: function (id){ + var defer = $q.defer(); + if (localStorage[pfxId(id)]) { + defer.resolve(false); + } else { + defer.resolve(true); + } + return defer.promise; + }, + getAllIds: function () { + return getAllIds(); + }, + getIds: function () { + return getAllIds(); + }, + getScheduledIds: function () { + return getAllIds(); + }, + getTriggeredIds: function () { + var defer = $q.defer(); + defer.resolve([]); + return defer.promise; + }, + hasPermission: function (id){ + var defer = $q.defer(); + defer.resolve(true); + return defer.promise; + }, + schedule: function (data){ + var defer = $q.defer(); + var id = pfxId(data.id); + localStorage[id] = JSON.stringify(data); + defer.resolve(); + return defer.promise; + }, + update: function (data){ + var defer = $q.defer(); + var id = pfxId(data.id); + localStorage[id] = JSON.stringify(data); + defer.resolve(); + return defer.promise; + } + }; +}]); /** * @ngdoc service * @name ngCordovaMocks.cordovaNetwork @@ -2302,7 +2498,7 @@ ngCordovaMocks.factory('$cordovaKeychain', ['$q', function ($q) { * A service for testing networked fetures * in an app build with ngCordova. */ -ngCordovaMocks.factory('$cordovaNetwork', function () { +ngCordovaMocks.factory('$cordovaNetwork', ['$rootScope',function ($rootScope) { var connectionType = 'WiFi connection'; var isConnected = true; @@ -2330,6 +2526,16 @@ ngCordovaMocks.factory('$cordovaNetwork', function () { **/ isConnected: isConnected, + switchToOnline: function (){ + this.isConnected = true; + $rootScope.$broadcast('$cordovaNetwork:online'); + }, + + switchToOffline: function (){ + this.isConnected = false; + $rootScope.$broadcast('$cordovaNetwork:offline'); + }, + getNetwork: function () { return this.connectionType; }, @@ -2342,7 +2548,160 @@ ngCordovaMocks.factory('$cordovaNetwork', function () { return !this.isConnected; } }; -}); +}]); + +/** + * @ngdoc service + * @name ngCordovaMocks.cordovaProgress + * + * @description + * A service for testing Progress Indicator + * in an app build with ngCordova. + */ + +ngCordovaMocks.factory('$cordovaProgress', [ + '$timeout', function ($timeout) { + + return { + show: function (_message) { + var message = _message || 'Please wait...'; + console.info('$cordovaProgress.message', message); + }, + + showSimple: function (_dim) { + var dim = _dim || false; + console.info('$cordovaProgress.dim', dim); + }, + + showSimpleWithLabel: function (_dim, _label) { + var dim = _dim || false; + var label = _label || 'Loading...'; + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.label', label); + console.groupEnd(); + }, + + showSimpleWithLabelDetail: function (_dim, _label, _detail) { + var dim = _dim || false; + var label = _label || 'Loading...'; + var detail = _detail || 'Please wait'; + + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.label', label); + console.info('$cordovaProgress.detail', detail); + console.groupEnd(); + }, + + showDeterminate: function (_dim, _timeout) { + var dim = _dim || false; + var timeout = _timeout || 50000; + console.group(); + console.info('$cordovaProgress.dim show', dim); + console.info('$cordovaProgress.timeout', timeout); + console.groupEnd(); + $timeout(function () { + console.info('$cordovaProgress.dim timeout', dim); + }, timeout); + }, + + showDeterminateWithLabel: function (_dim, _timeout, _label) { + var dim = _dim || false; + var timeout = _timeout || 50000; + var label = _label || 'Loading...'; + + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.timeout', timeout); + console.info('$cordovaProgress.label', label); + console.groupEnd(); + $timeout(function () { + console.info('$cordovaProgress[dim, label] timeout', [dim, label]); + }, timeout); + }, + + showAnnular: function (_dim, _timeout) { + var dim = _dim || false; + var timeout = _timeout || 50000; + + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.timeout', timeout); + console.groupEnd(); + $timeout(function () { + console.info('$cordovaProgress.dim timeout', dim); + }, timeout); + }, + + showAnnularWithLabel: function (_dim, _timeout, _label) { + var dim = _dim || false; + var timeout = _timeout || 50000; + var label = _label || 'Loading...'; + + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.timeout', timeout); + console.info('$cordovaProgress.label', label); + console.groupEnd(); + $timeout(function () { + console.info('$cordovaProgress[dim, label] timeout', [dim, label]); + }, timeout); + }, + + showBar: function (_dim, _timeout) { + var dim = _dim || false; + var timeout = _timeout || 50000; + + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.timeout', timeout); + console.groupEnd(); + $timeout(function () { + console.info('$cordovaProgress.dim timeout', dim); + }, timeout); + }, + + showBarWithLabel: function (_dim, _timeout, _label) { + var dim = _dim || false; + var timeout = _timeout || 50000; + var label = _label || 'Loading...'; + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.label', label); + console.info('$cordovaProgress.timeout', timeout); + console.groupEnd(); + $timeout(function () { + console.info('$cordovaProgress[dim, label] timeout', [dim, label]); + }, timeout); + }, + + showSuccess: function (_dim, _label) { + var dim = _dim || false; + var label = _label || 'Success'; + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.label', label); + console.groupEnd(); + }, + + showText: function (_dim, _text, _position) { + var dim = _dim || false; + var text = _text || 'Warning'; + var position = _position || 'center'; + console.group(); + console.info('$cordovaProgress.dim', dim); + console.info('$cordovaProgress.text', text); + console.info('$cordovaProgress.position', position); + console.groupEnd(); + }, + + hide: function () { + console.info('$cordovaProgress.hide'); + } + }; + } +]); 'use strict'; @@ -2423,6 +2782,57 @@ ngCordovaMocks.factory('$cordovaPush', ['$q', '$timeout', '$rootScope', function /** * @ngdoc service + * @name ngCordovaMocks.cordovaScreenshot + * + * @description + * A service for test app screenshot + * in an app build with ngCordova. + * + * @example + */ +ngCordovaMocks.factory('$cordovaScreenshot', ['$q', function ($q) { + var throwsError = false; + + var DATA_URI_MOCK = ""; + + return { + /** + * @ngdoc property + * @name throwsError + * @propertyOf ngCordovaMocks.cordovaScreenshot + * + * @description + * A flag that signals whether a promise should be rejected or not. + * This property should only be used in automated tests. + **/ + throwsError: throwsError, + + captureToFile: function () { + var defer = $q.defer(); + if (this.throwsError) { + defer.reject('There was an error capturing the screenshot.'); + } else { + defer.resolve("path"); + } + + return defer.promise; + }, + + captureToUri: function () { + var defer = $q.defer(); + if (this.throwsError) { + defer.reject('There was an error capturing the screenshot.'); + } else { + defer.resolve(); + } + + return defer.promise; + } + }; +}]); + +/** + * @ngdoc service * @name ngCordovaMocks.cordovaSocialSharing * * @description @@ -2725,6 +3135,65 @@ ngCordovaMocks.factory('$cordovaSplashscreen', function () { /** * @ngdoc service + * @name ngCordovaMocks.cordovaSQLite + * + * @description + * A service for testing SQLite + * in an app build with ngCordova. + */ + +ngCordovaMocks.factory('$cordovaSQLite', ['$q', function ($q) { + + return { + /** + * These properties are here for the purpose of automated testing only. + **/ + openDBShouldSucceedWith: null, + executeShouldSucceedWith: null, + insertCollectionShouldSucceedWith: null, + nestedExecuteShouldSucceedWith: null, + deleteDBShouldSucceedWith : null, + + openDB: function (options, background) { + if (this.openDBShouldSucceedWith !== null) { + $q.when(this.openDBShouldSucceedWith) + } else { + $q.reject() + } + }, + execute: function (db, query, binding) { + if (this.executeShouldSucceedWith !== null) { + $q.when(this.executeShouldSucceedWith) + } else { + $q.reject() + } + }, + insertCollection: function (db, query, bindings) { + if (this.insertCollectionShouldSucceedWith !== null) { + $q.when(this.insertCollectionShouldSucceedWith) + } else { + $q.reject() + } + }, + nestedExecute: function (db, query1, query2, binding1, binding2) { + if (this.nestedExecuteShouldSucceedWith !== null) { + $q.when(this.nestedExecuteShouldSucceedWith) + } else { + $q.reject() + } + }, + deleteDB: function (dbName) { + if (this.deleteDBShouldSucceedWith !== null) { + $q.when(this.deleteDBShouldSucceedWith) + } else { + $q.reject() + } + } + } +}]); + +/** + * @ngdoc service * @name ngCordovaMocks.cordovaStatusbar * * @description @@ -2878,6 +3347,15 @@ ngCordovaMocks.factory('$cordovaToast', ['$q', function ($q) { defer.resolve(); } return defer.promise; + }, + hide: function () { + var defer = $q.defer(); + if (this.throwsError) { + defer.reject('There was an error hiding the toast.'); + } else { + defer.resolve(); + } + return defer.promise; } }; }]); |
