chai = require('chai') chai.should() sinon = require("sinon") modulePath = "../../../../app/js/Features/Contacts/ContactManager" SandboxedModule = require('sandboxed-module') describe "ContactManager", -> beforeEach -> @ContactManager = SandboxedModule.require modulePath, requires: "request" : @request = sinon.stub() "settings-sharelatex": @settings = apis: contacts: url: "contacts.sharelatex.com" "logger-sharelatex": @logger = {log: sinon.stub(), error: sinon.stub(), err:->} @user_id = "user-id-123" @contact_id = "contact-id-123" @callback = sinon.stub() describe "getContacts", -> describe "with a successful response code", -> beforeEach -> @request.get = sinon.stub().callsArgWith(1, null, statusCode: 204, { contact_ids: @contact_ids = ["mock", "contact_ids"]}) @ContactManager.getContactIds @user_id, { limit: 42 }, @callback it "should get the contacts from the contacts api", -> @request.get .calledWith({ url: "#{@settings.apis.contacts.url}/user/#{@user_id}/contacts" qs: { limit: 42 } json: true jar: false }) .should.equal true it "should call the callback with the contatcs", -> @callback.calledWith(null, @contact_ids).should.equal true describe "with a failed response code", -> beforeEach -> @request.get = sinon.stub().callsArgWith(1, null, statusCode: 500, null) @ContactManager.getContactIds @user_id, { limit: 42 }, @callback it "should call the callback with an error", -> @callback.calledWith(new Error("contacts api responded with non-success code: 500")).should.equal true it "should log the error", -> @logger.error .calledWith({ err: new Error("contacts api responded with a non-success code: 500") user_id: @user_id }, "error getting contacts for user") .should.equal true describe "addContact", -> describe "with a successful response code", -> beforeEach -> @request.post = sinon.stub().callsArgWith(1, null, statusCode: 200, null) @ContactManager.addContact @user_id, @contact_id, @callback it "should add the contacts for the user in the contacts api", -> @request.post .calledWith({ url: "#{@settings.apis.contacts.url}/user/#{@user_id}/contacts" json: { contact_id: @contact_id } jar: false }) .should.equal true it "should call the callback", -> @callback.called.should.equal true describe "with a failed response code", -> beforeEach -> @request.post = sinon.stub().callsArgWith(1, null, statusCode: 500, null) @ContactManager.addContact @user_id, @contact_id, @callback it "should call the callback with an error", -> @callback.calledWith(new Error("contacts api responded with non-success code: 500")).should.equal true it "should log the error", -> @logger.error .calledWith({ err: new Error("contacts api responded with a non-success code: 500") user_id: @user_id contact_id: @contact_id }, "error adding contact for user") .should.equal true