Adding transfer project unit tests
parent
80c7704298
commit
cb07dea242
|
@ -1,4 +1,4 @@
|
||||||
tg-transfer-project.transfer-project(
|
tg-transfer-project.transfer-project(
|
||||||
ng-if="vm.project"
|
ng-if="vm.project"
|
||||||
project = "vm.project"
|
project="vm.project"
|
||||||
)
|
)
|
||||||
|
|
|
@ -0,0 +1,275 @@
|
||||||
|
###
|
||||||
|
# Copyright (C) 2014-2016 Taiga Agile LLC <taiga@taiga.io>
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as
|
||||||
|
# published by the Free Software Foundation, either version 3 of the
|
||||||
|
# License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program 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 program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
# File: transfer-project.controller.spec.coffee
|
||||||
|
###
|
||||||
|
|
||||||
|
describe "TransferProject", ->
|
||||||
|
$controller = null
|
||||||
|
$q = null
|
||||||
|
provide = null
|
||||||
|
$rootScope = null
|
||||||
|
mocks = {}
|
||||||
|
|
||||||
|
_mockRouteParams = () ->
|
||||||
|
mocks.routeParams = {}
|
||||||
|
provide.value "$routeParams", mocks.routeParams
|
||||||
|
|
||||||
|
_mockProjectsService = () ->
|
||||||
|
mocks.projectsService = {
|
||||||
|
transferValidateToken: sinon.stub()
|
||||||
|
transferAccept: sinon.stub()
|
||||||
|
transferReject: sinon.stub()
|
||||||
|
}
|
||||||
|
|
||||||
|
provide.value "tgProjectsService", mocks.projectsService
|
||||||
|
|
||||||
|
_mockLocation = () ->
|
||||||
|
mocks.location = {
|
||||||
|
path: sinon.stub()
|
||||||
|
}
|
||||||
|
provide.value "$location", mocks.location
|
||||||
|
|
||||||
|
_mockAuth = () ->
|
||||||
|
mocks.auth = {
|
||||||
|
refresh: sinon.stub()
|
||||||
|
}
|
||||||
|
|
||||||
|
provide.value "$tgAuth", mocks.auth
|
||||||
|
|
||||||
|
_mockCurrentUserService = () ->
|
||||||
|
mocks.currentUserService = {
|
||||||
|
getUser: sinon.stub()
|
||||||
|
canOwnProject: sinon.stub()
|
||||||
|
}
|
||||||
|
|
||||||
|
provide.value "tgCurrentUserService", mocks.currentUserService
|
||||||
|
|
||||||
|
_mockTgNavUrls = () ->
|
||||||
|
mocks.tgNavUrls = {
|
||||||
|
resolve: sinon.stub()
|
||||||
|
}
|
||||||
|
|
||||||
|
provide.value "$tgNavUrls", mocks.tgNavUrls
|
||||||
|
|
||||||
|
_mockTranslate = () ->
|
||||||
|
mocks.translate = {
|
||||||
|
instant: sinon.stub()
|
||||||
|
}
|
||||||
|
|
||||||
|
provide.value "$translate", mocks.translate
|
||||||
|
|
||||||
|
_mockTgConfirm = ->
|
||||||
|
mocks.tgConfirm = {
|
||||||
|
notify: sinon.stub()
|
||||||
|
}
|
||||||
|
|
||||||
|
provide.value("$tgConfirm", mocks.tgConfirm)
|
||||||
|
|
||||||
|
_mocks = () ->
|
||||||
|
module ($provide) ->
|
||||||
|
provide = $provide
|
||||||
|
_mockRouteParams()
|
||||||
|
_mockProjectsService()
|
||||||
|
_mockLocation()
|
||||||
|
_mockAuth()
|
||||||
|
_mockCurrentUserService()
|
||||||
|
_mockTgNavUrls()
|
||||||
|
_mockTranslate()
|
||||||
|
_mockTgConfirm()
|
||||||
|
return null
|
||||||
|
|
||||||
|
_inject = (callback) ->
|
||||||
|
inject (_$controller_, _$q_, _$rootScope_) ->
|
||||||
|
$q = _$q_
|
||||||
|
$rootScope = _$rootScope_
|
||||||
|
$controller = _$controller_
|
||||||
|
|
||||||
|
beforeEach ->
|
||||||
|
module "taigaProjects"
|
||||||
|
_mocks()
|
||||||
|
_inject()
|
||||||
|
|
||||||
|
it "invalid token", (done) ->
|
||||||
|
project = Immutable.fromJS({
|
||||||
|
id: 1
|
||||||
|
})
|
||||||
|
|
||||||
|
user = Immutable.fromJS({})
|
||||||
|
|
||||||
|
mocks.auth.refresh.promise().resolve()
|
||||||
|
mocks.routeParams.token = "BAD_TOKEN"
|
||||||
|
mocks.currentUserService.getUser.returns(user)
|
||||||
|
mocks.projectsService.transferValidateToken.withArgs(1, "BAD_TOKEN").promise().reject()
|
||||||
|
mocks.tgNavUrls.resolve.withArgs("not-found").returns("/not-found")
|
||||||
|
|
||||||
|
ctrl = $controller("TransferProjectController")
|
||||||
|
ctrl.project = project
|
||||||
|
ctrl.initialize().then () ->
|
||||||
|
expect(mocks.location.path).to.be.calledWith("/not-found")
|
||||||
|
done()
|
||||||
|
|
||||||
|
it "valid token private project with max projects for user", (done) ->
|
||||||
|
project = Immutable.fromJS({
|
||||||
|
id: 1
|
||||||
|
is_private: true
|
||||||
|
})
|
||||||
|
|
||||||
|
user = Immutable.fromJS({
|
||||||
|
max_private_projects: 1
|
||||||
|
total_private_projects: 1
|
||||||
|
max_memberships_private_projects: 25
|
||||||
|
})
|
||||||
|
|
||||||
|
mocks.auth.refresh.promise().resolve()
|
||||||
|
mocks.routeParams.token = "TOKEN"
|
||||||
|
mocks.currentUserService.getUser.returns(user)
|
||||||
|
mocks.projectsService.transferValidateToken.withArgs(1, "TOKEN").promise().resolve()
|
||||||
|
|
||||||
|
ctrl = $controller("TransferProjectController")
|
||||||
|
ctrl.project = project
|
||||||
|
ctrl.initialize().then () ->
|
||||||
|
expect(ctrl.ownerMessage).to.be.equal("ADMIN.PROJECT_TRANSFER.OWNER_MESSAGE.PRIVATE")
|
||||||
|
expect(ctrl.maxProjects).to.be.equal(1)
|
||||||
|
expect(ctrl.currentProjects).to.be.equal(1)
|
||||||
|
done()
|
||||||
|
|
||||||
|
it "valid token private project without max projects for user", (done) ->
|
||||||
|
project = Immutable.fromJS({
|
||||||
|
id: 1
|
||||||
|
is_private: true
|
||||||
|
})
|
||||||
|
|
||||||
|
user = Immutable.fromJS({
|
||||||
|
max_private_projects: null
|
||||||
|
total_private_projects: 1
|
||||||
|
max_memberships_private_projects: 25
|
||||||
|
})
|
||||||
|
|
||||||
|
mocks.auth.refresh.promise().resolve()
|
||||||
|
mocks.routeParams.token = "TOKEN"
|
||||||
|
mocks.currentUserService.getUser.returns(user)
|
||||||
|
mocks.projectsService.transferValidateToken.withArgs(1, "TOKEN").promise().resolve()
|
||||||
|
mocks.translate.instant.withArgs("ADMIN.PROJECT_TRANSFER.UNLIMITED_PROJECTS").returns("UNLIMITED_PROJECTS")
|
||||||
|
|
||||||
|
ctrl = $controller("TransferProjectController")
|
||||||
|
ctrl.project = project
|
||||||
|
ctrl.initialize().then () ->
|
||||||
|
expect(ctrl.ownerMessage).to.be.equal("ADMIN.PROJECT_TRANSFER.OWNER_MESSAGE.PRIVATE")
|
||||||
|
expect(ctrl.maxProjects).to.be.equal("UNLIMITED_PROJECTS")
|
||||||
|
expect(ctrl.currentProjects).to.be.equal(1)
|
||||||
|
done()
|
||||||
|
|
||||||
|
it "valid token public project with max projects for user", (done) ->
|
||||||
|
project = Immutable.fromJS({
|
||||||
|
id: 1
|
||||||
|
is_public: true
|
||||||
|
})
|
||||||
|
|
||||||
|
user = Immutable.fromJS({
|
||||||
|
max_public_projects: 1
|
||||||
|
total_public_projects: 1
|
||||||
|
max_memberships_public_projects: 25
|
||||||
|
})
|
||||||
|
|
||||||
|
mocks.auth.refresh.promise().resolve()
|
||||||
|
mocks.routeParams.token = "TOKEN"
|
||||||
|
mocks.currentUserService.getUser.returns(user)
|
||||||
|
mocks.projectsService.transferValidateToken.withArgs(1, "TOKEN").promise().resolve()
|
||||||
|
|
||||||
|
ctrl = $controller("TransferProjectController")
|
||||||
|
ctrl.project = project
|
||||||
|
ctrl.initialize().then () ->
|
||||||
|
expect(ctrl.ownerMessage).to.be.equal("ADMIN.PROJECT_TRANSFER.OWNER_MESSAGE.PUBLIC")
|
||||||
|
expect(ctrl.maxProjects).to.be.equal(1)
|
||||||
|
expect(ctrl.currentProjects).to.be.equal(1)
|
||||||
|
done()
|
||||||
|
|
||||||
|
it "valid token public project without max projects for user", (done) ->
|
||||||
|
project = Immutable.fromJS({
|
||||||
|
id: 1
|
||||||
|
is_public: true
|
||||||
|
})
|
||||||
|
|
||||||
|
user = Immutable.fromJS({
|
||||||
|
max_public_projects: null
|
||||||
|
total_public_projects: 1
|
||||||
|
max_memberships_public_projects: 25
|
||||||
|
})
|
||||||
|
|
||||||
|
mocks.auth.refresh.promise().resolve()
|
||||||
|
mocks.routeParams.token = "TOKEN"
|
||||||
|
mocks.currentUserService.getUser.returns(user)
|
||||||
|
mocks.projectsService.transferValidateToken.withArgs(1, "TOKEN").promise().resolve()
|
||||||
|
mocks.translate.instant.withArgs("ADMIN.PROJECT_TRANSFER.UNLIMITED_PROJECTS").returns("UNLIMITED_PROJECTS")
|
||||||
|
|
||||||
|
ctrl = $controller("TransferProjectController")
|
||||||
|
ctrl.project = project
|
||||||
|
ctrl.initialize().then () ->
|
||||||
|
expect(ctrl.ownerMessage).to.be.equal("ADMIN.PROJECT_TRANSFER.OWNER_MESSAGE.PUBLIC")
|
||||||
|
expect(ctrl.maxProjects).to.be.equal("UNLIMITED_PROJECTS")
|
||||||
|
expect(ctrl.currentProjects).to.be.equal(1)
|
||||||
|
done()
|
||||||
|
|
||||||
|
it "transfer accept", (done) ->
|
||||||
|
project = Immutable.fromJS({
|
||||||
|
id: 1
|
||||||
|
slug: "slug"
|
||||||
|
})
|
||||||
|
|
||||||
|
user = Immutable.fromJS({})
|
||||||
|
|
||||||
|
mocks.auth.refresh.promise().resolve()
|
||||||
|
mocks.routeParams.token = "TOKEN"
|
||||||
|
mocks.currentUserService.getUser.returns(user)
|
||||||
|
mocks.projectsService.transferValidateToken.withArgs(1, "TOKEN").promise().resolve()
|
||||||
|
mocks.projectsService.transferAccept.withArgs(1, "TOKEN", "this is my reason").promise().resolve()
|
||||||
|
mocks.tgNavUrls.resolve.withArgs("project-admin-project-profile-details", {project: "slug"}).returns("/project/slug/")
|
||||||
|
mocks.translate.instant.withArgs("ADMIN.PROJECT_TRANSFER.ACCEPTED_PROJECT_OWNERNSHIP").returns("ACCEPTED_PROJECT_OWNERNSHIP")
|
||||||
|
|
||||||
|
ctrl = $controller("TransferProjectController")
|
||||||
|
ctrl.project = project
|
||||||
|
ctrl.initialize().then () ->
|
||||||
|
ctrl.transferAccept("TOKEN", "this is my reason").then ->
|
||||||
|
expect(mocks.location.path).to.be.calledWith("/project/slug/")
|
||||||
|
expect(mocks.tgConfirm.notify).to.be.calledWith("success", "ACCEPTED_PROJECT_OWNERNSHIP", '', 5000)
|
||||||
|
|
||||||
|
done()
|
||||||
|
|
||||||
|
it "transfer reject", (done) ->
|
||||||
|
project = Immutable.fromJS({
|
||||||
|
id: 1
|
||||||
|
slug: "slug"
|
||||||
|
})
|
||||||
|
|
||||||
|
user = Immutable.fromJS({})
|
||||||
|
|
||||||
|
mocks.auth.refresh.promise().resolve()
|
||||||
|
mocks.routeParams.token = "TOKEN"
|
||||||
|
mocks.currentUserService.getUser.returns(user)
|
||||||
|
mocks.projectsService.transferValidateToken.withArgs(1, "TOKEN").promise().resolve()
|
||||||
|
mocks.projectsService.transferReject.withArgs(1, "TOKEN", "this is my reason").promise().resolve()
|
||||||
|
mocks.tgNavUrls.resolve.withArgs("project-admin-project-profile-details", {project: "slug"}).returns("/project/slug/")
|
||||||
|
mocks.translate.instant.withArgs("ADMIN.PROJECT_TRANSFER.REJECTED_PROJECT_OWNERNSHIP").returns("REJECTED_PROJECT_OWNERNSHIP")
|
||||||
|
|
||||||
|
ctrl = $controller("TransferProjectController")
|
||||||
|
ctrl.project = project
|
||||||
|
ctrl.initialize().then () ->
|
||||||
|
ctrl.transferReject("TOKEN", "this is my reason").then ->
|
||||||
|
expect(mocks.location.path).to.be.calledWith("/project/slug/")
|
||||||
|
expect(mocks.tgConfirm.notify).to.be.calledWith("success", "REJECTED_PROJECT_OWNERNSHIP", '', 5000)
|
||||||
|
|
||||||
|
done()
|
|
@ -32,17 +32,19 @@ class TransferProject
|
||||||
]
|
]
|
||||||
|
|
||||||
constructor: (@routeParams, @projectService, @location, @authService, @currentUserService, @navUrls, @translate, @confirmService) ->
|
constructor: (@routeParams, @projectService, @location, @authService, @currentUserService, @navUrls, @translate, @confirmService) ->
|
||||||
|
|
||||||
|
initialize: () ->
|
||||||
@.projectId = @.project.get("id")
|
@.projectId = @.project.get("id")
|
||||||
@.token = @routeParams.token
|
@.token = @routeParams.token
|
||||||
@._refreshUserData()
|
|
||||||
@.showAddComment = false
|
@.showAddComment = false
|
||||||
|
return @._refreshUserData()
|
||||||
|
|
||||||
_validateToken: () ->
|
_validateToken: () ->
|
||||||
@projectService.transferValidateToken(@.projectId, @.token).error (data, status) =>
|
return @projectService.transferValidateToken(@.projectId, @.token).then null, (data, status) =>
|
||||||
@location.path(@navUrls.resolve("not-found"))
|
@location.path(@navUrls.resolve("not-found"))
|
||||||
|
|
||||||
_refreshUserData: () ->
|
_refreshUserData: () ->
|
||||||
@authService.refresh().then () =>
|
return @authService.refresh().then () =>
|
||||||
@._validateToken()
|
@._validateToken()
|
||||||
@._setProjectData()
|
@._setProjectData()
|
||||||
@._checkOwnerData()
|
@._checkOwnerData()
|
||||||
|
@ -71,25 +73,25 @@ class TransferProject
|
||||||
@.validNumberOfMemberships = maxMemberships == null || @.project.get('total_memberships') <= maxMemberships
|
@.validNumberOfMemberships = maxMemberships == null || @.project.get('total_memberships') <= maxMemberships
|
||||||
|
|
||||||
transferAccept: (token, reason) ->
|
transferAccept: (token, reason) ->
|
||||||
@projectService.transferAccept(@.project.get("id"), token, reason).success () =>
|
return @projectService.transferAccept(@.project.get("id"), token, reason).then () =>
|
||||||
newUrl = @navUrls.resolve("project-admin-project-profile-details", {
|
newUrl = @navUrls.resolve("project-admin-project-profile-details", {
|
||||||
project: @.project.get("slug")
|
project: @.project.get("slug")
|
||||||
})
|
})
|
||||||
@location.path(newUrl)
|
@location.path(newUrl)
|
||||||
|
|
||||||
@confirmService.notify("success", @translate.instant("ADMIN.PROJECT_TRANSFER.ACCEPTED_PROJECT_OWNERNSHIP"), '', 15000)
|
@confirmService.notify("success", @translate.instant("ADMIN.PROJECT_TRANSFER.ACCEPTED_PROJECT_OWNERNSHIP"), '', 5000)
|
||||||
|
|
||||||
return
|
return
|
||||||
|
|
||||||
transferReject: (token, reason) ->
|
transferReject: (token, reason) ->
|
||||||
@projectService.transferReject(@.project.get("id"), token, reason).success () =>
|
return @projectService.transferReject(@.project.get("id"), token, reason).then () =>
|
||||||
newUrl = @navUrls.resolve("project-admin-project-profile-details", {
|
newUrl = @navUrls.resolve("project-admin-project-profile-details", {
|
||||||
project: @project.get("slug")
|
project: @project.get("slug")
|
||||||
})
|
})
|
||||||
@location.path(newUrl)
|
@location.path(newUrl)
|
||||||
@confirmService.notify("success", @translate.instant("ADMIN.PROJECT_TRANSFER.REJECTED_PROJECT_OWNERNSHIP"), '', 5000)
|
@confirmService.notify("success", @translate.instant("ADMIN.PROJECT_TRANSFER.REJECTED_PROJECT_OWNERNSHIP"), '', 5000)
|
||||||
|
|
||||||
return
|
return
|
||||||
|
|
||||||
addComment: () ->
|
addComment: () ->
|
||||||
@.showAddComment = true
|
@.showAddComment = true
|
||||||
|
@ -99,5 +101,4 @@ class TransferProject
|
||||||
@.reason = ''
|
@.reason = ''
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
module.controller("TransferProjectController", TransferProject)
|
module.controller("TransferProjectController", TransferProject)
|
||||||
|
|
|
@ -20,7 +20,11 @@
|
||||||
module = angular.module('taigaProjects')
|
module = angular.module('taigaProjects')
|
||||||
|
|
||||||
TransferProjectDirective = () ->
|
TransferProjectDirective = () ->
|
||||||
|
link = (scope, el, attrs, ctrl) ->
|
||||||
|
ctrl.initialize()
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
link: link,
|
||||||
scope: {},
|
scope: {},
|
||||||
bindToController: {
|
bindToController: {
|
||||||
project: "="
|
project: "="
|
||||||
|
|
Loading…
Reference in New Issue