diff options
author | Bernhard Posselt <dev@bernhard-posselt.com> | 2014-09-14 04:17:32 +0200 |
---|---|---|
committer | Bernhard Posselt <dev@bernhard-posselt.com> | 2014-09-14 04:17:32 +0200 |
commit | 242fdbf9fcc39795fe5567eadcb55c6709b303c5 (patch) | |
tree | 6c85a9836080997bf223341e11eecdac3c51ac1e /js/tests | |
parent | 721ae0b8bbde9716ed9073439805fd6497abf508 (diff) |
add import articles
Diffstat (limited to 'js/tests')
-rw-r--r-- | js/tests/unit/controller/SettingsControllerSpec.js | 101 | ||||
-rw-r--r-- | js/tests/unit/service/ItemResourceSpec.js | 15 | ||||
-rw-r--r-- | js/tests/unit/service/OPMLImporterSpec.js | 31 |
3 files changed, 142 insertions, 5 deletions
diff --git a/js/tests/unit/controller/SettingsControllerSpec.js b/js/tests/unit/controller/SettingsControllerSpec.js index ac6d2c9b6..83c706738 100644 --- a/js/tests/unit/controller/SettingsControllerSpec.js +++ b/js/tests/unit/controller/SettingsControllerSpec.js @@ -14,6 +14,7 @@ describe('SettingsController', function () { beforeEach(module('News', function ($provide) { $provide.value('BASE_URL', 'base'); + $provide.value('ITEM_BATCH_SIZE', 3); })); beforeEach(function () { @@ -59,14 +60,104 @@ describe('SettingsController', function () { })); - it('should return feed size', inject(function ($controller, FeedResource) { - FeedResource.add({url: 'hi'}); + it('should import articles', inject(function ($controller, ItemResource, + Publisher) { + var data = 1; + ItemResource.importArticles = jasmine.createSpy('importArticles') + .andCallFake(function () { + return { + success: function (callback) { + callback(data); + return { + finally: function (finalCallback) { + finalCallback(); + } + }; + } + }; + }); + Publisher.publishAll = jasmine.createSpy('publishAll'); var ctrl = $controller('SettingsController', { - FeedResource: FeedResource, - $route: route + ItemResource: ItemResource, + Publisher: Publisher }); - expect(ctrl.feedSize()).toBe(1); + var content = '{"test":1}'; + + ctrl.importArticles(content); + + expect(ItemResource.importArticles) + .toHaveBeenCalledWith(JSON.parse(content)); + expect(Publisher.publishAll).toHaveBeenCalledWith(data); + expect(ctrl.isArticlesImporting).toBe(false); + expect(ctrl.articleImportError).toBe(false); + })); + + + it('should display import articles error', inject(function ($controller) { + var ctrl = $controller('SettingsController'); + + var content = '{"test:1}'; + + ctrl.importArticles(content); + + expect(ctrl.isArticlesImporting).toBe(false); + expect(ctrl.articleImportError).toBe(true); + })); + + + + it('should import opml', inject(function ($controller, OPMLImporter, + OPMLParser) { + var queue = 4; + + OPMLParser.parse = jasmine.createSpy('parse').andReturn(2); + + OPMLImporter.importFolders = jasmine.createSpy('importFolders') + .andReturn({ + then: function (callback) { + callback(queue, 5); + return { + finally: function (finalCallback) { + finalCallback(); + } + }; + } + }); + + OPMLImporter.importFeedQueue = jasmine.createSpy('importFeedQueue'); + + var ctrl = $controller('SettingsController', { + OPMLImporter: OPMLImporter, + OPMLParser: OPMLParser + }); + + var content = '{"test":1}'; + + ctrl.importOPML(content); + + expect(OPMLParser.parse).toHaveBeenCalledWith(content); + expect(OPMLImporter.importFolders).toHaveBeenCalledWith(2); + expect(OPMLImporter.importFeedQueue).toHaveBeenCalledWith(4, 5); + expect(ctrl.isOPMLImporting).toBe(false); + expect(ctrl.opmlImportError).toBe(false); + })); + + + it('should display import opml error', inject(function ( + $controller, OPMLParser) { + OPMLParser.parse = jasmine.createSpy('parse').andCallFake(function () { + throw 1; + }); + + var ctrl = $controller('SettingsController', { + OPMLParser: OPMLParser + }); + + ctrl.importOPML('content'); + + expect(ctrl.isOPMLImporting).toBe(false); + expect(ctrl.opmlImportError).toBe(true); })); });
\ No newline at end of file diff --git a/js/tests/unit/service/ItemResourceSpec.js b/js/tests/unit/service/ItemResourceSpec.js index 7b7df64fb..a3228f7a4 100644 --- a/js/tests/unit/service/ItemResourceSpec.js +++ b/js/tests/unit/service/ItemResourceSpec.js @@ -298,4 +298,19 @@ describe('ItemResource', function () { })); + + it ('should import articles', inject(function (ItemResource) { + var json = 'test'; + + http.expectPOST('base/feeds/import/articles', { + json: json + }).respond(200, {}); + + ItemResource.importArticles(json); + + http.flush(); + + })); + + });
\ No newline at end of file diff --git a/js/tests/unit/service/OPMLImporterSpec.js b/js/tests/unit/service/OPMLImporterSpec.js new file mode 100644 index 000000000..b8359f82f --- /dev/null +++ b/js/tests/unit/service/OPMLImporterSpec.js @@ -0,0 +1,31 @@ +/** + * ownCloud - News + * + * This file is licensed under the Affero General Public License version 3 or + * later. See the COPYING file. + * + * @author Bernhard Posselt <dev@bernhard-posselt.com> + * @copyright Bernhard Posselt 2014 + */ +describe('OPMLParser', function () { + 'use strict'; + + var importer; + + beforeEach(module('News', function ($provide) { + $provide.value('BASE_URL', 'base'); + $provide.value('ITEM_BATCH_SIZE', 3); + })); + + beforeEach(inject(function (OPMLImporter) { + importer = OPMLImporter; + })); + + + // FIXME: tests missing + it ('should parse the correct amount of feeds and folders', function () { + + }); + + +}); |