Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
李少辉-开发者
gitlab-foss
提交
ac40843c
G
gitlab-foss
项目概览
李少辉-开发者
/
gitlab-foss
通知
15
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
G
gitlab-foss
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ac40843c
编写于
5月 02, 2016
作者:
S
Sean McGivern
提交者:
Alfredo Sumaran
6月 03, 2016
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fixup! WIP: allow adding and removing labels in bulk
上级
81a21c94
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
148 addition
and
0 deletion
+148
-0
spec/services/issues/bulk_update_service_spec.rb
spec/services/issues/bulk_update_service_spec.rb
+148
-0
未找到文件。
spec/services/issues/bulk_update_service_spec.rb
浏览文件 @
ac40843c
...
@@ -111,4 +111,152 @@ describe Issues::BulkUpdateService, services: true do
...
@@ -111,4 +111,152 @@ describe Issues::BulkUpdateService, services: true do
end
end
end
end
describe
'updating labels'
do
def
create_issue_with_labels
(
labels
)
create
(
:issue
,
project:
project
)
{
|
issue
|
issue
.
labels
=
labels
}
end
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
Projects
::
CreateService
.
new
(
user
,
namespace:
user
.
namespace
,
name:
'test'
).
execute
}
let
(
:label_1
)
{
create
(
:label
,
project:
project
)
}
let
(
:label_2
)
{
create
(
:label
,
project:
project
)
}
let
(
:label_3
)
{
create
(
:label
,
project:
project
)
}
let
(
:issue_all_labels
)
{
create_issue_with_labels
([
label_1
,
label_2
,
label_3
])
}
let
(
:issue_labels_1_and_2
)
{
create_issue_with_labels
([
label_1
,
label_2
])
}
let
(
:issue_labels_1_and_3
)
{
create_issue_with_labels
([
label_1
,
label_3
])
}
let
(
:issue_no_labels
)
{
create
(
:issue
,
project:
project
)
}
let
(
:issues
)
{
[
issue_all_labels
,
issue_labels_1_and_2
,
issue_labels_1_and_3
,
issue_no_labels
]
}
let
(
:labels
)
{
[]
}
let
(
:add_labels
)
{
[]
}
let
(
:remove_labels
)
{
[]
}
let
(
:params
)
do
{
label_ids:
labels
.
map
(
&
:id
),
add_label_ids:
add_labels
.
map
(
&
:id
),
remove_label_ids:
remove_labels
.
map
(
&
:id
),
issues_ids:
issues
.
map
(
&
:id
).
join
(
','
)
}
end
before
{
Issues
::
BulkUpdateService
.
new
(
project
,
user
,
params
).
execute
}
context
'when label_ids are passed'
do
let
(
:issues
)
{
[
issue_all_labels
,
issue_no_labels
]
}
let
(
:labels
)
{
[
label_1
,
label_2
]
}
it
'updates the labels of all issues passed to the labels passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
)).
to
all
(
eq
(
labels
.
map
(
&
:id
)))
end
it
'does not update issues not passed in'
do
expect
(
issue_labels_1_and_2
.
label_ids
).
to
contain_exactly
(
label_1
.
id
,
label_2
.
id
)
end
end
context
'when add_label_ids are passed'
do
let
(
:issues
)
{
[
issue_all_labels
,
issue_labels_1_and_3
,
issue_no_labels
]
}
let
(
:add_labels
)
{
[
label_1
,
label_2
,
label_3
]
}
it
'adds those label IDs to all issues passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
)).
to
all
(
include
(
*
add_labels
.
map
(
&
:id
)))
end
it
'does not update issues not passed in'
do
expect
(
issue_labels_1_and_2
.
label_ids
).
to
contain_exactly
(
label_1
.
id
,
label_2
.
id
)
end
end
context
'when remove_label_ids are passed'
do
let
(
:issues
)
{
[
issue_all_labels
,
issue_labels_1_and_3
,
issue_no_labels
]
}
let
(
:remove_labels
)
{
[
label_1
,
label_2
,
label_3
]
}
it
'removes those label IDs from all issues passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
)).
to
all
(
be_empty
)
end
it
'does not update issues not passed in'
do
expect
(
issue_labels_1_and_2
.
label_ids
).
to
contain_exactly
(
label_1
.
id
,
label_2
.
id
)
end
end
context
'when add_label_ids and remove_label_ids are passed'
do
let
(
:issues
)
{
[
issue_all_labels
,
issue_labels_1_and_3
,
issue_no_labels
]
}
let
(
:add_labels
)
{
[
label_1
]
}
let
(
:remove_labels
)
{
[
label_3
]
}
it
'adds the label IDs to all issues passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
)).
to
all
(
include
(
label_1
.
id
))
end
it
'removes the label IDs from all issues passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
).
flatten
).
not_to
include
(
label_3
.
id
)
end
it
'does not update issues not passed in'
do
expect
(
issue_labels_1_and_2
.
label_ids
).
to
contain_exactly
(
label_1
.
id
,
label_2
.
id
)
end
end
context
'when add_label_ids and label_ids are passed'
do
let
(
:issues
)
{
[
issue_all_labels
,
issue_labels_1_and_2
,
issue_labels_1_and_3
]
}
let
(
:labels
)
{
[
label_3
]
}
let
(
:add_labels
)
{
[
label_2
]
}
it
'adds the label IDs to all issues passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
)).
to
all
(
include
(
label_2
.
id
))
end
it
'ignores the label IDs parameter'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
)).
to
all
(
include
(
label_1
.
id
))
end
it
'does not update issues not passed in'
do
expect
(
issue_no_labels
.
label_ids
).
to
be_empty
end
end
context
'when remove_label_ids and label_ids are passed'
do
let
(
:issues
)
{
[
issue_no_labels
,
issue_labels_1_and_2
]
}
let
(
:labels
)
{
[
label_3
]
}
let
(
:remove_labels
)
{
[
label_2
]
}
it
'remove the label IDs from all issues passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
).
flatten
).
not_to
include
(
label_2
.
id
)
end
it
'ignores the label IDs parameter'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
).
flatten
).
not_to
include
(
label_3
.
id
)
end
it
'does not update issues not passed in'
do
expect
(
issue_all_labels
.
label_ids
).
to
contain_exactly
(
label_1
.
id
,
label_2
.
id
,
label_3
.
id
)
end
end
context
'when add_label_ids, remove_label_ids, and label_ids are passed'
do
let
(
:issues
)
{
[
issue_labels_1_and_3
,
issue_no_labels
]
}
let
(
:labels
)
{
[
label_2
]
}
let
(
:add_labels
)
{
[
label_1
]
}
let
(
:remove_labels
)
{
[
label_3
]
}
it
'adds the label IDs to all issues passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
)).
to
all
(
include
(
label_1
.
id
))
end
it
'removes the label IDs from all issues passed'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
).
flatten
).
not_to
include
(
label_3
.
id
)
end
it
'ignores the label IDs parameter'
do
expect
(
issues
.
map
(
&
:reload
).
map
(
&
:label_ids
).
flatten
).
not_to
include
(
label_2
.
id
)
end
it
'does not update issues not passed in'
do
expect
(
issue_labels_1_and_2
.
label_ids
).
to
contain_exactly
(
label_1
.
id
,
label_2
.
id
)
end
end
end
end
end
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录