Account Suspended
Account Suspended
This Account has been suspended.
Contact your hosting provider for more information.
 All Data Structures Functions Variables Pages
AccountContactAffiliationsRegularUserWalkthroughTest.php
1 <?php
2  /*********************************************************************************
3  * Zurmo is a customer relationship management program developed by
4  * Zurmo, Inc. Copyright (C) 2017 Zurmo Inc.
5  *
6  * Zurmo is free software; you can redistribute it and/or modify it under
7  * the terms of the GNU Affero General Public License version 3 as published by the
8  * Free Software Foundation with the addition of the following permission added
9  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10  * IN WHICH THE COPYRIGHT IS OWNED BY ZURMO, ZURMO DISCLAIMS THE WARRANTY
11  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12  *
13  * Zurmo is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15  * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
16  * details.
17  *
18  * You should have received a copy of the GNU Affero General Public License along with
19  * this program; if not, see http://www.gnu.org/licenses or write to the Free
20  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21  * 02110-1301 USA.
22  *
23  * You can contact Zurmo, Inc. with a mailing address at 27 North Wacker Drive
24  * Suite 370 Chicago, IL 60606. or at email address contact@zurmo.com.
25  *
26  * The interactive user interfaces in original and modified versions
27  * of this program must display Appropriate Legal Notices, as required under
28  * Section 5 of the GNU Affero General Public License version 3.
29  *
30  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31  * these Appropriate Legal Notices must retain the display of the Zurmo
32  * logo and Zurmo copyright notice. If the display of the logo is not reasonably
33  * feasible for technical reasons, the Appropriate Legal Notices must display the words
34  * "Copyright Zurmo Inc. 2017. All rights reserved".
35  ********************************************************************************/
36 
49  {
50  protected static $account;
51 
52  protected static $contact;
53 
54  public static function setUpBeforeClass()
55  {
56  parent::setUpBeforeClass();
57  Yii::app()->user->userModel = User::getByUsername('nobody');
58 
59  self::$account = AccountTestHelper::createAccountByNameForOwner('superAccount', Yii::app()->user->userModel);
60  self::$contact = ContactTestHelper::
61  createContactWithAccountByNameForOwner('superContact', Yii::app()->user->userModel, self::$account);
62  }
63 
64  public function testRegularUserHasIncorrectRightsAndThenElevates()
65  {
66  Yii::app()->user->userModel = User::getByUsername('nobody');
67 
68  //Now test access failure with incorrect access
69  $this->setGetArray(array( 'relationAttributeName' => 'account',
70  'relationModelId' => self::$account->id,
71  'relationModuleId' => 'accounts',
72  'redirectUrl' => 'someRedirect'));
73  $this->runControllerShouldResultInAccessFailureAndGetContent('accountContactAffiliations/default/createFromRelation');
74 
75  //Now add rights to AccountContactAffiliationsModule
76  $super = $this->logoutCurrentUserLoginNewUserAndGetByUsername('super');
77 
78  //Now test peon with elevated rights to contacts
79  $nobody = User::getByUsername('nobody');
80  $nobody->setRight('AccountContactAffiliationsModule', AccountContactAffiliationsModule::RIGHT_ACCESS_ACCOUNT_CONTACT_AFFILIATIONS);
81  $this->assertTrue($nobody->save());
82 
83  //Should still failure because missing access to accounts and contacts
84  Yii::app()->user->userModel = User::getByUsername('nobody');
85  $this->setGetArray(array( 'relationAttributeName' => 'account',
86  'relationModelId' => self::$account->id,
87  'relationModuleId' => 'accounts',
88  'redirectUrl' => 'someRedirect'));
89  $this->runControllerShouldResultInAccessFailureAndGetContent('accountContactAffiliations/default/createFromRelation');
90 
91  //Now add rights to accounts and contacts
92  $nobody = User::getByUsername('nobody');
93  $nobody->setRight('ContactsModule', ContactsModule::RIGHT_ACCESS_CONTACTS);
94  $nobody->setRight('AccountsModule', AccountsModule::RIGHT_ACCESS_ACCOUNTS);
95  $this->assertTrue($nobody->save());
96 
97  //Now nobody user should be able to get to the action ok
98  Yii::app()->user->userModel = User::getByUsername('nobody');
99  $this->setGetArray(array( 'relationAttributeName' => 'account',
100  'relationModelId' => self::$account->id,
101  'relationModuleId' => 'accounts',
102  'redirectUrl' => 'someRedirect'));
103  $this->runControllerWithNoExceptionsAndGetContent('accountContactAffiliations/default/createFromRelation');
104  }
105  }
106 ?>
static getByUsername($username)
Definition: User.php:49
logoutCurrentUserLoginNewUserAndGetByUsername($username)
runControllerWithNoExceptionsAndGetContent($route, $empty=false)
Generated on Sat Jul 4 2020 07:10:29
Account Suspended
Account Suspended
This Account has been suspended.
Contact your hosting provider for more information.