summaryrefslogtreecommitdiffstats
path: root/js/tests/services/businesslayer
diff options
context:
space:
mode:
authorBernhard Posselt <dev@bernhard-posselt.com>2014-05-15 03:00:53 +0200
committerBernhard Posselt <dev@bernhard-posselt.com>2014-05-15 03:00:53 +0200
commit3ce894af1e72c9488b8cb3340fd61656122f7d50 (patch)
treea603121e8b1e860201370399f8095121cd9c6bf7 /js/tests/services/businesslayer
parent10d76fff64363ea59d916b550854cf3540dadfbc (diff)
use markdown, refactor js
Diffstat (limited to 'js/tests/services/businesslayer')
-rw-r--r--js/tests/services/businesslayer/businesslayerSpec.coffee74
-rw-r--r--js/tests/services/businesslayer/feedbusinesslayerSpec.coffee357
-rw-r--r--js/tests/services/businesslayer/folderbusinesslayerSpec.coffee493
-rw-r--r--js/tests/services/businesslayer/itembusinesslayerSpec.coffee266
-rw-r--r--js/tests/services/businesslayer/starredbusinesslayerSpec.coffee64
-rw-r--r--js/tests/services/businesslayer/subsriptionsbusinesslayerSpec.coffee97
6 files changed, 0 insertions, 1351 deletions
diff --git a/js/tests/services/businesslayer/businesslayerSpec.coffee b/js/tests/services/businesslayer/businesslayerSpec.coffee
deleted file mode 100644
index 48be7f0c0..000000000
--- a/js/tests/services/businesslayer/businesslayerSpec.coffee
+++ /dev/null
@@ -1,74 +0,0 @@
-###
-
-ownCloud - News
-
-@author Bernhard Posselt
-@copyright 2012 Bernhard Posselt dev@bernhard-posselt.com
-
-This library is free software; you can redistribute it and/or
-modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
-License as published by the Free Software Foundation; either
-version 3 of the License, or any later version.
-
-This library is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU AFFERO GENERAL PUBLIC LICENSE for more details.
-
-You should have received a copy of the GNU Affero General Public
-License along with this library. If not, see <http://www.gnu.org/licenses/>.
-
-###
-
-
-describe 'BusinessLayer', ->
-
- beforeEach module 'News'
-
- beforeEach inject (@_BusinessLayer, @ActiveFeed, @FeedType, @ItemModel,
- $rootScope) =>
- @scope = $rootScope.$new()
-
- type = @FeedType.Starred
-
- @getItemsSpy = jasmine.createSpy('getItems')
- @persistence = {
- getItems: @getItemsSpy
- }
-
- class TestBusinessLayer extends @_BusinessLayer
-
- constructor: (activeFeed, persistence, itemModel, scope) ->
- super(activeFeed, persistence, itemModel, type, scope)
-
- @BusinessLayer = new TestBusinessLayer(@ActiveFeed, @persistence,
- @ItemModel, @scope)
-
-
- it 'should reset the item cache when a different feed is being loaded', =>
- @ItemModel.clear = jasmine.createSpy('clear')
- @ActiveFeed.handle({id: 0, type: @FeedType.Starred})
-
- @BusinessLayer.load(2)
- expect(@ItemModel.clear).toHaveBeenCalled()
-
- @ActiveFeed.handle({id: 2, type: @FeedType.Feed})
- @BusinessLayer.load(2)
- expect(@ItemModel.clear).toHaveBeenCalled()
-
-
-
- it 'should send a get all items query when feed changed', =>
- @persistence.getItems = jasmine.createSpy('latest')
- @ActiveFeed.handle({id: 3, type: @FeedType.Feed})
- @BusinessLayer.load(3)
-
- expect(@persistence.getItems).toHaveBeenCalledWith(@FeedType.Starred, 3,
- 0, jasmine.any(Function))
-
-
- it 'should be active when its selected', =>
- expect(@BusinessLayer.isActive(0)).toBe(false)
-
- @ActiveFeed.handle({type: @FeedType.Starred, id:0})
- expect(@BusinessLayer.isActive(0)).toBe(true) \ No newline at end of file
diff --git a/js/tests/services/businesslayer/feedbusinesslayerSpec.coffee b/js/tests/services/businesslayer/feedbusinesslayerSpec.coffee
deleted file mode 100644
index c15b2ed12..000000000
--- a/js/tests/services/businesslayer/feedbusinesslayerSpec.coffee
+++ /dev/null
@@ -1,357 +0,0 @@
-###
-
-ownCloud - News
-
-@author Bernhard Posselt
-@copyright 2012 Bernhard Posselt dev@bernhard-posselt.com
-
-This library is free software; you can redistribute it and/or
-modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
-License as published by the Free Software Foundation; either
-version 3 of the License, or any later version.
-
-This library is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU AFFERO GENERAL PUBLIC LICENSE for more details.
-
-You should have received a copy of the GNU Affero General Public
-License along with this library. If not, see <http://www.gnu.org/licenses/>.
-
-###
-
-
-describe 'FeedBusinessLayer', ->
-
- beforeEach module 'News'
-
- beforeEach module ($provide) =>
- @setFeedReadSpy = jasmine.createSpy('setFeedRead')
- @getItemsSpy = jasmine.createSpy('Get Items')
- @persistence =
- setFeedRead: @setFeedReadSpy
- getItems: @getItemsSpy
- createFeed: ->
- test: 'feedbusinesslayer'
-
- @imagePath = jasmine.createSpy('imagePath')
- @utils =
- imagePath: @imagePath
-
- $provide.value 'Persistence', @persistence
- $provide.value 'Utils', @utils
- return
-
-
- beforeEach inject (@FeedBusinessLayer, @FeedModel, @ItemModel, @FeedType,
- @ShowAll, @ActiveFeed, @_ExistsError, @$timeout,
- @NewestItem, @$rootScope) =>
- @ShowAll.setShowAll(false)
- @ActiveFeed.handle({type: @FeedType.Folder, id:0})
-
-
- it 'should delete feeds', =>
- data = null
- @$rootScope.$on 'undoMessage', (scope, data) ->
- data = data
-
- @FeedModel.removeById = jasmine.createSpy('remove').andCallFake ->
- return {id: 3, title: 'test'}
- @persistence.deleteFeed = jasmine.createSpy('deletequery')
- @FeedBusinessLayer.delete(3)
-
- expect(@FeedModel.removeById).toHaveBeenCalledWith(3)
- expect(@persistence.deleteFeed).toHaveBeenCalledWith(3)
-
- #expect(data.caption).toBe('test')
- # TODO: test for correct undocallbacks
-
-
- it 'should return the number of unread feeds', =>
- @FeedModel.add({id: 3, unreadCount:134, url: 'a1'})
- count = @FeedBusinessLayer.getUnreadCount(3)
-
- expect(count).toBe(134)
-
-
- it 'should return all feeds of a folder', =>
- feed1 = {id: 3, unreadCount:134, url: 'a1', folderId: 3}
- feed2 = {id: 4, unreadCount:134, url: 'a2', folderId: 2}
- feed3 = {id: 5, unreadCount:134, url: 'a3', folderId: 3}
- @FeedModel.add(feed1)
- @FeedModel.add(feed2)
- @FeedModel.add(feed3)
-
- feeds = @FeedBusinessLayer.getFeedsOfFolder(3)
-
- expect(feeds).toContain(feed1)
- expect(feeds).toContain(feed3)
-
-
- it 'should get the correct unread count for folders', =>
- @FeedModel.add({id: 3, unreadCount:134, folderId: 3, url: 'a1'})
- @FeedModel.add({id: 5, unreadCount:2, folderId: 2, url: 'a2'})
- @FeedModel.add({id: 1, unreadCount:12, folderId: 5, url: 'a3'})
- @FeedModel.add({id: 2, unreadCount:35, folderId: 3, url: 'a4'})
- count = @FeedBusinessLayer.getFolderUnreadCount(3)
-
- expect(count).toBe(169)
-
-
- it 'should not mark feed read when no highest item id', =>
- @FeedModel.add({id: 5, unreadCount:2, folderId: 2, url: 'a1'})
- @persistence.setFeedRead = jasmine.createSpy('setFeedRead')
- @FeedBusinessLayer.markRead(5)
- expect(@persistence.setFeedRead).not.toHaveBeenCalled()
-
-
- it 'should mark feed as read', =>
- @NewestItem.handle(25)
- @ActiveFeed.handle({type: @FeedType.Feed, id: 5})
- @persistence.setFeedRead = jasmine.createSpy('setFeedRead')
-
- @FeedModel.add({id: 5, unreadCount:2, folderId: 2, url: 'a1'})
-
- item1 = {id: 3, feedId: 5, guidHash: 'a3', status: 0}
- @ItemModel.add(item1)
- item1.setUnread()
- item2 = {id: 2, feedId: 3, guidHash: 'a3', status: 0}
- @ItemModel.add(item2)
- item2.setUnread()
-
- @FeedBusinessLayer.markRead(5)
-
- expect(@persistence.setFeedRead).toHaveBeenCalledWith(5, 25)
- expect(@FeedModel.getById(5).unreadCount).toBe(0)
- expect(item1.isRead()).toBe(true)
- expect(item2.isRead()).toBe(false)
-
-
- it 'should get the correct unread count for subscribtions', =>
- @FeedModel.add({id: 3, unreadCount:134, url: 'a1'})
- @FeedModel.add({id: 5, unreadCount:2, url: 'a2'})
- count = @FeedBusinessLayer.getAllUnreadCount()
-
- expect(count).toBe(136)
-
-
- it 'should return the correct number of feeds', =>
- @FeedModel.add({id: 3, unreadCount:134, url: 'a1'})
- @FeedModel.add({id: 5, unreadCount:2, url: 'a2'})
- count = @FeedBusinessLayer.getNumberOfFeeds()
-
- expect(count).toBe(2)
-
-
- it 'should be visible if its active', =>
- @ActiveFeed.handle({type: @FeedType.Feed, id:3})
- expect(@FeedBusinessLayer.isVisible(3)).toBe(true)
-
-
- it 'should be visible if show all is true', =>
- expect(@FeedBusinessLayer.isVisible(3)).toBe(false)
-
- @ShowAll.setShowAll(true)
- expect(@FeedBusinessLayer.isVisible(3)).toBe(true)
-
-
- it 'should be visible if unreadcount bigger than 0', =>
- @FeedModel.add({id: 2, unreadCount:134, url: 'a1'})
- expect(@FeedBusinessLayer.isVisible(2)).toBe(true)
-
-
- it 'should not move the feed to a new folder', =>
- @persistence.moveFeed = jasmine.createSpy('Move feed')
- @FeedModel.add({id: 2, unreadCount:134, url: 'a1', folderId: 3})
- @FeedBusinessLayer.move(2, 4)
-
- expect(@persistence.moveFeed).toHaveBeenCalledWith(2, 4)
- expect(@FeedModel.getById(2).folderId).toBe(4)
-
-
- it 'should not move the feed to the same folder', =>
- @persistence.moveFeed = jasmine.createSpy('Move feed')
- @FeedModel.add({id: 2, unreadCount:134, url: 'a1', folderId: 3})
- @FeedBusinessLayer.move(2, 3)
-
- expect(@persistence.moveFeed).not.toHaveBeenCalled()
-
-
- it 'should set the show all setting', =>
- @persistence.userSettingsReadShow = jasmine.createSpy('Show All')
- @FeedBusinessLayer.setShowAll(true)
-
- expect(@persistence.userSettingsReadShow).toHaveBeenCalled()
-
-
-
- it 'should set the hide read setting', =>
- @persistence.userSettingsReadHide = jasmine.createSpy('Hide Read')
- @FeedBusinessLayer.setShowAll(false)
-
- expect(@persistence.userSettingsReadHide).toHaveBeenCalled()
-
-
- it 'should return all feeds', =>
- item1 = {id: 2, unreadCount:134, url: 'a1', folderId: 3}
- item2 = {id: 4, unreadCount:134, url: 'a2', folderId: 3}
- @FeedModel.add(item1)
- @FeedModel.add(item2)
-
- expect(@FeedBusinessLayer.getAll()).toContain(item1)
- expect(@FeedBusinessLayer.getAll()).toContain(item2)
-
-
- it 'should return if ShowAll is set', =>
- @persistence.userSettingsReadShow = jasmine.createSpy('Show All')
- expect(@FeedBusinessLayer.isShowAll()).toBe(false)
- @FeedBusinessLayer.setShowAll(true)
-
- expect(@FeedBusinessLayer.isShowAll()).toBe(true)
-
-
- it 'should return all feeds of a folder', =>
- item1 = {id: 2, unreadCount:134, url: 'a1', folderId: 3}
- item2 = {id: 4, unreadCount:134, url: 'a2', folderId: 2}
- item3 = {id: 5, unreadCount:134, url: 'a3', folderId: 3}
- @FeedModel.add(item1)
- @FeedModel.add(item2)
- @FeedModel.add(item3)
-
- folders = @FeedBusinessLayer.getFeedsOfFolder(3)
-
- expect(folders).toContain(item1)
- expect(folders).toContain(item3)
-
-
- it 'should return the correct feed link', =>
- item2 =
- id: 4,
- unreadCount:134,
- url: 'a2',
- folderId: 3,
- link: 'test.com'
- @FeedModel.add(item2)
-
- expect(@FeedBusinessLayer.getFeedLink(4)).toBe('test.com')
-
-
-
- it 'should not create a feed if it already exists', =>
- item1 = {url: 'http://john'}
- @FeedModel.add(item1)
-
- expect =>
- @FeedBusinessLayer.create('john')
- .toThrow(new @_ExistsError('Exists already'))
-
- expect =>
- @FeedBusinessLayer.create('johns')
- .not.toThrow(new @_ExistsError('Exists already'))
-
-
- it 'should not create feeds that are empty', =>
- expect =>
- @FeedBusinessLayer.create(' ')
- .toThrow(new Error('Url must not be empty'))
-
-
- it 'should create a feed before theres a response from the server', =>
- @FeedBusinessLayer.create('johns')
- expect(@FeedModel.size()).toBe(1)
-
-
- it 'should set a title and an url to the newly created feed', =>
- url = 'www.google.de'
- @FeedBusinessLayer.create(url)
-
- feed = @FeedModel.getByUrl('http://' + url)
-
- expect(feed.title).toBe('http://www.google.de')
- expect(feed.url).toBe('http://' + url)
- expect(feed.folderId).toBe(0)
- expect(feed.unreadCount).toBe(0)
- expect(@imagePath).toHaveBeenCalledWith('core', 'loading.gif')
-
-
- it 'should not add http when it already is at the start of created feed', =>
- url = 'https://www.google.de'
- @FeedBusinessLayer.create(url)
- feed = @FeedModel.getByUrl(url)
-
- expect(feed.url).toBe(url)
-
-
- it 'should make a create feed request', =>
- @persistence.createFeed = jasmine.createSpy('add feed')
-
- @FeedBusinessLayer.create(' johns ')
- expect(@persistence.createFeed).toHaveBeenCalledWith('http://johns', 0,
- jasmine.any(Function), jasmine.any(Function))
-
-
- it 'should call the onSuccess function on response status ok', =>
- onSuccess = jasmine.createSpy('Success')
- @persistence.createFeed = jasmine.createSpy('add feed')
- @persistence.createFeed.andCallFake (folderName, parentId, success) =>
- @response =
- data: 'hi'
- success(@response)
-
- @FeedBusinessLayer.create(' johns ', 0, onSuccess)
-
- expect(onSuccess).toHaveBeenCalledWith(@response)
-
-
- it 'should call the handle a response error when creating a folder', =>
- onSuccess = jasmine.createSpy('Success')
- onFailure = jasmine.createSpy('Failure')
- @persistence.createFeed = jasmine.createSpy('add feed')
- @persistence.createFeed.andCallFake (folderName, parentId, success,
- failure) =>
- @response =
- message: 'this is an error'
- failure(@response)
-
- @FeedBusinessLayer.create(' johns ', 0, onSuccess, onFailure)
-
- expect(onSuccess).not.toHaveBeenCalled()
- expect(onFailure).toHaveBeenCalled()
-
- expect(@FeedModel.getByUrl('http://johns').error).toBe(
- @response.message)
-
-
- it 'should mark a feed error as read by removing it', =>
- @FeedModel.add({id: 3, url: 'john'})
-
- @FeedBusinessLayer.markErrorRead('john')
-
- expect(@FeedModel.size()).toBe(0)
- expect(@FeedModel.getByUrl('john')).toBe(undefined)
-
-
- it 'should create an import article request', =>
- callback = jasmine.createSpy('called')
- @persistence.importArticles = jasmine.createSpy('importArticles')
- @persistence.importArticles.andCallFake (data, onSuccess) ->
- onSuccess()
-
- json = {"test": "hi"}
- @FeedBusinessLayer.importArticles(json, callback)
-
- expect(@persistence.importArticles).toHaveBeenCalledWith(json,
- jasmine.any(Function))
- expect(callback).toHaveBeenCalled()
-
-
- it 'should make a rename feed request and disable editing', =>
- @persistence.renameFeed = jasmine.createSpy('Rename feed')
- @FeedModel.add({id: 2, unreadCount:134, url: 'a1', folderId: 3})
- @FeedBusinessLayer.renameFeed(2, "New Title")
-
- expect(@persistence.renameFeed).toHaveBeenCalledWith(2, "New Title")
- expect(@FeedModel.getById(2).editing).toBe(false)
-
-
-
diff --git a/js/tests/services/businesslayer/folderbusinesslayerSpec.coffee b/js/tests/services/businesslayer/folderbusinesslayerSpec.coffee
deleted file mode 100644
index 2c5c9bf2a..000000000
--- a/js/tests/services/businesslayer/folderbusinesslayerSpec.coffee
+++ /dev/null
@@ -1,493 +0,0 @@
-###
-
-ownCloud - News
-
-@author Bernhard Posselt
-@copyright 2012 Bernhard Posselt dev@bernhard-posselt.com
-
-This library is free software; you can redistribute it and/or
-modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
-License as published by the Free Software Foundation; either
-version 3 of the License, or any later version.
-
-This library is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU AFFERO GENERAL PUBLIC LICENSE for more details.
-
-You should have received a copy of the GNU Affero General Public
-License along with this library. If not, see <http://www.gnu.org/licenses/>.
-
-###
-
-
-describe 'FolderBusinessLayer', ->
-
- beforeEach module 'News'
-
- beforeEach module ($provide) =>
- @persistence =
- test: 'folderbusinesslayer'
-
- @imagePath = jasmine.createSpy('imagePath')
- @utils =
- imagePath: @imagePath
-
- $provide.value 'Persistence', @persistence
- $provide.value 'Utils', @utils
- return
-
-
- beforeEach inject (@FolderBusinessLayer, @FolderModel, @FeedModel, @ShowAll,
- @ActiveFeed, @FeedType, @_ExistsError, @$timeout,
- @NewestItem, @ItemModel, @$rootScope) =>
- @ShowAll.setShowAll(false)
- @ActiveFeed.handle({type: @FeedType.Feed, id:0})
-
-
- it 'should delete folders', =>
- data = null
- @$rootScope.$on 'undoMessage', (scope, data) ->
- data = data
-
- @FeedModel.add({id: 5, unreadCount:2, folderId: 3, url: 'a1'})
- @FolderModel.removeById = jasmine.createSpy('remove').andCallFake ->
- return {id: 3, name: 'test'}
- @FeedModel.removeById = jasmine.createSpy('remove').andCallFake ->
- return {id: 5, name: 'test', folderId: 3}
-
- @persistence.deleteFolder = jasmine.createSpy('deletequery')
- @FolderBusinessLayer.delete(3)
-
- expect(@FolderModel.removeById).toHaveBeenCalledWith(3)
- expect(@FeedModel.removeById).toHaveBeenCalledWith(5)
- expect(@persistence.deleteFolder).toHaveBeenCalledWith(3)
-
- #expect(data.caption).toBe('test')
- # TODO: test for correct undocallbacks
-
-
-
- it 'should return true when folder has feeds', =>
- @FeedModel.add({id: 5, unreadCount:2, folderId: 2, url: 'a1'})
- expect(@FolderBusinessLayer.hasFeeds(3)).toBeFalsy()
-
- @FeedModel.add({id: 2, unreadCount:35, folderId: 3, url: 'a2'})
- expect(@FolderBusinessLayer.hasFeeds(3)).toBeTruthy()
-
-
- it 'should toggle folder', =>
- @persistence.openFolder = jasmine.createSpy('open')
- @persistence.collapseFolder = jasmine.createSpy('collapse')
-
- @FolderModel.add({id: 3, opened: false, name: 'ho'})
- @FolderBusinessLayer.toggleFolder(4)
- expect(@FolderModel.getById(3).opened).toBeFalsy()
-
- @FolderBusinessLayer.toggleFolder(3)
- expect(@FolderModel.getById(3).opened).toBeTruthy()
- expect(@persistence.openFolder).toHaveBeenCalledWith(3)
-
- @FolderBusinessLayer.toggleFolder(3)
- expect(@FolderModel.getById(3).opened).toBeFalsy()
- expect(@persistence.collapseFolder).toHaveBeenCalledWith(3)
-
-
- it 'should mark folder as read', =>
- @NewestItem.handle(25)
-
- @persistence.setFolderRead = jasmine.createSpy('setFeedRead')
-
- item1 = {id: 3, feedId: 5, guidHash: 'a3', status: 0}
- @ItemModel.add(item1)
- item1.setUnread()
- item2 = {id: 2, feedId: 3, guidHash: 'a3', status: 0}
- @ItemModel.add(item2)
- item2.setUnread()
-
- @FolderModel.add({id: 3, opened: false, name: 'ho'})
- @FeedModel.add({id: 3, unreadCount:134, folderId: 3, url: 'a1'})
- @FeedModel.add({id: 5, unreadCount:2, folderId: 2, url: 'a2'})
- @FeedModel.add({id: 1, unreadCount:12, folderId: 3, url: 'a3'})
-
- @FolderBusinessLayer.markRead(3)
-
- expect(@FeedModel.getById(3).unreadCount).toBe(0)
- expect(@FeedModel.getById(1).unreadCount).toBe(0)
- expect(@FeedModel.getById(5).unreadCount).toBe(2)
-
- expect(item1.isRead()).toBe(false)
- expect(item2.isRead()).toBe(true)
-
- expect(@persistence.setFolderRead).toHaveBeenCalledWith(3, 25)
-
-
- it 'should not mark folder read when no highest item id', =>
- @FolderModel.add({id: 5, opened: false, name: 'ho'})
- @persistence.setFolderRead = jasmine.createSpy('setFolderRead')
- @FolderBusinessLayer.markRead(5)
- expect(@persistence.setFolderRead).not.toHaveBeenCalled()
-
-
- it 'should get the correct unread count', =>
- @FeedModel.add({id: 5, unreadCount:2, folderId: 2, url: 'a1'})
- @FeedModel.add({id: 6, unreadCount:3, folderId: 3, url: 'a2'})
- @FeedModel.add({id: 7, unreadCount:4, folderId: 2, url: 'a3'})
-
- expect(@FolderBusinessLayer.getUnreadCount(2)).toBe(6)
-
-
- it 'should be visible if show all is true', =>
- @FolderModel.add({id: 3, opened: false, name: 'ho'})
- @FeedModel.add({id: 3, unreadCount:0, folderId: 3, url: 'a1'})
- expect(@FolderBusinessLayer.isVisible(3)).toBe(false)
-
- @ShowAll.setShowAll(true)
- expect(@FolderBusinessLayer.isVisible(3)).toBe(true)
-
-
- it 'should be visible if it has no feeds', =>
- @FeedModel.add({id: 3, unreadCount:0, folderId: 3, url: 'a1'})
- @FolderModel.add({id: 13, opened: false, name: 'ho'})
- expect(@FolderBusinessLayer.isVisible(13)).toBe(true)
-
-
- it 'should be visible if its active', =>
- @ActiveFeed.handle({type: @FeedType.Folder, id:3})
- expect(@FolderBusinessLayer.isVisible(3)).toBe(true)
-
-
- it 'should be visible if one of its subfeeds is active', =>
- @FeedModel.add({id: 5, unreadCount:0, folderId: 2, url: 'a1'})
- @FeedModel.add({id: 6, unreadCount:0, folderId: 3, url: 'a2'})
- @FeedModel.add({id: 7, unreadCount:0, folderId: 2, url: 'a3'})
-
- @ActiveFeed.handle({type: @FeedType.Feed, id:6})
- expect(@FolderBusinessLayer.isVisible(3)).toBe(true)
-
-
- it 'should be visible if showAll is false and it has unread items', =>
- @FeedModel.add({id: 5, unreadCount:2, folderId: 2, url: 'a1'})
- @FeedModel.add({id: 6, unreadCount:3, folderId: 3, url: 'a2'})
- @FeedModel.add({id: 7, unreadCount:4, folderId: 2, url: 'a3'})
-
- @ActiveFeed.handle({type: @FeedType.Folder, id:2})
- expect(@FolderBusinessLayer.isVisible(3)).toBe(true)
-
-
- it 'should return all folders', =>
- item1 = {id: 3, open: false, name: 'ho'}
- item2 = {id: 4, open: true, name: 'hod'}
- @FolderModel.add(item1)
- @FolderModel.add(item2)
-
- expect(@FolderBusinessLayer.getAll()).toContain(item1)
- expect(@FolderBusinessLayer.getAll()).toContain(item2)
-
-
- it 'should not create a folder if it already exists', =>
- item1 = {id: 4, open: true, name: 'john'}
- @FolderModel.add(item1)
-
- expect =>
- @FolderBusinessLayer.create('john')
- .toThrow(new @_ExistsError('Exists already'))
-
- expect =>
- @FolderBusinessLayer.create('johns')
- .not.toThrow(new @_ExistsError('Exists already'))
-
-
- it 'should not create folders that are empty', =>
- expect =>
- @FolderBusinessLayer.create(' ')
- .toThrow(new Error('Folder name must not be empty'))
-
-
- it 'should create a folder before theres a response from the server', =>
- @persistence.createFolder = jasmine.createSpy('create folder')
- @FolderBusinessLayer.create('johns')
- expect(@FolderModel.size()).toBe(1)
- expect(@FolderModel.getByName('johns').opened).toBe(true)
-
-
- it 'should make a create folder request', =>
- @persistence.createFolder = jasmine.createSpy('add folder')
-
- @FolderBusinessLayer.create(' johns ')
- expect(@persistence.createFolder).toHaveBeenCalledWith('johns', 0,
- jasmine.any(Function), jasmine.any(Function))
-
-
- it 'should call the onSuccess function on response status ok', =>
- onSuccess = jasmine.createSpy('Success')
- @persistence.createFolder = jasmine.createSpy('add folder')
- @persistence.createFolder.andCallFake (folderName, parentId, success) =>
- @response =
- data: 'jooo'
- success(@response)
-
- @FolderBusinessLayer.create(' johns ', onSuccess)
-
- expect(onSuccess).toHaveBeenCalledWith(@response)
-
-
- it 'should call the handle a response error when creating a folder', =>
- onSuccess = jasmine.createSpy('Success')
- onFailure = jasmine.createSpy('Failure')
- @persistence.createFolder = jasmine.createSpy('add folder')
- @persistence.createFolder.andCallFake (folderName, parentId, success,
- onFailure) =>
- @response =
- message: 'this is an error'
- onFailure(@response)
-
- @FolderBusinessLayer.create(' johns ', onSuccess, onFailure)
-
- expect(onSuccess).not.toHaveBeenCalled()
- expect(onFailure).toHaveBeenCalled()
-
- expect(@FolderModel.getByName('johns').error).toBe(@response.message)
-
-
- it 'should mark a folder error as read by removing it', =>
- @FolderModel.add({id: 3, name: 'john'})
-
- @FolderBusinessLayer.markErrorRead('John')
-
- expect(@FolderModel.size()).toBe(0)
- expect(@FolderModel.getByName('john')).toBe(undefined)
-
-
- it 'should return the corret folder for id', =>
- item = {id: 3, name: 'john'}
- @FolderModel.add(item)
-
- expect(@FolderBusinessLayer.getById(3)).toBe(item)
-
-
- it 'should open a folder', =>
- @persistence.openFolder = jasmine.createSpy('open')
-
- @FolderModel.add({id: 3, opened: false, name: 'ho'})
- @FolderBusinessLayer.open(3)
- expect(@FolderModel.getById(3).opened).toBeTruthy()
- expect(@persistence.openFolder).toHaveBeenCalledWith(3)
-
-
- it 'should not import on empty opml', =>
- @persistence.createFolder = jasmine.createSpy('create folder')
- @persistence.createFeed = jasmine.createSpy('create feed')
-
- xml = '<?xml version="1.0" ?>
- <opml version="1.1">
- <!--Generated by NewsBlur - www.newsblur.com-->
- <head>
- <title>
- NewsBlur Feeds
- </title>
- <dateCreated>
- 2013-03-14 16:44:01.356965
- </dateCreated>
- <dateModified>
- 2013-03-14 16:44:01.356965
- </dateModified>
- </head>
- <body>
-
- </body>
- </opml>'
-
- @FolderBusinessLayer.import(xml)
-
- expect(@persistence.createFolder).not.toHaveBeenCalled()
- expect(@persistence.createFeed).not.toHaveBeenCalled()
-
-
- it 'should import a folder', =>
- @persistence.createFolder = jasmine.createSpy('create folder')
- @persistence.createFeed = jasmine.createSpy('create feed')
-
- xml = '<?xml version="1.0" ?>
- <opml version="1.1">
- <!--Generated by NewsBlur - www.newsblur.com-->
- <head>
- <title>
- NewsBlur Feeds
- </title>
- <dateCreated>
- 2013-03-14 16:44:01.356965
- </dateCreated>
- <dateModified>
- 2013-03-14 16:44:01.356965
- </dateModified>
- </head>
- <body>
- <outline text="Design" title="Design" />
- <outline text="test" title="test"></outline>
- </body>
- </opml>'
-
- @FolderBusinessLayer.import(xml)
-
- expect(@persistence.createFolder).toHaveBeenCalledWith('test', 0,
- jasmine.any(Function), jasmine.any(Function))
- expect(@persistence.createFeed).not.toHaveBeenCalled()
-
-
- it 'should import a feed', =>
- @persistence.createFolder = jasmine.createSpy('create folder')
- @persistence.createFeed = jasmine.createSpy('create feed')
-
- xml = '<?xml version="1.0" ?>
- <opml version="1.1">
- <!--Generated by NewsBlur - www.newsblur.com-->
- <head>
- <title>
- NewsBlur Feeds
- </title>
- <dateCreated>
- 2013-03-14 16:44:01.356965
- </dateCreated>
- <dateModified>
- 2013-03-14 16:44:01.356965
- </dateModified>
- </head>
- <body>
- <outline htmlUrl="http://worrydream.com/" text=
- "&lt;div&gt;Bret Victor\'s website&lt;/div&gt;"
- title="&lt;div&gt;Bret Victor\'s website&lt;/div&gt;"
- type="rss"
- version="RSS" xmlUrl="http://worrydream.com/feed.xml"/>
- </body>
- </opml>'
-
- @FolderBusinessLayer.import(xml)
-
- expect(@persistence.createFolder).not.toHaveBeenCalled()
- expect(@persistence.createFeed).toHaveBeenCalledWith(
- 'http://worrydream.com/feed.xml', 0, jasmine.any(Function),
- jasmine.any(Function))
-
-
- it 'should import nested folders', =>
- @persistence.createFolder = jasmine.createSpy('create folder')
- @persistence.createFolder.andCallFake (name, parentId, onSuccess) ->
- data =
- folders: [
- {id: 3}
- ]
- onSuccess(data)
-
- @persistence.createFeed = jasmine.createSpy('create feed')
-
- xml = '<?xml version="1.0" ?>
- <opml version="1.1">
- <!--Generated by NewsBlur - www.newsblur.com-->
- <head>
- <title>
- NewsBlur Feeds
- </title>
- <dateCreated>
- 2013-03-14 16:44:01.356965
- </dateCreated>
- <dateModified>
- 2013-03-14 16:44:01.356965
- </dateModified>
- </head>
- <body>
- <outline text="Design" title="Design">
- <outline htmlUrl="http://worrydream.com/" text=
- "&lt;div&gt;Bret Victor\'s website&lt;/div&gt;"
- title="&lt;div&gt;Bret Victor\'s website&lt;/div&gt;"
- type="rss"
- version="RSS" xmlUrl="http://worrydream.com/feed.xml"/>
- </outline>
- </body>
- </opml>'
-
- @FolderBusinessLayer.import(xml)
-
- expect(@persistence.createFolder).toHaveBeenCalledWith('Design', 0,
- jasmine.any(Function), jasmine.any(Function))
- expect(@persistence.createFeed).toHaveBeenCalledWith(
- 'http://worrydream.com/feed.xml', 3, jasmine.any(Function),
- jasmine.any(Function))
-
-
- it 'should use an existing folder when importing a folder', =>
- @persistence.createFolder = jasmine.createSpy('create folder')
- @persistence.createFeed = jasmine.createSpy('create feed')
- @persistence.openFolder = jasmine.createSpy('open')
-
- folder = {id: 2, name: 'design', opened: false}
- @FolderModel.add(folder)
- xml = '<?xml version="1.0" ?>
- <opml version="1.1">
- <!--Generated by NewsBlur - www.newsblur.com-->
- <head>
- <title>
- NewsBlur Feeds
- </title>
- <dateCreated>
- 2013-03-14 16:44:01.356965
- </dateCreated>
- <dateModified>
- 2013-03-14 16:44:01.356965
- </dateModified>
- </head>
- <body>
- <outline text="Design" title="Design">
- <outline htmlUrl="http://worrydream.com/" text=
- "&lt;div&gt;Bret Victor\'s website&lt;/div&gt;"
- title="&lt;div&gt;Bret Victor\'s website&lt;/div&gt;"
- type="rss"
- version="RSS" xmlUrl="http://worrydream.com/feed.xml"/>
- </outline>
- </body>
- </opml>'
-
- @FolderBusinessLayer.import(xml)
-
- expect(@persistence.createFolder).not.toHaveBeenCalled()
- expect(@persistence.createFeed).toHaveBeenCalledWith(
- 'http://worrydream.com/feed.xml', 2, jasmine.any(Function),
- jasmine.any(Function))
- expect(folder.opened).toBe(true)
- expect(@persistence.openFolder).toHaveBeenCalled()
-
-
-
- it 'should not import a feed if it already exists', =>
- @persistence.createFolder = jasmine.createSpy('create folder')
- @persistence.createFeed = jasmine.createSpy('create feed')
-
- @FeedModel.add({url: 'http://worrydream.com/feed.xml'})
-
- xml = '<?xml version="1.0" ?>
- <opml version="1.1">
- <!--Generated by NewsBlur - www.newsblur.com-->
- <head>
- <title>
- NewsBlur Feeds
- </title>
- <dateCreated>
- 2013-03-14 16:44:01.356965
- </dateCreated>
- <dateModified>