mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
413e81f29a
It fixes a typo in the path. Related to https://github.com/sharelatex/analytics-sharelatex/pull/43
174 lines
6 KiB
CoffeeScript
174 lines
6 KiB
CoffeeScript
should = require('chai').should()
|
|
SandboxedModule = require('sandboxed-module')
|
|
assert = require('assert')
|
|
path = require('path')
|
|
modulePath = path.join __dirname, '../../../../app/js/Features/Announcements/AnnouncementsHandler'
|
|
sinon = require("sinon")
|
|
expect = require("chai").expect
|
|
|
|
|
|
describe 'AnnouncementsHandler', ->
|
|
|
|
beforeEach ->
|
|
@user =
|
|
_id:"3c6afe000000000000000000" #2002-02-14T00:00:00.000Z
|
|
email: "someone@gmail.com"
|
|
@AnalyticsManager =
|
|
getLastOccurrence: sinon.stub()
|
|
@BlogHandler =
|
|
getLatestAnnouncements:sinon.stub()
|
|
@settings = {}
|
|
@handler = SandboxedModule.require modulePath, requires:
|
|
"../Analytics/AnalyticsManager":@AnalyticsManager
|
|
"../Blog/BlogHandler":@BlogHandler
|
|
"settings-sharelatex":@settings
|
|
"logger-sharelatex":
|
|
log:->
|
|
|
|
describe "getUnreadAnnouncements", ->
|
|
beforeEach ->
|
|
@stubbedAnnouncements = [
|
|
{
|
|
date: new Date(1478836800000),
|
|
id: '/2016/11/01/introducting-latex-code-checker'
|
|
}, {
|
|
date: new Date(1308369600000),
|
|
id: '/2013/08/02/thesis-series-pt1'
|
|
}, {
|
|
date: new Date(1108369600000),
|
|
id: '/2005/08/04/somethingelse'
|
|
}, {
|
|
date: new Date(1208369600000),
|
|
id: '/2008/04/12/title-date-irrelivant'
|
|
}
|
|
]
|
|
@BlogHandler.getLatestAnnouncements.callsArgWith(0, null, @stubbedAnnouncements)
|
|
|
|
|
|
it "should mark all announcements as read is false", (done)->
|
|
@AnalyticsManager.getLastOccurrence.callsArgWith(2, null, [])
|
|
@handler.getUnreadAnnouncements @user, (err, announcements)=>
|
|
announcements[0].read.should.equal false
|
|
announcements[1].read.should.equal false
|
|
announcements[2].read.should.equal false
|
|
announcements[3].read.should.equal false
|
|
done()
|
|
|
|
it "should should be sorted again to ensure correct order", (done)->
|
|
@AnalyticsManager.getLastOccurrence.callsArgWith(2, null, [])
|
|
@handler.getUnreadAnnouncements @user, (err, announcements)=>
|
|
announcements[3].should.equal @stubbedAnnouncements[2]
|
|
announcements[2].should.equal @stubbedAnnouncements[3]
|
|
announcements[1].should.equal @stubbedAnnouncements[1]
|
|
announcements[0].should.equal @stubbedAnnouncements[0]
|
|
done()
|
|
|
|
it "should return older ones marked as read as well", (done)->
|
|
@AnalyticsManager.getLastOccurrence.callsArgWith(2, null, {segmentation:{blogPostId:"/2008/04/12/title-date-irrelivant"}})
|
|
@handler.getUnreadAnnouncements @user, (err, announcements)=>
|
|
announcements[0].id.should.equal @stubbedAnnouncements[0].id
|
|
announcements[0].read.should.equal false
|
|
|
|
announcements[1].id.should.equal @stubbedAnnouncements[1].id
|
|
announcements[1].read.should.equal false
|
|
|
|
announcements[2].id.should.equal @stubbedAnnouncements[3].id
|
|
announcements[2].read.should.equal true
|
|
|
|
announcements[3].id.should.equal @stubbedAnnouncements[2].id
|
|
announcements[3].read.should.equal true
|
|
|
|
done()
|
|
|
|
it "should return all of them marked as read", (done)->
|
|
@AnalyticsManager.getLastOccurrence.callsArgWith(2, null, {segmentation:{blogPostId:"/2016/11/01/introducting-latex-code-checker"}})
|
|
@handler.getUnreadAnnouncements @user, (err, announcements)=>
|
|
announcements[0].read.should.equal true
|
|
announcements[1].read.should.equal true
|
|
announcements[2].read.should.equal true
|
|
announcements[3].read.should.equal true
|
|
done()
|
|
|
|
it "should return posts older than signup date as read", (done)->
|
|
@stubbedAnnouncements.push({
|
|
date: new Date(978836800000),
|
|
id: '/2001/04/12/title-date-irrelivant'
|
|
})
|
|
@AnalyticsManager.getLastOccurrence.callsArgWith(2, null, [])
|
|
@handler.getUnreadAnnouncements @user, (err, announcements)=>
|
|
announcements[0].read.should.equal false
|
|
announcements[1].read.should.equal false
|
|
announcements[2].read.should.equal false
|
|
announcements[3].read.should.equal false
|
|
announcements[4].read.should.equal true
|
|
announcements[4].id.should.equal '/2001/04/12/title-date-irrelivant'
|
|
done()
|
|
|
|
|
|
describe "with custom domain announcements", ->
|
|
beforeEach ->
|
|
@stubbedDomainSpecificAnn = [
|
|
{
|
|
domains: ["gmail.com", 'yahoo.edu']
|
|
title: "some message"
|
|
excerpt: "read this"
|
|
url:"http://www.sharelatex.com/i/somewhere"
|
|
id:"iaaa"
|
|
date: new Date(1308369600000).toString()
|
|
}
|
|
]
|
|
|
|
@handler._domainSpecificAnnouncements = sinon.stub().returns(@stubbedDomainSpecificAnn)
|
|
|
|
it "should insert the domain specific in the correct place", (done)->
|
|
@AnalyticsManager.getLastOccurrence.callsArgWith(2, null, [])
|
|
@handler.getUnreadAnnouncements @user, (err, announcements)=>
|
|
announcements[4].should.equal @stubbedAnnouncements[2]
|
|
announcements[3].should.equal @stubbedAnnouncements[3]
|
|
announcements[2].should.equal @stubbedAnnouncements[1]
|
|
announcements[1].should.equal @stubbedDomainSpecificAnn[0]
|
|
announcements[0].should.equal @stubbedAnnouncements[0]
|
|
done()
|
|
|
|
describe "_domainSpecificAnnouncements", ->
|
|
beforeEach ->
|
|
@settings.domainAnnouncements = [
|
|
{
|
|
domains: ["gmail.com", 'yahoo.edu']
|
|
title: "some message"
|
|
excerpt: "read this"
|
|
url:"http://www.sharelatex.com/i/somewhere"
|
|
id:"id1"
|
|
date: new Date(1308369600000).toString()
|
|
}, {
|
|
domains: ["gmail.com", 'yahoo.edu']
|
|
title: "some message"
|
|
excerpt: "read this"
|
|
url:"http://www.sharelatex.com/i/somewhere"
|
|
date: new Date(1308369600000).toString()
|
|
}, {
|
|
domains: ["gmail.com", 'yahoo.edu']
|
|
title: "some message"
|
|
excerpt: "read this"
|
|
url:"http://www.sharelatex.com/i/somewhere"
|
|
id:"id3"
|
|
date: new Date(1308369600000).toString()
|
|
}
|
|
]
|
|
|
|
it "should filter announcments which don't have an id", (done) ->
|
|
result = @handler._domainSpecificAnnouncements "someone@gmail.com"
|
|
result.length.should.equal 2
|
|
result[0].id.should.equal "id1"
|
|
result[1].id.should.equal "id3"
|
|
done()
|
|
|
|
|
|
it "should match on domain", (done) ->
|
|
@settings.domainAnnouncements[2].domains = ["yahoo.com"]
|
|
result = @handler._domainSpecificAnnouncements "someone@gmail.com"
|
|
result.length.should.equal 1
|
|
result[0].id.should.equal "id1"
|
|
done()
|
|
|
|
|