2017-03-22 13:11:45 +00:00
|
|
|
should = require('chai').should()
|
|
|
|
SandboxedModule = require('sandboxed-module')
|
|
|
|
assert = require('assert')
|
|
|
|
path = require('path')
|
|
|
|
modulePath = path.join __dirname, '../../../../app/js/Features/Analytics/AnalyticsController'
|
|
|
|
sinon = require("sinon")
|
|
|
|
expect = require("chai").expect
|
|
|
|
|
|
|
|
|
|
|
|
describe 'AnalyticsController', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
|
|
|
@AuthenticationController =
|
|
|
|
getLoggedInUserId: sinon.stub()
|
|
|
|
|
|
|
|
@AnalyticsManager =
|
2018-03-05 11:15:41 +00:00
|
|
|
updateEditingSession: sinon.stub().callsArgWith(3)
|
2017-03-22 13:11:45 +00:00
|
|
|
recordEvent: sinon.stub().callsArgWith(3)
|
|
|
|
|
2018-08-22 17:31:29 +00:00
|
|
|
@InstitutionsAPI =
|
|
|
|
getInstitutionLicences: sinon.stub().callsArgWith(4)
|
|
|
|
|
2017-03-22 13:11:45 +00:00
|
|
|
@controller = SandboxedModule.require modulePath, requires:
|
|
|
|
"./AnalyticsManager":@AnalyticsManager
|
|
|
|
"../Authentication/AuthenticationController":@AuthenticationController
|
2018-08-22 17:31:29 +00:00
|
|
|
"../Institutions/InstitutionsAPI":@InstitutionsAPI
|
2017-03-22 13:11:45 +00:00
|
|
|
"logger-sharelatex":
|
|
|
|
log:->
|
2018-03-05 10:46:51 +00:00
|
|
|
'../../infrastructure/GeoIpLookup': @GeoIpLookup =
|
|
|
|
getDetails: sinon.stub()
|
2017-03-22 13:11:45 +00:00
|
|
|
|
2018-01-22 17:20:55 +00:00
|
|
|
@res =
|
|
|
|
send:->
|
|
|
|
|
|
|
|
describe "updateEditingSession", ->
|
|
|
|
beforeEach ->
|
|
|
|
@req =
|
|
|
|
params:
|
|
|
|
projectId: "a project id"
|
2018-03-05 10:46:51 +00:00
|
|
|
@GeoIpLookup.getDetails = sinon.stub()
|
|
|
|
.callsArgWith(1, null, {country_code: 'XY'})
|
2018-01-22 17:20:55 +00:00
|
|
|
|
|
|
|
it "delegates to the AnalyticsManager", (done) ->
|
|
|
|
@AuthenticationController.getLoggedInUserId.returns("1234")
|
|
|
|
@controller.updateEditingSession @req, @res
|
|
|
|
|
2018-03-02 12:02:45 +00:00
|
|
|
@AnalyticsManager.updateEditingSession.calledWith(
|
|
|
|
"1234",
|
|
|
|
"a project id",
|
2018-03-05 11:15:41 +00:00
|
|
|
'XY'
|
2018-03-02 12:02:45 +00:00
|
|
|
).should.equal true
|
2018-01-22 17:20:55 +00:00
|
|
|
done()
|
|
|
|
|
2017-03-22 13:11:45 +00:00
|
|
|
describe "recordEvent", ->
|
2018-01-22 17:20:55 +00:00
|
|
|
beforeEach ->
|
|
|
|
@req =
|
|
|
|
params:
|
|
|
|
event:"i_did_something"
|
|
|
|
body:"stuff"
|
|
|
|
sessionID: "sessionIDHere"
|
2018-03-02 12:02:45 +00:00
|
|
|
session: {}
|
2017-03-22 13:11:45 +00:00
|
|
|
|
|
|
|
it "should use the user_id", (done)->
|
|
|
|
@AuthenticationController.getLoggedInUserId.returns("1234")
|
|
|
|
@controller.recordEvent @req, @res
|
|
|
|
@AnalyticsManager.recordEvent.calledWith("1234", @req.params["event"], @req.body).should.equal true
|
|
|
|
done()
|
|
|
|
|
|
|
|
it "should use the session id", (done)->
|
|
|
|
@controller.recordEvent @req, @res
|
|
|
|
@AnalyticsManager.recordEvent.calledWith(@req.sessionID, @req.params["event"], @req.body).should.equal true
|
|
|
|
done()
|
2018-08-22 17:31:29 +00:00
|
|
|
|
|
|
|
describe "licences", ->
|
|
|
|
beforeEach ->
|
|
|
|
@req =
|
|
|
|
query:
|
|
|
|
resource_id:1
|
|
|
|
start_date:'1514764800'
|
|
|
|
end_date:'1530662400'
|
|
|
|
resource_type:'institution'
|
|
|
|
sessionID: "sessionIDHere"
|
|
|
|
session: {}
|
|
|
|
|
|
|
|
it "should trigger institutions api to fetch licences graph data", (done)->
|
|
|
|
@controller.licences @req, @res
|
|
|
|
@InstitutionsAPI.getInstitutionLicences.calledWith(@req.query["resource_id"], @req.query["start_date"], @req.query["end_date"], @req.query["lag"]).should.equal true
|
|
|
|
done()
|