/
TestOfToggleOwnerAdminController.php
115 lines (103 loc) · 4.23 KB
/
TestOfToggleOwnerAdminController.php
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
<?php
/**
*
* ThinkUp/tests/TestOfToggleOwnerAdminController.php
*
* Copyright (c) 2011-2012 Gina Trapani
*
* LICENSE:
*
* This file is part of ThinkUp (http://thinkupapp.com).
*
* ThinkUp is free software: you can redistribute it and/or modify it under the terms of the GNU General Public
* License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any
* later version.
*
* ThinkUp 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 General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with ThinkUp. If not, see
* <http://www.gnu.org/licenses/>.
*
*
* @author Gina Trapani <ginatrapani[at]gmail[dot]com>
* @license http://www.gnu.org/licenses/gpl.html
* @copyright 2011-2012 Gina Trapani
*/
require_once dirname(__FILE__).'/init.tests.php';
require_once THINKUP_WEBAPP_PATH.'_lib/extlib/simpletest/autorun.php';
require_once THINKUP_WEBAPP_PATH.'config.inc.php';
class TestOfToggleOwnerAdminController extends ThinkUpUnitTestCase {
public function setUp() {
parent::setUp();
}
public function tearDown() {
parent::tearDown();
}
public function testConstructor() {
$controller = new ToggleOwnerAdminController(true);
$this->assertTrue(isset($controller));
}
public function testNotLoggedIn() {
$controller = new ToggleOwnerAdminController(true);
$results = $controller->go();
$v_mgr = $controller->getViewManager();
$config = Config::getInstance();
$this->assertEqual('You must <a href="'.$config->getValue('site_root_path').
'session/login.php">log in</a> to do this.', $v_mgr->getTemplateDataItem('error_msg'));
}
public function testNotAnAdmin() {
$this->simulateLogin('me@example.com');
$controller = new ToggleOwnerAdminController(true);
$results = $controller->go();
$v_mgr = $controller->getViewManager();
$config = Config::getInstance();
$this->assertEqual('You must be a ThinkUp admin to do this', $v_mgr->getTemplateDataItem('error_msg'));
}
public function testMissingOwnerIdParam() {
$this->simulateLogin('me@example.com', true);
$_GET['a'] = 1;
$controller = new ToggleOwnerAdminController(true);
$results = $controller->go();
$this->assertEqual($results, 'Missing required parameters.', $results);
}
public function testMissingAdminParam() {
$this->simulateLogin('me@example.com', true);
$_GET['oid'] = 1;
$controller = new ToggleOwnerAdminController(true);
$results = $controller->go();
$this->assertEqual($results, 'Missing required parameters.', $results);
}
public function testBothParamsNonExistentInstance() {
$this->simulateLogin('me@example.com', true);
$_GET['oid'] = 1;
$_GET['a'] = 1;
$controller = new ToggleOwnerAdminController(true);
$results = $controller->go();
$this->assertEqual($results, 0, $results);
}
public function testBothParamsExistentInstanceNoCSRFToken() {
$builder = FixtureBuilder::build('owners', array('id'=>51, 'email'=>'me123@example.com', 'is_active'=>0));
$this->simulateLogin('me@example.com', true, true);
$_GET['oid'] = '51';
$_GET['a'] = '1';
$controller = new ToggleOwnerAdminController(true);
try {
$results = $controller->control();
$this->fail("should throw InvalidCSRFTokenException");
} catch(InvalidCSRFTokenException $e) {
$this->assertIsA($e, 'InvalidCSRFTokenException');
}
}
public function testBothParamsExistentInstance() {
$builder = FixtureBuilder::build('owners', array('id'=>51, 'email'=>'me123@example.com', 'is_active'=>0));
$this->simulateLogin('me@example.com', true, true);
$_GET['csrf_token'] = parent::CSRF_TOKEN;
$_GET['oid'] = '51';
$_GET['a'] = '1';
$controller = new ToggleOwnerAdminController(true);
$results = $controller->go();
$this->assertEqual($results, 1);
}
}