-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathEditTest.php
More file actions
148 lines (132 loc) · 3.25 KB
/
EditTest.php
File metadata and controls
148 lines (132 loc) · 3.25 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
<?php
/**
* TaskBlockRolePermissionsController::edit()のテスト
*
* @author Noriko Arai <arai@nii.ac.jp>
* @author Yuto Kitatsuji <kitatsuji.yuto@withone.co.jp>
* @link http://www.netcommons.org NetCommons Project
* @license http://www.netcommons.org/license.txt NetCommons License
* @copyright Copyright 2014, NetCommons Project
*/
App::uses('BlockRolePermissionsControllerEditTest', 'Blocks.TestSuite');
/**
* TaskBlockRolePermissionsController::edit()のテスト
*
* @author Yuto Kitatsuji <kitatsuji.yuto@withone.co.jp>
* @package NetCommons\Tasks\Test\Case\Controller\TaskBlockRolePermissionsController
*/
class TaskBlockRolePermissionsControllerEditTest extends BlockRolePermissionsControllerEditTest {
/**
* Fixtures
*
* @var array
*/
public $fixtures = array(
'plugin.tasks.task',
'plugin.tasks.task_charge',
'plugin.tasks.task_content',
'plugin.tasks.block_setting_for_task',
'plugin.workflow.workflow_comment',
);
/**
* Plugin name
*
* @var string
*/
public $plugin = 'tasks';
/**
* Controller name
*
* @var string
*/
protected $_controller = 'task_block_role_permissions';
/**
* 権限設定で使用するFieldsの取得
*
* @return array
*/
private function __approvalFields() {
$data = array(
'TaskSetting' => array(
'use_workflow',
'use_comment_approval',
'approval_type',
)
);
return $data;
}
/**
* テストDataの取得
*
* @return array
*/
private function __data() {
$data = array(
'TaskSetting' => array(
'id' => 2,
'task_key' => 'task_key_2',
'use_workflow' => true,
'use_comment_approval' => true,
'approval_type' => true,
)
);
return $data;
}
/**
* edit()アクションDataProvider
*
* ### 戻り値
* - approvalFields コンテンツ承認の利用有無のフィールド
* - exception Exception
* - return testActionの実行後の結果
*
* @return array
*/
public function dataProviderEditGet() {
return array(
array('approvalFields' => $this->__approvalFields())
);
}
/**
* edit()アクションDataProvider
*
* ### 戻り値
* - data POSTデータ
* - exception Exception
* - return testActionの実行後の結果
*
* @return array
*/
public function dataProviderEditPost() {
return array(
array('data' => $this->__data())
);
}
/**
* editアクションのGETテスト(Exceptionエラー)
*
* @param array $approvalFields コンテンツ承認の利用有無のフィールド
* @param string|null $exception Exception
* @param string $return testActionの実行後の結果
* @dataProvider dataProviderEditGet
* @return void
*/
public function testEditGetExceptionError($approvalFields, $exception = null, $return = 'view') {
$this->_mockForReturnFalse('Tasks.Task', 'getTask');
$exception = 'BadRequestException';
$this->testEditGet($approvalFields, $exception, $return);
}
/**
* test Post でのsaveTaskSetting 失敗
*
* @param array $data saveデータ
* @return void
* @dataProvider dataProviderEditPost
*/
public function testSaveTaskSettingFail($data) {
$this->_mockForReturnFalse('Tasks.TaskSetting', 'saveTaskSetting');
$result = $this->testEditPost($data, false, 'view');
$approvalFields = $this->__approvalFields();
$this->_assertEditGetPermission($approvalFields, $result);
}
}