All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.opencms.file.TestDeletion Maven / Gradle / Ivy

Go to download

OpenCms is an enterprise-ready, easy to use website content management system based on Java and XML technology. Offering a complete set of features, OpenCms helps content managers worldwide to create and maintain beautiful websites fast and efficiently.

There is a newer version: 18.0
Show newest version
/*
 * This library is part of OpenCms -
 * the Open Source Content Management System
 *
 * Copyright (c) Alkacon Software GmbH & Co. KG (http://www.alkacon.com)
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.
 *
 * For further information about Alkacon Software GmbH & Co. KG, please see the
 * company website: http://www.alkacon.com
 *
 * For further information about OpenCms, please see the
 * project website: http://www.opencms.org
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

package org.opencms.file;

import org.opencms.db.CmsResourceState;
import org.opencms.file.types.CmsResourceTypeFolder;
import org.opencms.file.types.CmsResourceTypePlain;
import org.opencms.lock.CmsLockType;
import org.opencms.main.OpenCms;
import org.opencms.security.CmsAccessControlEntry;
import org.opencms.security.CmsPermissionViolationException;
import org.opencms.security.CmsRole;
import org.opencms.security.I_CmsPrincipal;
import org.opencms.test.OpenCmsTestCase;
import org.opencms.test.OpenCmsTestProperties;

import java.util.Iterator;
import java.util.List;

import junit.extensions.TestSetup;
import junit.framework.Test;
import junit.framework.TestSuite;

/**
 * Unit tests for VFS permissions.

*/ public class TestDeletion extends OpenCmsTestCase { /** * Default JUnit constructor.

* * @param arg0 JUnit parameters */ public TestDeletion(String arg0) { super(arg0); } /** * Test suite for this test class.

* * @return the test suite */ public static Test suite() { OpenCmsTestProperties.initialize(org.opencms.test.AllTests.TEST_PROPERTIES_PATH); TestSuite suite = new TestSuite(); suite.setName(TestDeletion.class.getName()); suite.addTest(new TestDeletion("testGroupDeletion")); suite.addTest(new TestDeletion("testDeleteFolderAfterMove")); suite.addTest(new TestDeletion("testDeleteFolderAfterMoveWithLock")); suite.addTest(new TestDeletion("testDeleteFolderAfterDeleteWithLock")); suite.addTest(new TestDeletion("testAdvancedGroupDeletion")); suite.addTest(new TestDeletion("testUserDeletion")); suite.addTest(new TestDeletion("testDeleteFolderWithUnvisibleResources")); suite.addTest(new TestDeletion("testDeleteFolderWithLockedSiblings")); suite.addTest(new TestDeletion("testDeleteFolderWithLockedResources")); suite.addTest(new TestDeletion("testDeleteWithoutWritePermissions")); TestSetup wrapper = new TestSetup(suite) { @Override protected void setUp() { setupOpenCms("simpletest", "/"); } @Override protected void tearDown() { removeOpenCms(); } }; return wrapper; } /** * Tests an advanced group deletion.

* * @throws Throwable if something goes wrong */ public void testAdvancedGroupDeletion() throws Throwable { CmsObject cms = getCmsObject(); echo("Testing advanced group deletion"); // create test group cms.createGroup("Testgroup", "A test group", 0, null); CmsGroup testGroup = cms.readGroup("Testgroup"); // set a child cms.setParentGroup(OpenCms.getDefaultUsers().getGroupUsers(), testGroup.getName()); // create test user cms.createUser("testuser1", "test1", "A test user 1", null); cms.addUserToGroup("testuser1", "Testgroup"); CmsUser testUser1 = cms.readUser("testuser1"); // login in offline project CmsProject offline = cms.readProject("Offline"); cms.loginUser("Admin", "admin"); cms.getRequestContext().setCurrentProject(offline); // change permission of a resource String resName = "/folder1/subfolder11/subsubfolder111/text.txt"; cms.lockResource(resName); cms.chacc(resName, I_CmsPrincipal.PRINCIPAL_USER, testUser1.getName(), "+r+w+v+i"); cms.chacc(resName, I_CmsPrincipal.PRINCIPAL_GROUP, testGroup.getName(), "+r+v+i"); cms.unlockResource(resName); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); // create a 2nd test group cms.createGroup("testgroup2", "A test group 2", 0, null); CmsGroup testGroup2 = cms.readGroup("testgroup2"); // remember group data List children = cms.getChildren(testGroup.getName(), false); List users = cms.getUsersOfGroup(testGroup.getName()); // delete the test group cms.deleteGroup(testGroup.getId(), testGroup2.getId()); // check ace for the resource boolean found = false; Iterator it = cms.getAccessControlEntries(resName, false).iterator(); while (it.hasNext()) { CmsAccessControlEntry ace = (CmsAccessControlEntry)it.next(); if (ace.getPrincipal().equals(testGroup2.getId())) { CmsAccessControlEntry newAce = new CmsAccessControlEntry( cms.readResource(resName).getResourceId(), testGroup2.getId(), "+r+v+i"); newAce.setFlags(CmsAccessControlEntry.ACCESS_FLAGS_GROUP); assertTrue(newAce.equals(ace)); found = true; } } assertTrue(found); // check group data assertEquals(children, cms.getChildren(testGroup2.getName(), false)); assertEquals(users, cms.getUsersOfGroup(testGroup2.getName())); // restore the previous state cms.deleteUser(testUser1.getId()); cms.setParentGroup(OpenCms.getDefaultUsers().getGroupUsers(), null); cms.deleteGroup(testGroup2.getName()); } /** * Tests to delete a folder after deleting a subresource with lock.

* * @throws Exception if the test fails */ public void testDeleteFolderAfterDeleteWithLock() throws Exception { CmsObject cms = getCmsObject(); echo("Testing to delete a folder after deleting a subresource with lock"); CmsResource folder = cms.createResource("breakFolder", CmsResourceTypeFolder.getStaticTypeId()); CmsResource file1 = cms.createResource( "breakFolder/file1.txt", CmsResourceTypePlain.getStaticTypeId(), "test1".getBytes(), null); cms.createResource("breakFolder/file2.txt", CmsResourceTypePlain.getStaticTypeId(), "test2".getBytes(), null); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); cms.lockResource(cms.getSitePath(file1)); cms.deleteResource(cms.getSitePath(file1), CmsResource.DELETE_PRESERVE_SIBLINGS); OpenCms.getRoleManager().addUserToRole(cms, CmsRole.PROJECT_MANAGER, "test2"); cms.loginUser("test2", "test2"); cms.getRequestContext().setCurrentProject(cms.readProject("Offline")); cms.lockResource(cms.getSitePath(folder)); cms.deleteResource(cms.getSitePath(folder), CmsResource.DELETE_PRESERVE_SIBLINGS); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); } /** * Tests to delete a folder after moving a subresource.

* * @throws Exception if the test fails */ public void testDeleteFolderAfterMove() throws Exception { CmsObject cms = getCmsObject(); echo("Testing to delete a folder after moving a subresource"); CmsResource folder = cms.createResource("breakFolder", CmsResourceTypeFolder.getStaticTypeId()); CmsResource file1 = cms.createResource( "breakFolder/file1.txt", CmsResourceTypePlain.getStaticTypeId(), "test1".getBytes(), null); cms.createResource("breakFolder/file2.txt", CmsResourceTypePlain.getStaticTypeId(), "test2".getBytes(), null); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); cms.lockResource(cms.getSitePath(file1)); cms.moveResource(cms.getSitePath(file1), "folder1/movedFile1.txt"); cms.lockResource(cms.getSitePath(folder)); cms.deleteResource(cms.getSitePath(folder), CmsResource.DELETE_PRESERVE_SIBLINGS); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); } /** * Tests to delete a folder after moving a subresource with lock.

* * @throws Exception if the test fails */ public void testDeleteFolderAfterMoveWithLock() throws Exception { CmsObject cms = getCmsObject(); echo("Testing to delete a folder after moving a subresource with lock"); CmsResource folder = cms.createResource("breakFolder", CmsResourceTypeFolder.getStaticTypeId()); CmsResource file1 = cms.createResource( "breakFolder/file1.txt", CmsResourceTypePlain.getStaticTypeId(), "test1".getBytes(), null); cms.createResource("breakFolder/file2.txt", CmsResourceTypePlain.getStaticTypeId(), "test2".getBytes(), null); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); cms.lockResource(cms.getSitePath(file1)); cms.moveResource(cms.getSitePath(file1), "folder1/movedFile2.txt"); OpenCms.getRoleManager().addUserToRole(cms, CmsRole.PROJECT_MANAGER, "test2"); cms.loginUser("test2", "test2"); cms.getRequestContext().setCurrentProject(cms.readProject("Offline")); cms.lockResource(cms.getSitePath(folder)); cms.deleteResource(cms.getSitePath(folder), CmsResource.DELETE_PRESERVE_SIBLINGS); // publish all test2 resources OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); // publish all remaining resources cms = getCmsObject(); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); } /** * Tests to delete a folder structure with (from other user) locked resources inside.

* * @throws Exception if the test fails */ public void testDeleteFolderWithLockedResources() throws Exception { CmsObject cms = getCmsObject(); echo("Testing to delete a folder structure with (from other user) locked resources inside"); String folder = "/mytestfolder3"; String file = "/index.html"; // create folder cms.createResource(folder, CmsResourceTypeFolder.RESOURCE_TYPE_ID); cms.unlockResource(folder); // switch user cms.loginUser("test1", "test1"); cms.getRequestContext().setCurrentProject(cms.readProject("Offline")); // copy resource cms.copyResource(file, folder + file, CmsResource.COPY_AS_SIBLING); assertLock(cms, file, CmsLockType.EXCLUSIVE); assertLock(cms, folder + file, CmsLockType.SHARED_EXCLUSIVE); cms.changeLock(folder + file); assertLock(cms, file, CmsLockType.SHARED_EXCLUSIVE); assertLock(cms, folder + file, CmsLockType.EXCLUSIVE); // switch back CmsUser user = cms.getRequestContext().getCurrentUser(); cms = getCmsObject(); assertLock(cms, file, CmsLockType.SHARED_EXCLUSIVE, user); assertLock(cms, folder + file, CmsLockType.EXCLUSIVE, user); // delete the folder cms.lockResource(folder); assertLock(cms, folder + file, CmsLockType.INHERITED); assertLock(cms, file, CmsLockType.UNLOCKED); cms.deleteResource(folder, CmsResource.DELETE_PRESERVE_SIBLINGS); } /** * Tests to delete a folder structure with (from other user) locked siblings inside.

* * @throws Exception if the test fails */ public void testDeleteFolderWithLockedSiblings() throws Exception { CmsObject cms = getCmsObject(); echo("Testing to delete a folder structure with (from other user) locked siblings inside"); String folder = "/mytestfolder2"; String file = "/index.html"; // create folder cms.createResource(folder, CmsResourceTypeFolder.RESOURCE_TYPE_ID); cms.unlockResource(folder); // switch user cms.loginUser("test1", "test1"); cms.getRequestContext().setCurrentProject(cms.readProject("Offline")); // copy resource cms.copyResource(file, folder + file, CmsResource.COPY_AS_SIBLING); cms.unlockResource(folder + file); // lock the sibling cms.lockResource(file); // switch back CmsUser user = cms.getRequestContext().getCurrentUser(); cms = getCmsObject(); int sibCount = cms.readResource(file).getSiblingCount(); assertLock(cms, folder + file, CmsLockType.SHARED_EXCLUSIVE, user); // delete the folder cms.lockResource(folder); assertLock(cms, folder + file, CmsLockType.SHARED_INHERITED, user); cms.deleteResource(folder, CmsResource.DELETE_PRESERVE_SIBLINGS); assertSiblingCount(cms, file, sibCount - 1); } /** * Tests to delete a folder structure with invisible resources inside.

* * @throws Exception if the test fails */ public void testDeleteFolderWithUnvisibleResources() throws Exception { CmsObject cms = getCmsObject(); echo("Testing to delete a folder structure with invisible resources inside"); // Creating paths String folder = "/mytestfolder/"; String file = "index.html"; // create structure cms.createResource(folder, CmsResourceTypeFolder.RESOURCE_TYPE_ID); cms.createResource(folder + file, CmsResourceTypePlain.getStaticTypeId()); // change permissions cms.chacc(folder + file, I_CmsPrincipal.PRINCIPAL_USER, "test2", "-r+v+i"); // unlock resources cms.unlockResource(folder); // publish OpenCms.getPublishManager().publishResource(cms, folder); OpenCms.getPublishManager().waitWhileRunning(); // lock the whole folder as test2 cms.loginUser("test2", "test2"); cms.getRequestContext().setCurrentProject(cms.readProject("Offline")); cms.lockResource(folder); // delete the folder cms.deleteResource(folder, CmsResource.DELETE_PRESERVE_SIBLINGS); cms.loginUser("Admin", "admin"); cms.getRequestContext().setCurrentProject(cms.readProject("Offline")); assertEquals(cms.readResource(folder + file, CmsResourceFilter.ALL).getState(), CmsResource.STATE_DELETED); } /** * Tests to delete a folder with no write permission on a subresource.

* * @throws Exception if the test fails */ public void testDeleteWithoutWritePermissions() throws Exception { CmsObject cms = getCmsObject(); echo("Testing to delete a folder with no write permission on a subresource"); // Creating paths String folder = "/folder1/"; String test = "subfolder11/"; List list = cms.readResources(folder, CmsResourceFilter.ALL, true); int files = list.size(); // remove read permission for test2 cms.lockResource(folder); cms.chacc(folder, I_CmsPrincipal.PRINCIPAL_USER, "test2", "+r+w+v+i"); cms.chacc(folder + test, I_CmsPrincipal.PRINCIPAL_USER, "test2", "+r-w+v+i"); cms.unlockResource(folder); // login as test2 cms.loginUser("test2", "test2"); cms.getRequestContext().setCurrentProject(cms.readProject("Offline")); cms.lockResource(folder); // try delete the folder try { cms.deleteResource(folder, CmsResource.DELETE_PRESERVE_SIBLINGS); fail("to delete a resource with no write permission on a subresource should fail"); } catch (CmsPermissionViolationException e) { // ok } // login as Admin for testing cms.loginUser("Admin", "admin"); cms.getRequestContext().setCurrentProject(cms.readProject("Offline")); assertEquals( "there missing files after deletion try", files, cms.readResources(folder, CmsResourceFilter.ALL, true).size()); } /** * Tests user group deletion.

* * @throws Throwable if something goes wrong */ public void testGroupDeletion() throws Throwable { CmsObject cms = getCmsObject(); echo("Testing user group deletion"); String groupname = "deleteGroup"; List expected = OpenCms.getOrgUnitManager().getGroups(cms, "", true); // create group cms.createGroup(groupname, "deleteMe", I_CmsPrincipal.FLAG_ENABLED, "Users"); // now delete the group again cms.deleteGroup(groupname); List actual = OpenCms.getOrgUnitManager().getGroups(cms, "", true); assertEquals(expected, actual); } /** * Tests user deletion.

* * @throws Throwable if something goes wrong */ public void testUserDeletion() throws Throwable { CmsObject cms = getCmsObject(); echo("Testing user deletion"); cms.createGroup("Testgroup", "A test group", 0, null); CmsGroup testGroup = cms.readGroup("Testgroup"); cms.createUser("testuser1", "test1", "A test user 1", null); cms.addUserToGroup("testuser1", "Testgroup"); OpenCms.getRoleManager().addUserToRole(cms, CmsRole.ELEMENT_AUTHOR, "testuser1"); CmsUser testUser1 = cms.readUser("testuser1"); cms.lockResource("/"); cms.chacc("/", I_CmsPrincipal.PRINCIPAL_USER, testUser1.getName(), "+r+w+v+i+c"); cms.unlockResource("/"); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); cms.loginUser(testUser1.getName(), "test1"); CmsProject offline = cms.readProject("Offline"); cms.getRequestContext().setCurrentProject(offline); String resName = "/myfile.txt"; cms.createResource(resName, CmsResourceTypePlain.getStaticTypeId(), "my content".getBytes(), null); cms.lockResource(resName); cms.chacc(resName, I_CmsPrincipal.PRINCIPAL_USER, testUser1.getName(), "+r+w+v+i"); cms.chacc(resName, I_CmsPrincipal.PRINCIPAL_GROUP, testGroup.getName(), "+r+v+i"); cms.unlockResource(resName); cms.loginUser("Admin", "admin"); cms.getRequestContext().setCurrentProject(offline); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); String resName2 = "/folder1/subfolder11/subsubfolder111/text.txt"; cms.lockResource(resName2); cms.chacc(resName2, I_CmsPrincipal.PRINCIPAL_USER, testUser1.getName(), "+r+w+v+i"); cms.chacc(resName2, I_CmsPrincipal.PRINCIPAL_GROUP, testGroup.getName(), "+r+v+i"); cms.unlockResource(resName2); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); cms.createUser("testuser2", "test2", "A test user 2", null); cms.addUserToGroup("testuser2", "Testgroup"); CmsUser testUser2 = cms.readUser("testuser2"); CmsResourceState state = cms.readResource(resName).getState(); cms.deleteUser(testUser1.getId(), testUser2.getId()); // check attributes CmsResource res = cms.readResource(resName); assertEquals(res.getUserCreated(), testUser2.getId()); assertEquals(res.getUserLastModified(), testUser2.getId()); assertEquals(res.getState(), state); // check ace for first resource boolean found = false; Iterator it = cms.getAccessControlEntries(resName, false).iterator(); while (it.hasNext()) { CmsAccessControlEntry ace = (CmsAccessControlEntry)it.next(); if (ace.getPrincipal().equals(testUser2.getId())) { CmsAccessControlEntry newAce = new CmsAccessControlEntry( cms.readResource(resName).getResourceId(), testUser2.getId(), "+r+w+v+i"); newAce.setFlags(CmsAccessControlEntry.ACCESS_FLAGS_USER); assertTrue(newAce.equals(ace)); found = true; } } assertTrue(found); // check ace for second resource found = false; it = cms.getAccessControlEntries(resName2, false).iterator(); while (it.hasNext()) { CmsAccessControlEntry ace = (CmsAccessControlEntry)it.next(); if (ace.getPrincipal().equals(testUser2.getId())) { CmsAccessControlEntry newAce = new CmsAccessControlEntry( cms.readResource(resName2).getResourceId(), testUser2.getId(), "+r+w+v+i"); newAce.setFlags(CmsAccessControlEntry.ACCESS_FLAGS_USER); assertTrue(newAce.equals(ace)); found = true; } } assertTrue(found); // restore the previous state cms.lockResource(resName); cms.deleteResource(resName, CmsResource.DELETE_REMOVE_SIBLINGS); cms.unlockResource(resName); OpenCms.getPublishManager().publishProject(cms); OpenCms.getPublishManager().waitWhileRunning(); cms.deleteUser(testUser2.getId()); cms.deleteGroup(testGroup.getName()); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy