BigW Consortium Gitlab
Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
gitlab-ce
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Forest Godfrey
gitlab-ce
Commits
21a1e156
Commit
21a1e156
authored
Apr 22, 2016
by
Alfredo Sumaran
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/master' into issue_3799
parents
e0c07b5e
d5398e96
Hide whitespace changes
Inline
Side-by-side
Showing
36 changed files
with
253 additions
and
63 deletions
+253
-63
CHANGELOG
CHANGELOG
+3
-1
labels_select.js.coffee
app/assets/javascripts/labels_select.js.coffee
+1
-1
buttons.scss
app/assets/stylesheets/framework/buttons.scss
+4
-0
files.scss
app/assets/stylesheets/framework/files.scss
+5
-0
confirmation.scss
app/assets/stylesheets/pages/confirmation.scss
+18
-0
confirmations_controller.rb
app/controllers/confirmations_controller.rb
+9
-0
application_controller.rb
app/controllers/projects/application_controller.rb
+1
-2
issues_controller.rb
app/controllers/projects/issues_controller.rb
+1
-2
merge_requests_controller.rb
app/controllers/projects/merge_requests_controller.rb
+1
-2
registrations_controller.rb
app/controllers/registrations_controller.rb
+2
-2
issuable_finder.rb
app/finders/issuable_finder.rb
+1
-3
diff_helper.rb
app/helpers/diff_helper.rb
+7
-1
issuable_base_service.rb
app/services/issuable_base_service.rb
+26
-2
almost_there.haml
app/views/devise/confirmations/almost_there.haml
+10
-0
devise_empty.html.haml
app/views/layouts/devise_empty.html.haml
+17
-0
update.js.haml
app/views/projects/issues/update.js.haml
+0
-0
_show.html.haml
app/views/projects/merge_requests/_show.html.haml
+1
-1
update.js.haml
app/views/projects/merge_requests/update.js.haml
+0
-0
_sidebar.html.haml
app/views/shared/issuable/_sidebar.html.haml
+1
-1
routes.rb
config/routes.rb
+1
-0
20160421130527_disable_repository_checks.rb
db/migrate/20160421130527_disable_repository_checks.rb
+11
-0
schema.rb
db/schema.rb
+2
-2
repository_checks.md
doc/administration/repository_checks.md
+2
-1
cherry_pick_changes.md
doc/workflow/cherry_pick_changes.md
+2
-1
import_projects_from_github.md
doc/workflow/importing/import_projects_from_github.md
+9
-5
external_link_filter.rb
lib/banzai/filter/external_link_filter.rb
+2
-3
merge_requests_controller_spec.rb
spec/controllers/projects/merge_requests_controller_spec.rb
+0
-8
issues_spec.rb
spec/features/issues_spec.rb
+13
-0
markdown_spec.rb
spec/features/markdown_spec.rb
+6
-1
signup_spec.rb
spec/features/signup_spec.rb
+2
-2
diff_helper_spec.rb
spec/helpers/diff_helper_spec.rb
+20
-0
external_link_filter_spec.rb
spec/lib/banzai/filter/external_link_filter_spec.rb
+9
-1
bulk_update_service_spec.rb
spec/services/issues/bulk_update_service_spec.rb
+1
-1
create_service_spec.rb
spec/services/issues/create_service_spec.rb
+49
-14
update_service_spec.rb
spec/services/issues/update_service_spec.rb
+8
-3
update_service_spec.rb
spec/services/merge_requests/update_service_spec.rb
+8
-3
No files found.
CHANGELOG
View file @
21a1e156
...
...
@@ -4,6 +4,7 @@ v 8.8.0 (unreleased)
v 8.7.0 (unreleased)
- Gitlab::GitAccess and Gitlab::GitAccessWiki are now instrumented
- Fix vulnerability that made it possible to gain access to private labels and milestones
- The number of InfluxDB points stored per UDP packet can now be configured
- Fix error when cross-project label reference used with non-existent project
- Transactions for /internal/allowed now have an "action" tag set
...
...
@@ -54,7 +55,7 @@ v 8.7.0 (unreleased)
- Add links to CI setup documentation from project settings and builds pages
- Display project members page to all members
- Handle nil descriptions in Slack issue messages (Stan Hu)
- Add automated repository integrity checks
- Add automated repository integrity checks
(OFF by default)
- API: Expose open_issues_count, closed_issues_count, open_merge_requests_count for labels (Robert Schilling)
- API: Ability to star and unstar a project (Robert Schilling)
- Add default scope to projects to exclude projects pending deletion
...
...
@@ -81,6 +82,7 @@ v 8.7.0 (unreleased)
- Remove "Congratulations!" tweet button on newly-created project. (Connor Shea)
- Fix admin/projects when using visibility levels on search (PotHix)
- Build status notifications
- Update email confirmation interface
- API: Expose user location (Robert Schilling)
- API: Do not leak group existence via return code (Robert Schilling)
- ClosingIssueExtractor regex now also works with colons. e.g. "Fixes: #1234" !3591
...
...
app/assets/javascripts/labels_select.js.coffee
View file @
21a1e156
...
...
@@ -31,7 +31,7 @@ class @LabelsSelect
labelHTMLTemplate
=
_
.
template
(
'<% _.each(labels, function(label){ %>
<a href="<%= ["",issueURLSplit[1], issueURLSplit[2],""].join("/") %>issues?label_name=<%= _.escape(label.title) %>">
<span class="label has-tooltip color-label" title="<%= _.escape(label.description) %>" style="background-color: <%= label.color %>;">
<span class="label has-tooltip color-label" title="<%= _.escape(label.description) %>" style="background-color: <%= label.color %>;
color: <%= label.text_color %>;
">
<%= _.escape(label.title) %>
</span>
</a>
...
...
app/assets/stylesheets/framework/buttons.scss
View file @
21a1e156
...
...
@@ -144,6 +144,10 @@
}
}
.btn-lg
{
padding
:
12px
20px
;
}
.btn-transparent
{
color
:
$btn-transparent-color
;
background-color
:
transparent
;
...
...
app/assets/stylesheets/framework/files.scss
View file @
21a1e156
...
...
@@ -131,6 +131,11 @@
td
.line-numbers
{
float
:
none
;
border-left
:
1px
solid
#ddd
;
i
{
float
:
none
;
margin-right
:
0
;
}
}
td
.lines
{
padding
:
0
;
...
...
app/assets/stylesheets/pages/confirmation.scss
0 → 100644
View file @
21a1e156
.well-confirmation
{
margin-bottom
:
20px
;
border-bottom
:
1px
solid
#eee
;
>
h1
{
font-weight
:
400
;
}
.lead
{
margin-bottom
:
20px
;
}
}
.confirmation-content
{
a
{
color
:
$md-link-color
;
}
}
app/controllers/confirmations_controller.rb
View file @
21a1e156
class
ConfirmationsController
<
Devise
::
ConfirmationsController
def
almost_there
flash
[
:notice
]
=
nil
render
layout:
"devise_empty"
end
protected
def
after_resending_confirmation_instructions_path_for
(
resource
)
users_almost_there_path
end
def
after_confirmation_path_for
(
resource_name
,
resource
)
if
signed_in?
(
resource_name
)
after_sign_in_path_for
(
resource
)
...
...
app/controllers/projects/application_controller.rb
View file @
21a1e156
...
...
@@ -83,8 +83,7 @@ class Projects::ApplicationController < ApplicationController
end
def
apply_diff_view_cookie!
view
=
params
[
:view
]
||
cookies
[
:diff_view
]
cookies
.
permanent
[
:diff_view
]
=
params
[
:view
]
=
view
if
view
cookies
.
permanent
[
:diff_view
]
=
params
.
delete
(
:view
)
if
params
[
:view
].
present?
end
def
builds_enabled
...
...
app/controllers/projects/issues_controller.rb
View file @
21a1e156
...
...
@@ -101,7 +101,6 @@ class Projects::IssuesController < Projects::ApplicationController
end
respond_to
do
|
format
|
format
.
js
format
.
html
do
if
@issue
.
valid?
redirect_to
issue_path
(
@issue
)
...
...
@@ -110,7 +109,7 @@ class Projects::IssuesController < Projects::ApplicationController
end
end
format
.
json
do
render
json:
@issue
.
to_json
(
include:
[
:milestone
,
:labels
,
assignee:
{
methods: :avatar_url
}])
render
json:
@issue
.
to_json
(
include:
[
:milestone
,
labels:
{
methods: :text_color
}
,
assignee:
{
methods: :avatar_url
}])
end
end
end
...
...
app/controllers/projects/merge_requests_controller.rb
View file @
21a1e156
...
...
@@ -149,13 +149,12 @@ class Projects::MergeRequestsController < Projects::ApplicationController
if
@merge_request
.
valid?
respond_to
do
|
format
|
format
.
js
format
.
html
do
redirect_to
([
@merge_request
.
target_project
.
namespace
.
becomes
(
Namespace
),
@merge_request
.
target_project
,
@merge_request
])
end
format
.
json
do
render
json:
@merge_request
.
to_json
(
include:
[
:milestone
,
:labels
,
assignee:
{
methods: :avatar_url
}])
render
json:
@merge_request
.
to_json
(
include:
[
:milestone
,
labels:
{
methods: :text_color
}
,
assignee:
{
methods: :avatar_url
}])
end
end
else
...
...
app/controllers/registrations_controller.rb
View file @
21a1e156
...
...
@@ -31,11 +31,11 @@ class RegistrationsController < Devise::RegistrationsController
end
def
after_sign_up_path_for
(
_resource
)
new_user_session
_path
users_almost_there
_path
end
def
after_inactive_sign_up_path_for
(
_resource
)
new_user_session
_path
users_almost_there
_path
end
private
...
...
app/finders/issuable_finder.rb
View file @
21a1e156
...
...
@@ -278,9 +278,7 @@ class IssuableFinder
end
end
# When filtering by multiple labels we may end up duplicating issues (if one
# has multiple labels). This ensures we only return unique issues.
items
.
distinct
items
end
def
by_due_date
(
items
)
...
...
app/helpers/diff_helper.rb
View file @
21a1e156
...
...
@@ -9,7 +9,13 @@ module DiffHelper
end
def
diff_view
params
[
:view
]
==
'parallel'
?
'parallel'
:
'inline'
diff_views
=
%w(inline parallel)
if
diff_views
.
include?
(
cookies
[
:diff_view
])
cookies
[
:diff_view
]
else
diff_views
.
first
end
end
def
diff_hard_limit_enabled?
...
...
app/services/issuable_base_service.rb
View file @
21a1e156
...
...
@@ -37,8 +37,9 @@ class IssuableBaseService < BaseService
end
def
filter_params
(
issuable_ability_name
=
:issue
)
params
[
:assignee_id
]
=
""
if
params
[
:assignee_id
]
==
IssuableFinder
::
NONE
params
[
:milestone_id
]
=
""
if
params
[
:milestone_id
]
==
IssuableFinder
::
NONE
filter_assignee
filter_milestone
filter_labels
ability
=
:"admin_
#{
issuable_ability_name
}
"
...
...
@@ -49,6 +50,29 @@ class IssuableBaseService < BaseService
end
end
def
filter_assignee
if
params
[
:assignee_id
]
==
IssuableFinder
::
NONE
params
[
:assignee_id
]
=
''
end
end
def
filter_milestone
milestone_id
=
params
[
:milestone_id
]
return
unless
milestone_id
if
milestone_id
==
IssuableFinder
::
NONE
||
project
.
milestones
.
find_by
(
id:
milestone_id
).
nil?
params
[
:milestone_id
]
=
''
end
end
def
filter_labels
return
if
params
[
:label_ids
].
to_a
.
empty?
params
[
:label_ids
]
=
project
.
labels
.
where
(
id:
params
[
:label_ids
]).
pluck
(
:id
)
end
def
update
(
issuable
)
change_state
(
issuable
)
filter_params
...
...
app/views/devise/confirmations/almost_there.haml
0 → 100644
View file @
21a1e156
.well-confirmation.text-center
%h1
.prepend-top-0
Almost there...
%p
.lead
Please check your email to confirm your account
%p
.confirmation-content.text-center
No confirmation email received? Please check your spam folder or
.append-bottom-20.prepend-top-20.text-center
%a
.btn.btn-lg.btn-success
{
href:
new_user_confirmation_path
}
Request new confirmation email
app/views/layouts/devise_empty.html.haml
0 → 100644
View file @
21a1e156
!!! 5
%html
{
lang:
"en"
}
=
render
"layouts/head"
%body
.ui_charcoal.login-page.application.navless
=
render
"layouts/header/empty"
=
render
"layouts/broadcast"
.container.navless-container
.content
=
render
"layouts/flash"
=
yield
%hr
.container
.footer-links
=
link_to
"Explore"
,
explore_root_path
=
link_to
"Help"
,
help_path
=
link_to
"About GitLab"
,
"https://about.gitlab.com/"
app/views/projects/issues/update.js.haml
deleted
100644 → 0
View file @
e0c07b5e
app/views/projects/merge_requests/_show.html.haml
View file @
21a1e156
...
...
@@ -3,7 +3,7 @@
-
page_card_attributes
@merge_request
.
card_attributes
-
header_title
project_title
(
@project
,
"Merge Requests"
,
namespace_project_merge_requests_path
(
@project
.
namespace
,
@project
))
-
if
params
[
:view
]
==
'parallel'
-
if
diff_view
==
'parallel'
-
fluid_layout
true
.merge-request
{
'data-url'
=>
merge_request_path
(
@merge_request
)}
...
...
app/views/projects/merge_requests/update.js.haml
deleted
100644 → 0
View file @
e0c07b5e
app/views/shared/issuable/_sidebar.html.haml
View file @
21a1e156
...
...
@@ -20,7 +20,7 @@
%a
.btn.btn-default.issuable-pager.disabled
{
href:
'#'
}
Next
=
form_for
[
@project
.
namespace
.
becomes
(
Namespace
),
@project
,
issuable
],
remote:
true
,
html:
{
class:
'issuable-context-form inline-update js-issuable-update'
}
do
|
f
|
=
form_for
[
@project
.
namespace
.
becomes
(
Namespace
),
@project
,
issuable
],
remote:
true
,
format: :json
,
html:
{
class:
'issuable-context-form inline-update js-issuable-update'
}
do
|
f
|
.block.assignee
.sidebar-collapsed-icon.sidebar-collapsed-user
{
data:
{
toggle:
"tooltip"
,
placement:
"left"
,
container:
"body"
},
title:
(
issuable
.
assignee
.
to_reference
if
issuable
.
assignee
)}
-
if
issuable
.
assignee
...
...
config/routes.rb
View file @
21a1e156
...
...
@@ -418,6 +418,7 @@ Rails.application.routes.draw do
devise_scope
:user
do
get
'/users/auth/:provider/omniauth_error'
=>
'omniauth_callbacks#omniauth_error'
,
as: :omniauth_error
get
'/users/almost_there'
=>
'confirmations#almost_there'
end
root
to:
"root#index"
...
...
db/migrate/20160421130527_disable_repository_checks.rb
0 → 100644
View file @
21a1e156
class
DisableRepositoryChecks
<
ActiveRecord
::
Migration
def
up
change_column_default
:application_settings
,
:repository_checks_enabled
,
false
execute
'UPDATE application_settings SET repository_checks_enabled = false'
end
def
down
change_column_default
:application_settings
,
:repository_checks_enabled
,
true
execute
'UPDATE application_settings SET repository_checks_enabled = true'
end
end
db/schema.rb
View file @
21a1e156
...
...
@@ -11,7 +11,7 @@
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord
::
Schema
.
define
(
version:
201604
1912001
7
)
do
ActiveRecord
::
Schema
.
define
(
version:
201604
2113052
7
)
do
# These are extensions that must be enabled in order to support this database
enable_extension
"plpgsql"
...
...
@@ -77,7 +77,7 @@ ActiveRecord::Schema.define(version: 20160419120017) do
t
.
string
"akismet_api_key"
t
.
boolean
"email_author_in_body"
,
default:
false
t
.
integer
"default_group_visibility"
t
.
boolean
"repository_checks_enabled"
,
default:
tru
e
t
.
boolean
"repository_checks_enabled"
,
default:
fals
e
t
.
integer
"metrics_packet_size"
,
default:
1
t
.
text
"shared_runners_text"
end
...
...
doc/administration/repository_checks.md
View file @
21a1e156
# Repository checks
>**Note:**
This feature was
[
introduced
][
ce-3232
]
in GitLab 8.7.
This feature was
[
introduced
][
ce-3232
]
in GitLab 8.7. It is OFF by
default because it still causes too many false alarms.
Git has a built-in mechanism,
[
git fsck
][
git-fsck
]
, to verify the
integrity of all data commited to a repository. GitLab administrators
...
...
doc/workflow/cherry_pick_changes.md
View file @
21a1e156
# Cherry-pick changes
_**Note:** This feature was [introduced][ce-3514] in GitLab 8.7._
>**Note:**
This feature was
[
introduced
][
ce-3514
]
in GitLab 8.7.
---
...
...
doc/workflow/importing/import_projects_from_github.md
View file @
21a1e156
# Import your project from GitHub to GitLab
_
**Note:**
In order to enable the GitHub import setting, you should first
enable the
[
GitHub integration
][
gh-import
]
in your GitLab instance._
>**Note:**
In order to enable the GitHub import setting, you should first
enable the
[
GitHub integration
][
gh-import
]
in your GitLab instance.
At its current state, GitHub importer can import:
...
...
@@ -10,10 +11,13 @@ At its current state, GitHub importer can import:
-
the issues (introduced in GitLab 7.7)
-
the pull requests (introduced in GitLab 8.4)
-
the wiki pages (introduced in GitLab 8.4)
-
the milestones (introduced in GitLab 8.7)
-
the labels (introduced in GitLab 8.7)
It is not yet possible to import your labels, milestones and cross-repository
pull requests (those from forks). We are working on improving this in the near
future.
With GitLab 8.7+, references to pull requests and issues are preserved.
It is not yet possible to import your cross-repository pull requests (those from
forks). We are working on improving this in the near future.
The importer page is visible when you
[
create a new project
][
new-project
]
.
Click on the
**GitHub**
link and you will be redirected to GitHub for
...
...
lib/banzai/filter/external_link_filter.rb
View file @
21a1e156
module
Banzai
module
Filter
# HTML Filter to add a `rel="nofollow"` attribute to external links
#
# HTML Filter to modify the attributes of external links
class
ExternalLinkFilter
<
HTML
::
Pipeline
::
Filter
def
call
doc
.
search
(
'a'
).
each
do
|
node
|
...
...
@@ -15,7 +14,7 @@ module Banzai
# Skip internal links
next
if
link
.
start_with?
(
internal_url
)
node
.
set_attribute
(
'rel'
,
'nofollow'
)
node
.
set_attribute
(
'rel'
,
'nofollow
noreferrer
'
)
end
doc
...
...
spec/controllers/projects/merge_requests_controller_spec.rb
View file @
21a1e156
...
...
@@ -300,14 +300,6 @@ describe Projects::MergeRequestsController do
expect
(
response
.
cookies
[
'diff_view'
]).
to
eq
(
'parallel'
)
end
it
'assigns :view param based on cookie'
do
request
.
cookies
[
'diff_view'
]
=
'parallel'
go
expect
(
controller
.
params
[
:view
]).
to
eq
'parallel'
end
end
describe
'GET commits'
do
...
...
spec/features/issues_spec.rb
View file @
21a1e156
...
...
@@ -178,6 +178,19 @@ describe 'Issues', feature: true do
expect
(
first_issue
).
to
include
(
'foo'
)
end
context
'with a filter on labels'
do
let
(
:label
)
{
create
(
:label
,
project:
project
)
}
before
{
create
(
:label_link
,
label:
label
,
target:
foo
)
}
it
'sorts by least recently due date by excluding nil due dates'
do
bar
.
update
(
due_date:
nil
)
visit
namespace_project_issues_path
(
project
.
namespace
,
project
,
label_names:
[
label
.
name
],
sort:
sort_value_due_date_later
)
expect
(
first_issue
).
to
include
(
'foo'
)
end
end
end
describe
'filtering by due date'
do
...
...
spec/features/markdown_spec.rb
View file @
21a1e156
...
...
@@ -165,7 +165,12 @@ describe 'GitLab Markdown', feature: true do
describe
'ExternalLinkFilter'
do
it
'adds nofollow to external link'
do
link
=
doc
.
at_css
(
'a:contains("Google")'
)
expect
(
link
.
attr
(
'rel'
)).
to
match
'nofollow'
expect
(
link
.
attr
(
'rel'
)).
to
include
(
'nofollow'
)
end
it
'adds noreferrer to external link'
do
link
=
doc
.
at_css
(
'a:contains("Google")'
)
expect
(
link
.
attr
(
'rel'
)).
to
include
(
'noreferrer'
)
end
it
'ignores internal link'
do
...
...
spec/features/signup_spec.rb
View file @
21a1e156
...
...
@@ -13,8 +13,8 @@ feature 'Signup', feature: true do
fill_in
'user_password_sign_up'
,
with:
user
.
password
click_button
"Sign up"
expect
(
current_path
).
to
eq
user
_session
_path
expect
(
page
).
to
have_content
(
"
A message with a confirmation link has been sent to your email address.
"
)
expect
(
current_path
).
to
eq
user
s_almost_there
_path
expect
(
page
).
to
have_content
(
"
Please check your email to confirm your account
"
)
end
end
...
...
spec/helpers/diff_helper_spec.rb
View file @
21a1e156
...
...
@@ -11,6 +11,26 @@ describe DiffHelper do
let
(
:diff_refs
)
{
[
commit
.
parent
,
commit
]
}
let
(
:diff_file
)
{
Gitlab
::
Diff
::
File
.
new
(
diff
,
diff_refs
)
}
describe
'diff_view'
do
it
'returns a valid value when cookie is set'
do
helper
.
request
.
cookies
[
:diff_view
]
=
'parallel'
expect
(
helper
.
diff_view
).
to
eq
'parallel'
end
it
'returns a default value when cookie is invalid'
do
helper
.
request
.
cookies
[
:diff_view
]
=
'invalid'
expect
(
helper
.
diff_view
).
to
eq
'inline'
end
it
'returns a default value when cookie is nil'
do
expect
(
helper
.
request
.
cookies
).
to
be_empty
expect
(
helper
.
diff_view
).
to
eq
'inline'
end
end
describe
'diff_hard_limit_enabled?'
do
it
'should return true if param is provided'
do
allow
(
controller
).
to
receive
(
:params
)
{
{
force_show_diff:
true
}
}
...
...
spec/lib/banzai/filter/external_link_filter_spec.rb
View file @
21a1e156
...
...
@@ -24,6 +24,14 @@ describe Banzai::Filter::ExternalLinkFilter, lib: true do
doc
=
filter
(
act
)
expect
(
doc
.
at_css
(
'a'
)).
to
have_attribute
(
'rel'
)
expect
(
doc
.
at_css
(
'a'
)[
'rel'
]).
to
eq
'nofollow'
expect
(
doc
.
at_css
(
'a'
)[
'rel'
]).
to
include
'nofollow'
end
it
'adds rel="noreferrer" to external links'
do
act
=
%q(<a href="https://google.com/">Google</a>)
doc
=
filter
(
act
)
expect
(
doc
.
at_css
(
'a'
)).
to
have_attribute
(
'rel'
)
expect
(
doc
.
at_css
(
'a'
)[
'rel'
]).
to
include
'noreferrer'
end
end
spec/services/issues/bulk_update_service_spec.rb
View file @
21a1e156
...
...
@@ -100,7 +100,7 @@ describe Issues::BulkUpdateService, services: true do
describe
:update_milestone
do
before
do
@milestone
=
create
:milestone
@milestone
=
create
(
:milestone
,
project:
@project
)
@params
=
{
issues_ids:
[
issue
.
id
],
milestone_id:
@milestone
.
id
...
...
spec/services/issues/create_service_spec.rb
View file @
21a1e156
...
...
@@ -3,40 +3,75 @@ require 'spec_helper'
describe
Issues
::
CreateService
,
services:
true
do
let
(
:project
)
{
create
(
:empty_project
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:assignee
)
{
create
(
:user
)
}
describe
:execute
do
context
'valid params'
do
describe
'#execute'
do
let
(
:issue
)
{
described_class
.
new
(
project
,
user
,
opts
).
execute
}
context
'when params are valid'
do
let
(
:assignee
)
{
create
(
:user
)
}
let
(
:milestone
)
{
create
(
:milestone
,
project:
project
)
}
let
(
:labels
)
{
create_pair
(
:label
,
project:
project
)
}
before
do
project
.
team
<<
[
user
,
:master
]
project
.
team
<<
[
assignee
,
:master
]
end
opts
=
{
title:
'Awesome issue'
,
let
(
:opts
)
do
{
title:
'Awesome issue'
,
description:
'please fix'
,
assignee:
assignee
}
@issue
=
Issues
::
CreateService
.
new
(
project
,
user
,
opts
).
execute
assignee:
assignee
,
label_ids:
labels
.
map
(
&
:id
),
milestone_id:
milestone
.
id
}
end
it
{
expect
(
@issue
).
to
be_valid
}
it
{
expect
(
@issue
.
title
).
to
eq
(
'Awesome issue'
)
}
it
{
expect
(
@issue
.
assignee
).
to
eq
assignee
}
it
{
expect
(
issue
).
to
be_valid
}
it
{
expect
(
issue
.
title
).
to
eq
(
'Awesome issue'
)
}
it
{
expect
(
issue
.
assignee
).
to
eq
assignee
}
it
{
expect
(
issue
.
labels
).
to
match_array
labels
}
it
{
expect
(
issue
.
milestone
).
to
eq
milestone
}
it
'creates a pending todo for new assignee'
do
attributes
=
{
project:
project
,
author:
user
,
user:
assignee
,
target_id:
@
issue
.
id
,
target_type:
@
issue
.
class
.
name
,
target_id:
issue
.
id
,
target_type:
issue
.
class
.
name
,
action:
Todo
::
ASSIGNED
,
state: :pending
}
expect
(
Todo
.
where
(
attributes
).
count
).
to
eq
1
end
context
'when label belongs to different project'
do
let
(
:label
)
{
create
(
:label
)
}
let
(
:opts
)
do
{
title:
'Title'
,
description:
'Description'
,
label_ids:
[
label
.
id
]
}
end
it
'does not assign label'
do
expect
(
issue
.
labels
).
to_not
include
label
end
end
context
'when milestone belongs to different project'
do
let
(
:milestone
)
{
create
(
:milestone
)
}
let
(
:opts
)
do
{
title:
'Title'
,
description:
'Description'
,
milestone_id:
milestone
.
id
}
end
it
'does not assign milestone'
do
expect
(
issue
.
milestone
).
to_not
eq
milestone
end
end
end
end
end
spec/services/issues/update_service_spec.rb
View file @
21a1e156
...
...
@@ -4,10 +4,15 @@ describe Issues::UpdateService, services: true do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user2
)
{
create
(
:user
)
}
let
(
:user3
)
{
create
(
:user
)
}
let
(
:
issue
)
{
create
(
:issue
,
title:
'Old title'
,
assignee_id:
user3
.
id
)
}
let
(
:label
)
{
create
(
:label
)
}
let
(
:
project
)
{
create
(
:empty_project
)
}
let
(
:label
)
{
create
(
:label
,
project:
project
)
}
let
(
:label2
)
{
create
(
:label
)
}
let
(
:project
)
{
issue
.
project
}
let
(
:issue
)
do
create
(
:issue
,
title:
'Old title'
,
assignee_id:
user3
.
id
,
project:
project
)
end
before
do
project
.
team
<<
[
user
,
:master
]
...
...
spec/services/merge_requests/update_service_spec.rb
View file @
21a1e156
require
'spec_helper'
describe
MergeRequests
::
UpdateService
,
services:
true
do
let
(
:project
)
{
create
(
:project
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:user2
)
{
create
(
:user
)
}
let
(
:user3
)
{
create
(
:user
)
}
let
(
:merge_request
)
{
create
(
:merge_request
,
:simple
,
title:
'Old title'
,
assignee_id:
user3
.
id
)
}
let
(
:project
)
{
merge_request
.
project
}
let
(
:label
)
{
create
(
:label
)
}
let
(
:label
)
{
create
(
:label
,
project:
project
)
}
let
(
:label2
)
{
create
(
:label
)
}
let
(
:merge_request
)
do
create
(
:merge_request
,
:simple
,
title:
'Old title'
,
assignee_id:
user3
.
id
,
source_project:
project
)
end
before
do
project
.
team
<<
[
user
,
:master
]
project
.
team
<<
[
user2
,
:developer
]
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment