summaryrefslogtreecommitdiffstats
path: root/js/tests
diff options
context:
space:
mode:
authorBernhard Posselt <dev@bernhard-posselt.com>2014-09-14 04:17:32 +0200
committerBernhard Posselt <dev@bernhard-posselt.com>2014-09-14 04:17:32 +0200
commit242fdbf9fcc39795fe5567eadcb55c6709b303c5 (patch)
tree6c85a9836080997bf223341e11eecdac3c51ac1e /js/tests
parent721ae0b8bbde9716ed9073439805fd6497abf508 (diff)
add import articles
Diffstat (limited to 'js/tests')
-rw-r--r--js/tests/unit/controller/SettingsControllerSpec.js101
-rw-r--r--js/tests/unit/service/ItemResourceSpec.js15
-rw-r--r--js/tests/unit/service/OPMLImporterSpec.js31
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 () {
+
+ });
+
+
+});