Skip to content
Snippets Groups Projects
UsersControllerManagedLibrariesTest.php 16.3 KiB
Newer Older
<?php
/**
 * Copyright (c) 2012-2024, Agence Française Informatique (AFI). All rights reserved.
 *
 * BOKEH is free software; you can redistribute it and/or modify
 * it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE as published by
 * the Free Software Foundation.
 *
 * There are special exceptions to the terms and conditions of the AGPL as it
 * is applied to this software (see README file).
 *
 * BOKEH 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 AFFERO GENERAL PUBLIC LICENSE for more details.
 *
 * You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
 * along with BOKEH; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301  USA
 */


class UsersControllerManagedLibrariesGuestTest extends AbstractControllerTestCase {

  public function setUp()
  {
    parent::setUp();
    $this->fixture(Class_Users::class, ['id' => 458,
                                        'prenom' => 'Mimi',
                                        'nom' => 'Mathy',
                                        'login' => 'mmathy',
                                        'mail'=> 'mmathy@gmail.com',
                                        'pseudo' => 'mimi',
                                        'password' => 'secret',
                                        'role_level' => ZendAfi_Acl_AdminControllerRoles::INVITE,
                                        'idabon' => '',
                                        'id_site' => '',
                                        'ordreabon' => 1,
                                        'date_debut' => '19-07-2009',
                                        'date_fin' => '19-07-2050',
                                        'telephone' => '',
                                        'mobile' => '',
                                        'adresse' => '',
                                        'code_postal' => '',
                                        'ville' => '',
                                        'subscription_type' => '',
                                        'last_login' => null,
                                        'civilite' => '']);

    $this->dispatch('/admin/users/edit/id/458');
  }


  /** @test */
  public function multiInputManagedLibrariesShouldExist()
  {
    $this->assertXPath('//input[@name="managed_libraries"]');
  }


  /** @test */
  public function onLoadScriptShouldContainExpectedJS()
  {
    $this->assertXPathContentContains('//script', '$(function(){if ($(\'#role_level\').val() < 3) { $(\'#managed_libraries\').parent().parent().hide() } else { $(\'#managed_libraries\').parent().parent().show() }});');
  }


  /** @test */
  public function onChangeRoleLevelShouldContainExpectedJS()
  {
    $this->assertXPath('//select[@name="role_level"][@onchange="if (event.target.value < 3) { $(\'#managed_libraries\').parent().parent().hide() } else { $(\'#managed_libraries\').parent().parent().show() }"]');
  }
}




class UsersControllerManagedLibrariesPostGuestTest extends AbstractControllerTestCase {

  public function setUp()
  {
    parent::setUp();

    $this->fixture(Class_Bib::class,
                   ['id' => 100,
                    'libelle' => 'Poiter']);

    $this->postDispatch('/admin/users/add',
                        ['login' => 'mdavis',
                         'password' => 'tutu',
                         'nom' => 'Davis',
                         'prenom' => 'Miles',
                         'pseudo' => '',
                         'mail' => 'mdavis@free.fr',
                         'role_level' => ZendAfi_Acl_AdminControllerRoles::INVITE,
                         'id_site' => '100',
                         'managed_libraries' => '3;5;31',
                         'idabon' => '3444',
                         'ordreabon' => '',
                         'telephone' => '',
                         'adresse' => '',
                         'code_postal' => '',
                         'ville' => '',
                         'naissance' => '',
                         'mobile' => '',
                         'date_debut' => '',
                         'date_fin' => '',
                         'civilite' => 1,
                         'user_group_ids' => '']);
  }


  /** @test */
  public function mimiMathyManagedLibrariesShouldBeEmpty()
  {
    $this->assertEquals('', Class_Users::findFirstBy(['idabon' => '3444'])->getManagedLibraries());
  }
}




class UsersControllerManagedLibrariesPostAdminTest extends AbstractControllerTestCase {

  public function setUp()
  {
    parent::setUp();

    $this->fixture(Class_Bib::class,
                   ['id' => 100,
                    'libelle' => 'Poiter']);

    $this->postDispatch('/admin/users/add',
                        ['login' => 'mdavis',
                         'password' => 'tutu',
                         'nom' => 'Davis',
                         'prenom' => 'Miles',
                         'pseudo' => '',
                         'mail' => 'mdavis@free.fr',
                         'role_level' => ZendAfi_Acl_AdminControllerRoles::MODO_BIB,
                         'id_site' => '100',
                         'managed_libraries' => '3;5;31',
                         'idabon' => '3444',
                         'ordreabon' => '',
                         'telephone' => '',
                         'adresse' => '',
                         'code_postal' => '',
                         'ville' => '',
                         'naissance' => '',
                         'mobile' => '',
                         'date_debut' => '',
                         'date_fin' => '',
                         'civilite' => 1,
                         'user_group_ids' => '']);
  }


  /** @test */
  public function mimiMathyManagedLibrariesShouldBeEmpty()
  {
    $this->assertEquals('3;5;31', Class_Users::findFirstBy(['idabon' => '3444'])->getManagedLibraries());
  }
}




abstract class UsersControllerManagedLibrariesIndexTest
  extends Admin_AbstractControllerTestCase {

  public function setUp()
  {
    parent::setUp();


    $this->fixture(Class_Bib::class,
                   ['id' => 1,
                    'libelle' => 'Guéret']);
    $this->fixture(Class_Bib::class,
                   ['id' => 2,
                    'libelle' => 'Aubusson']);
    $this->fixture(Class_Bib::class,
                   ['id' => 3,
                    'libelle' => 'Felletin']);


    $this->fixture(Class_Users::class,
                   ['id' => 10,
                    'idabon' => '65656',
                    'login' => 'user_from_gueret',
                    'password' => 'secret',
                    'id_site' => 1,
                    'role_level' => ZendAfi_Acl_AdminControllerRoles::ABONNE_SIGB,
                    'last_login' => 0]);

    $this->fixture(Class_Users::class,
                   ['id' => 11,
                    'idabon' => '65657',
                    'login' => 'user_from_aubusson',
                    'password' => 'secret',
                    'id_site' => 2,
                    'role_level' => ZendAfi_Acl_AdminControllerRoles::ABONNE_SIGB,
                    'last_login' => 0]);

    $this->fixture(Class_Users::class,
                   ['id' => 12,
                    'idabon' => '65658',
                    'login' => 'user_from_felletin',
                    'password' => 'secret',
                    'id_site' => 3,
                    'role_level' => ZendAfi_Acl_AdminControllerRoles::ABONNE_SIGB,
                    'last_login' => 0]);


    ZendAfi_Auth::getInstance()->logUser($this->_getLoggedUser());

    $this->dispatch('/admin/users');
  }


  protected function _createLoggedUser(): Class_Users
  {
    return $this->fixture(Class_Users::class,
                          ['id' => 1,
                           'login' => 'logged_in',
                           'password' => 'secret',
                           'id_site' => 1,
                           'managed_libraries' => '',
                           'role_level' => '',
                           'last_login' => 0]);
  }


  protected function _getLoggedUser(): Class_Users
  {
    return $this->_createLoggedUser();
  }
}




class UsersControllerManagedLibrariesIndexModoBibManageGueretTest
  extends UsersControllerManagedLibrariesIndexTest {

  protected function _getLoggedUser(): Class_Users
  {
    $group = $this->fixture(Class_UserGroup::class,
                            ['id' => 28,
                             'libelle' => 'Rédacteur Bib',
                             'rights' => [Class_UserGroup::RIGHT_USER_SIGB_USER_READ]]);

    return $this->_createLoggedUser()
                ->setManagedLibraries('1')
                ->addUserGroup($group)
                ->setRoleLevel(ZendAfi_Acl_AdminControllerRoles::MODO_BIB);
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromGueret() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_gueret"]');
  }


  /** @test */
  public function usersTableShouldNotContainIdentifiantUserFromAubusson() {
    $this->assertNotXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_aubusson"]');
  }


  /** @test */
  public function usersTableShouldNotContainIdentifiantUserFromFelletin() {
    $this->assertNotXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_felletin"]');
  }


  /** @test */
  public function librarySelectorShouldContainGueret()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="1"]');
  }


  /** @test */
  public function librarySelectorShouldNotContainAubusson()
  {
    $this->assertNotXPath('//select[@name="search_id_site"]/option[@value="2"]');
  }


  /** @test */
  public function librarySelectorShouldNotContainFelletin()
  {
    $this->assertNotXPath('//select[@name="search_id_site"]/option[@value="3"]');
  }
}




class UsersControllerManagedLibrariesIndexAdminBibManageAubussonFelletinTest
  extends UsersControllerManagedLibrariesIndexTest {

  protected function _getLoggedUser(): Class_Users
  {
    $group = $this->fixture(Class_UserGroup::class,
                            ['id' => 28,
                             'libelle' => 'Admin Bib',
                             'rights' => [Class_UserGroup::RIGHT_USER_SIGB_USER_READ]]);

    return $this->_createLoggedUser()
                ->setManagedLibraries('2;3')
                ->addUserGroup($group)
                ->setRoleLevel(ZendAfi_Acl_AdminControllerRoles::ADMIN_BIB);
  }


  /** @test */
  public function usersTableShouldNotContainIdentifiantUserFromGueret() {
    $this->assertNotXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_gueret"]');
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromAubusson() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_aubusson"]');
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromFelletin() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_felletin"]');
  }


  /** @test */
  public function librarySelectorShouldNotContainGueret()
  {
    $this->assertNotXPath('//select[@name="search_id_site"]/option[@value="1"]');
  }


  /** @test */
  public function librarySelectorShouldContainAubusson()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="2"]');
  }


  /** @test */
  public function librarySelectorShouldContainFelletin()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="3"]');
  }
}




class UsersControllerManagedLibrariesIndexModoPortailManageAubussonFelletinTest
  extends UsersControllerManagedLibrariesIndexTest {

  protected function _getLoggedUser(): Class_Users
  {
    $group = $this->fixture(Class_UserGroup::class,
                            ['id' => 28,
                             'libelle' => 'Admin Bib',
                             'rights' => [Class_UserGroup::RIGHT_USER_SIGB_USER_READ]]);

    return $this->_createLoggedUser()
                ->setManagedLibraries('2;3')
                ->addUserGroup($group)
                ->setRoleLevel(ZendAfi_Acl_AdminControllerRoles::MODO_PORTAIL);
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromGueret() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_gueret"]');
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromAubusson() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_aubusson"]');
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromFelletin() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_felletin"]');
  }


  /** @test */
  public function librarySelectorShouldNotContainGueret()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="1"]');
  }


  /** @test */
  public function librarySelectorShouldContainAubusson()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="2"]');
  }


  /** @test */
  public function librarySelectorShouldContainFelletin()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="3"]');
  }
}




class UsersControllerManagedLibrariesIndexAdminPortailManageGueretTest
  extends UsersControllerManagedLibrariesIndexTest {

  protected function _getLoggedUser(): Class_Users
  {
    $group = $this->fixture(Class_UserGroup::class,
                            ['id' => 28,
                             'libelle' => 'Admin Bib',
                             'rights' => [Class_UserGroup::RIGHT_USER_SIGB_USER_READ]]);

    return $this->_createLoggedUser()
                ->setManagedLibraries('1')
                ->addUserGroup($group)
                ->setRoleLevel(ZendAfi_Acl_AdminControllerRoles::ADMIN_PORTAIL);
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromGueret() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_gueret"]');
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromAubusson() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_aubusson"]');
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromFelletin() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_felletin"]');
  }


  /** @test */
  public function librarySelectorShouldNotContainGueret()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="1"]');
  }


  /** @test */
  public function librarySelectorShouldContainAubusson()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="2"]');
  }


  /** @test */
  public function librarySelectorShouldContainFelletin()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="3"]');
  }
}




class UsersControllerManagedLibrariesIndexSuperAdminTest
  extends UsersControllerManagedLibrariesIndexTest {

  protected function _getLoggedUser(): Class_Users
  {
    $group = $this->fixture(Class_UserGroup::class,
                            ['id' => 28,
                             'libelle' => 'Admin Bib',
                             'rights' => [Class_UserGroup::RIGHT_USER_SIGB_USER_READ]]);

    return $this->_createLoggedUser()
                ->addUserGroup($group)
                ->setRoleLevel(ZendAfi_Acl_AdminControllerRoles::SUPER_ADMIN);
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromGueret() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_gueret"]');
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromAubusson() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_aubusson"]');
  }


  /** @test */
  public function usersTableShouldContainIdentifiantUserFromFelletin() {
    $this->assertXPath('//table[@id="users_table"]/tbody/tr/td[text()="user_from_felletin"]');
  }


  /** @test */
  public function librarySelectorShouldNotContainGueret()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="1"]');
  }


  /** @test */
  public function librarySelectorShouldContainAubusson()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="2"]');
  }


  /** @test */
  public function librarySelectorShouldContainFelletin()
  {
    $this->assertXPath('//select[@name="search_id_site"]/option[@value="3"]');
  }
}