mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-15 15:02:20 +00:00 
			
		
		
		
	109499: Merged V4.2-BUG-FIX (4.2.6) to 5.0.N (5.0.3)
      109403: Merged DEV to V4.2-BUG-FIX (4.2.6)
         109221 : MNT-12819 : InvalidNodeRefException - Node does not exist, if you call RuleService.removeAllRules(Node) for a folder which has INBOUND rules and OUTBOUND rules.
            - Added a check for existence of rule
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@109581 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
	
		
			
				
	
	
		
			1518 lines
		
	
	
		
			68 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			1518 lines
		
	
	
		
			68 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2014 Alfresco Software Limited.
 | |
|  *
 | |
|  * This file is part of Alfresco
 | |
|  *
 | |
|  * Alfresco 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 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * Alfresco 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.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public License
 | |
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| package org.alfresco.repo.rule;
 | |
| 
 | |
| import java.io.File;
 | |
| import java.io.Serializable;
 | |
| import java.util.ArrayList;
 | |
| import java.util.Collections;
 | |
| import java.util.HashMap;
 | |
| import java.util.HashSet;
 | |
| import java.util.List;
 | |
| import java.util.Map;
 | |
| 
 | |
| import org.alfresco.model.ContentModel;
 | |
| import org.alfresco.repo.action.evaluator.ComparePropertyValueEvaluator;
 | |
| import org.alfresco.repo.action.executer.AddFeaturesActionExecuter;
 | |
| import org.alfresco.repo.action.executer.CopyActionExecuter;
 | |
| import org.alfresco.repo.action.executer.ImageTransformActionExecuter;
 | |
| import org.alfresco.repo.action.executer.MoveActionExecuter;
 | |
| import org.alfresco.repo.content.MimetypeMap;
 | |
| import org.alfresco.repo.content.transform.AbstractContentTransformerTest;
 | |
| import org.alfresco.repo.security.authentication.AuthenticationUtil;
 | |
| import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
 | |
| import org.alfresco.service.cmr.action.Action;
 | |
| import org.alfresco.service.cmr.action.ActionCondition;
 | |
| import org.alfresco.service.cmr.action.CompositeAction;
 | |
| import org.alfresco.service.cmr.model.FileExistsException;
 | |
| import org.alfresco.service.cmr.model.FileFolderService;
 | |
| import org.alfresco.service.cmr.model.FileInfo;
 | |
| import org.alfresco.service.cmr.repository.ChildAssociationRef;
 | |
| import org.alfresco.service.cmr.repository.ContentWriter;
 | |
| import org.alfresco.service.cmr.repository.CyclicChildRelationshipException;
 | |
| import org.alfresco.service.cmr.repository.InvalidNodeRefException;
 | |
| import org.alfresco.service.cmr.repository.NodeRef;
 | |
| import org.alfresco.service.cmr.repository.StoreRef;
 | |
| import org.alfresco.service.cmr.rule.Rule;
 | |
| import org.alfresco.service.cmr.rule.RuleType;
 | |
| import org.alfresco.service.cmr.security.MutableAuthenticationService;
 | |
| import org.alfresco.service.cmr.security.PermissionService;
 | |
| import org.alfresco.service.namespace.NamespaceService;
 | |
| import org.alfresco.service.cmr.search.SearchService;
 | |
| import org.alfresco.service.namespace.QName;
 | |
| import org.alfresco.service.namespace.RegexQNamePattern;
 | |
| import org.alfresco.test_category.BaseSpringTestsCategory;
 | |
| import org.alfresco.test_category.OwnJVMTestsCategory;
 | |
| import org.alfresco.util.GUID;
 | |
| import org.junit.experimental.categories.Category;
 | |
| import org.junit.Test;
 | |
| 
 | |
| import javax.transaction.UserTransaction;
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Rule service implementation test
 | |
|  * 
 | |
|  * @author Roy Wetherall
 | |
|  */
 | |
| @Category(BaseSpringTestsCategory.class)
 | |
| public class RuleServiceImplTest extends BaseRuleTest
 | |
| {    
 | |
|     private String ASSOC_NAME_RULES_PREFIX = "rules";
 | |
|     private RegexQNamePattern ASSOC_NAME_RULES_REGEX = new RegexQNamePattern(RuleModel.RULE_MODEL_URI, "^" + ASSOC_NAME_RULES_PREFIX + ".*");
 | |
|     
 | |
|     MutableAuthenticationService authenticationService;
 | |
|     PermissionService permissionService;  
 | |
|     SearchService searchService;
 | |
|     NamespaceService namespaceService;
 | |
|     FileFolderService fileFolderService;
 | |
|     
 | |
|     @Override
 | |
|     protected void onSetUpInTransaction() throws Exception 
 | |
|     {
 | |
|         super.onSetUpInTransaction();        
 | |
|         this.permissionService = (PermissionService)this.applicationContext.getBean("permissionService");
 | |
| 		this.authenticationService = (MutableAuthenticationService)this.applicationContext.getBean("authenticationService");
 | |
|         this.searchService = (SearchService) applicationContext.getBean("SearchService");
 | |
|         this.namespaceService = (NamespaceService) applicationContext.getBean("NamespaceService");
 | |
|         this.fileFolderService = (FileFolderService) applicationContext.getBean("FileFolderService");
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Test get rule type
 | |
|      */
 | |
|     public void testGetRuleType()
 | |
|     {
 | |
|         List<RuleType> ruleTypes = this.ruleService.getRuleTypes();
 | |
|         assertNotNull(ruleTypes);  
 | |
|         
 | |
|         // Visual check to make sure that the display labels are being returned correctly
 | |
|         for (RuleType type : ruleTypes)
 | |
|         {
 | |
|             System.out.println(type.getDisplayLabel());
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Test addRule
 | |
|      *
 | |
|      */
 | |
|     public void testAddRule()
 | |
|     {
 | |
|         Rule newRule = createTestRule();
 | |
|         
 | |
|         // The node it's going on won't have the aspect yet
 | |
|         assertEquals(false, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|         
 | |
|         // Attach the rule to the node
 | |
|         this.ruleService.saveRule(this.nodeRef, newRule);
 | |
|         assertNotNull(newRule.getNodeRef());
 | |
|         
 | |
|         // Check the owning node reference
 | |
|         assertNotNull(this.ruleService.getOwningNodeRef(newRule));
 | |
|         assertEquals(this.nodeRef, this.ruleService.getOwningNodeRef(newRule));
 | |
|         
 | |
|         // Check the aspect was applied to the owning node
 | |
|         assertEquals(true, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|         
 | |
|         // Check we can retrieve it
 | |
|         Rule savedRule = this.ruleService.getRule(newRule.getNodeRef());
 | |
|         assertNotNull(savedRule);
 | |
|         assertFalse(savedRule.isAppliedToChildren());
 | |
|         
 | |
|         savedRule.applyToChildren(true);
 | |
|         this.ruleService.saveRule(this.nodeRef, savedRule);
 | |
|         
 | |
|         Rule savedRule2 = this.ruleService.getRule(savedRule.getNodeRef());
 | |
|         assertNotNull(savedRule2);
 | |
|         assertTrue(savedRule2.isAppliedToChildren());
 | |
|     }
 | |
|     
 | |
|     public void testRemoveRule()
 | |
|     {
 | |
|         this.ruleService.removeAllRules(this.nodeRef);
 | |
|         List<Rule> rules = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules);
 | |
|         assertEquals(0, rules.size());
 | |
|         assertEquals(false, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|         
 | |
|         
 | |
|         // Add a rule + check
 | |
|         Rule newRule = createTestRule(); //this.ruleService.createRule(ruleType.getName());        
 | |
|         this.ruleService.saveRule(this.nodeRef, newRule);
 | |
|         
 | |
|         rules = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules);
 | |
|         assertEquals(1, rules.size());
 | |
|         assertEquals(true, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|         
 | |
|         
 | |
|         // Remove it
 | |
|         this.ruleService.removeRule(nodeRef, newRule);
 | |
|         
 | |
|         // And check
 | |
|         rules = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules);
 | |
|         assertEquals(0, rules.size());
 | |
|         assertEquals(false, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|         
 | |
|         
 | |
|         // Add two rules
 | |
|         Rule newRule2 = createTestRule(); //this.ruleService.createRule(ruleType.getName());
 | |
|         this.ruleService.saveRule(this.nodeRef, newRule2); 
 | |
|         Rule newRule3 = createTestRule(); //this.ruleService.createRule(ruleType.getName());
 | |
|         this.ruleService.saveRule(this.nodeRef, newRule3); 
 | |
|         
 | |
|         rules = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules);
 | |
|         assertEquals(2, rules.size());
 | |
|         assertEquals(true, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|         
 | |
|         
 | |
|         // Remove each in turn
 | |
|         this.ruleService.removeRule(nodeRef, newRule3);
 | |
|         
 | |
|         rules = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules);
 | |
|         assertEquals(1, rules.size());
 | |
|         assertEquals(true, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|         
 | |
|         
 | |
|         this.ruleService.removeRule(nodeRef, newRule2);
 | |
|         
 | |
|         rules = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules);
 | |
|         assertEquals(0, rules.size());
 | |
|         assertEquals(false, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|     }
 | |
|     
 | |
|     public void testRemoveAllRules()
 | |
|     {
 | |
|         this.ruleService.removeAllRules(this.nodeRef);
 | |
|         List<Rule> rules1 = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules1);
 | |
|         assertEquals(0, rules1.size());
 | |
|         
 | |
|         Rule newRule = createTestRule(); //this.ruleService.createRule(ruleType.getName());        
 | |
|         this.ruleService.saveRule(this.nodeRef, newRule); 
 | |
|         Rule newRule2 = createTestRule(); //this.ruleService.createRule(ruleType.getName());
 | |
|         this.ruleService.saveRule(this.nodeRef, newRule2); 
 | |
|         
 | |
|         // Check the rules are showing up as expected
 | |
|         List<Rule> rules2 = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules2);
 | |
|         assertEquals(2, rules2.size());
 | |
|         assertEquals(true, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
| 
 | |
|         // Remove all the rules from the node
 | |
|         this.ruleService.removeAllRules(this.nodeRef);
 | |
|         
 | |
|         // Check they've gone
 | |
|         List<Rule> rules3 = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules3);
 | |
|         assertEquals(0, rules3.size());        
 | |
|         
 | |
|         // Removing the rules will have removed the aspect from the node
 | |
|         assertEquals(false, nodeService.hasAspect(nodeRef, RuleModel.ASPECT_RULES));
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Test get rules
 | |
|      */
 | |
|     public void testGetRules()
 | |
|     {
 | |
|         // Check that there are no rules associationed with the node
 | |
|         List<Rule> noRules = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(noRules);
 | |
|         assertEquals(0, noRules.size());
 | |
|         
 | |
|         // Check that we still get nothing back after the details of the node
 | |
|         // have been cached in the rule store
 | |
|         List<Rule> noRulesAfterCache = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(noRulesAfterCache);
 | |
|         assertEquals(0, noRulesAfterCache.size());
 | |
|         
 | |
|         // Add a rule to the node
 | |
|         testAddRule();
 | |
|         
 | |
|         // Get the rule from the rule service
 | |
|         List<Rule> rules = this.ruleService.getRules(this.nodeRef);
 | |
|         assertNotNull(rules);
 | |
|         assertEquals(1, rules.size());
 | |
|         
 | |
|         // Check the details of the rule
 | |
|         Rule rule = rules.get(0);
 | |
|         assertEquals("title", rule.getTitle());
 | |
|         assertEquals("description", rule.getDescription());
 | |
|         assertNotNull(this.nodeService.getProperty(rule.getNodeRef(), ContentModel.PROP_CREATED));
 | |
|         assertNotNull(this.nodeService.getProperty(rule.getNodeRef(), ContentModel.PROP_CREATOR));
 | |
|         
 | |
|         // Check that the condition action have been retireved correctly
 | |
|         Action action = rule.getAction();
 | |
|         assertNotNull(action);
 | |
|         List<ActionCondition> conditions = action.getActionConditions();
 | |
|         assertNotNull(conditions);
 | |
|         assertEquals(1, conditions.size());                
 | |
|     }
 | |
|     
 | |
|     /** Ensure the rules are retrieved in the correct order **/
 | |
|     public void testGetRulesOrder()
 | |
|     {
 | |
|         for (int index = 0; index < 10; index++)
 | |
|         {         
 | |
|             Rule newRule = createTestRule(true, Integer.toString(index));        
 | |
|             this.ruleService.saveRule(this.nodeRef, newRule);
 | |
|         }
 | |
|         
 | |
|         // Check that they are all returned in the correct order
 | |
|         List<Rule> rules = this.ruleService.getRules(this.nodeRef);
 | |
|         int index = 0;
 | |
|         for (Rule rule : rules)
 | |
|         {
 | |
|             assertEquals(Integer.toString(index), rule.getTitle());
 | |
|             index++;
 | |
|         }
 | |
|         
 | |
|         // Create a child node
 | |
|         NodeRef level1 = createNewNode(this.nodeRef);
 | |
|         for (int index2 = 10; index2 < 20; index2++)
 | |
|         {         
 | |
|             Rule newRule = createTestRule(true, Integer.toString(index2));        
 | |
|             this.ruleService.saveRule(level1, newRule);
 | |
|         }
 | |
|         
 | |
|         // Check that they are all returned in the correct order
 | |
|         List<Rule> rules2 = this.ruleService.getRules(level1);
 | |
|         int index2 = 0;
 | |
|         for (Rule rule : rules2)
 | |
|         {
 | |
|             assertEquals(Integer.toString(index2), rule.getTitle());
 | |
|             index2++;
 | |
|         }
 | |
|         
 | |
|         // Create a child node
 | |
|         NodeRef level2 = createNewNode(level1);
 | |
|         for (int index3 = 20; index3 < 30; index3++)
 | |
|         {         
 | |
|             Rule newRule = createTestRule(true, Integer.toString(index3));        
 | |
|             this.ruleService.saveRule(level2, newRule);
 | |
|         }
 | |
|         
 | |
|         // Check that they are all returned in the correct order
 | |
|         List<Rule> rules3 = this.ruleService.getRules(level2);
 | |
|         int index3 = 0;
 | |
|         for (Rule rule : rules3)
 | |
|         {
 | |
|             //System.out.println(rule.getTitle());
 | |
|             assertEquals(Integer.toString(index3), rule.getTitle());
 | |
|             index3++;
 | |
|         }
 | |
|         
 | |
|         // Update a couple of the rules
 | |
|         Rule rule1 = rules3.get(2);
 | |
|         rule1.setDescription("This has been changed");
 | |
|         this.ruleService.saveRule(this.nodeRef, rule1);
 | |
|         Rule rule2 = rules3.get(12);
 | |
|         rule2.setDescription("This has been changed");
 | |
|         this.ruleService.saveRule(level1, rule2);
 | |
|         Rule rule3 = rules3.get(22);
 | |
|         rule3.setDescription("This has been changed");
 | |
|         this.ruleService.saveRule(level2, rule3);
 | |
|         
 | |
|         // Check that they are all returned in the correct order
 | |
|         List<Rule> rules4 = this.ruleService.getRules(level2);
 | |
|         int index4 = 0;
 | |
|         for (Rule rule : rules4)
 | |
|         {
 | |
|             assertEquals(Integer.toString(index4), rule.getTitle());
 | |
|             index4++;
 | |
|         }
 | |
|         
 | |
|         // Lets have a look at the assoc index and see if the are set correctly
 | |
|         NodeRef ruleFolder = ((RuntimeRuleService)ruleService).getSavedRuleFolderAssoc(nodeRef).getChildRef();
 | |
|         if (ruleFolder != null)
 | |
|         {
 | |
|             // Get the rules for this node
 | |
|             List<ChildAssociationRef> ruleChildAssocRefs = nodeService.getChildAssocs(ruleFolder, RegexQNamePattern.MATCH_ALL, ASSOC_NAME_RULES_REGEX);
 | |
|             System.out.println("Association Nth Sibling values ...");
 | |
|             for (ChildAssociationRef ruleChildAssocRef : ruleChildAssocRefs)
 | |
|             {
 | |
|                 System.out.println(" - Assoc index = " + ruleChildAssocRef.getNthSibling() + ", name = " + 
 | |
|                                                          nodeService.getProperty(ruleChildAssocRef.getChildRef(), ContentModel.PROP_TITLE));
 | |
|             }
 | |
|         }
 | |
|         
 | |
|         rules = ruleService.getRules(nodeRef);
 | |
|         
 | |
|         Rule rule = rules.get(3);
 | |
|         ruleService.setRulePosition(nodeRef, rule, 1);
 | |
|         
 | |
|         if (ruleFolder != null)
 | |
|         {
 | |
|             // Get the rules for this node
 | |
|             List<ChildAssociationRef> ruleChildAssocRefs = nodeService.getChildAssocs(ruleFolder, RegexQNamePattern.MATCH_ALL, ASSOC_NAME_RULES_REGEX);
 | |
|             System.out.println("After change of index ...");
 | |
|             for (ChildAssociationRef ruleChildAssocRef : ruleChildAssocRefs)
 | |
|             {
 | |
|                 System.out.println(" - Assoc index = " + ruleChildAssocRef.getNthSibling() + ", name = " + 
 | |
|                         nodeService.getProperty(ruleChildAssocRef.getChildRef(), ContentModel.PROP_TITLE));
 | |
|             }
 | |
|         }
 | |
|         
 | |
|         List<NodeRef> ruleNodeRefs = new ArrayList<NodeRef>(rules.size());
 | |
|         for (Rule tempRule : rules)
 | |
|         {
 | |
|             ruleNodeRefs.add(0, tempRule.getNodeRef());            
 | |
|         }        
 | |
|         
 | |
|         Action action = actionService.createAction(ReorderRules.NAME);
 | |
|         action.setParameterValue(ReorderRules.PARAM_RULES, (Serializable)ruleNodeRefs);
 | |
|         
 | |
|         actionService.executeAction(action, nodeRef);
 | |
|         
 | |
|         List<ChildAssociationRef> ruleChildAssocRefs = nodeService.getChildAssocs(ruleFolder, RegexQNamePattern.MATCH_ALL, ASSOC_NAME_RULES_REGEX);
 | |
|         System.out.println("After execution of action ...");
 | |
|         for (ChildAssociationRef ruleChildAssocRef : ruleChildAssocRefs)
 | |
|         {
 | |
|             System.out.println(" - Assoc index = " + ruleChildAssocRef.getNthSibling() + ", name = " + 
 | |
|                     nodeService.getProperty(ruleChildAssocRef.getChildRef(), ContentModel.PROP_TITLE));
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     public void testIgnoreInheritedRules()
 | |
|     {
 | |
|         // Create the nodes and rules
 | |
|         this.ruleService.saveRule(this.nodeRef, createTestRule(true, "rule1"));
 | |
|         this.ruleService.saveRule(this.nodeRef, createTestRule(false, "rule2"));
 | |
|         NodeRef nodeRef1 = createNewNode(this.nodeRef);
 | |
|         this.ruleService.saveRule(nodeRef1, createTestRule(true, "rule3"));
 | |
|         this.ruleService.saveRule(nodeRef1, createTestRule(false, "rule4"));
 | |
|         NodeRef nodeRef2 = createNewNode(nodeRef1);
 | |
|         this.ruleService.saveRule(nodeRef2, createTestRule(true, "rule5"));
 | |
|         this.ruleService.saveRule(nodeRef2, createTestRule(false, "rule6"));
 | |
|         
 | |
|         // Apply the ignore aspect    
 | |
|         this.nodeService.addAspect(nodeRef1, RuleModel.ASPECT_IGNORE_INHERITED_RULES, null);
 | |
|         
 | |
|         // Get the rules
 | |
|         List<Rule> rules1 = this.ruleService.getRules(nodeRef2);
 | |
|         assertNotNull(rules1);
 | |
|         assertEquals(3, rules1.size());
 | |
|         assertEquals("rule3", rules1.get(0).getTitle());
 | |
|         assertEquals("rule5", rules1.get(1).getTitle());
 | |
|         assertEquals("rule6", rules1.get(2).getTitle());
 | |
|         
 | |
|         // Apply the ignore aspect
 | |
|         this.nodeService.addAspect(nodeRef2, RuleModel.ASPECT_IGNORE_INHERITED_RULES, null);
 | |
|         
 | |
|         // Get the rules
 | |
|         List<Rule> rules2 = this.ruleService.getRules(nodeRef2);
 | |
|         assertNotNull(rules2);
 | |
|         assertEquals(2, rules2.size());
 | |
|         assertEquals("rule5", rules2.get(0).getTitle());
 | |
|         assertEquals("rule6", rules2.get(1).getTitle());
 | |
|         
 | |
|         // Remove the ignore aspect
 | |
|         this.nodeService.removeAspect(nodeRef1, RuleModel.ASPECT_IGNORE_INHERITED_RULES);
 | |
|         this.nodeService.removeAspect(nodeRef2, RuleModel.ASPECT_IGNORE_INHERITED_RULES);
 | |
|         
 | |
|         // Get the rules
 | |
|         List<Rule> rules3 = this.ruleService.getRules(nodeRef2);
 | |
|         assertNotNull(rules3);
 | |
|         assertEquals(4, rules3.size());
 | |
|         assertEquals("rule1", rules3.get(0).getTitle());
 | |
|         assertEquals("rule3", rules3.get(1).getTitle());
 | |
|         assertEquals("rule5", rules3.get(2).getTitle());
 | |
|         assertEquals("rule6", rules3.get(3).getTitle());        
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Test disabling the rules
 | |
|      */
 | |
|     public void testRulesDisabled()
 | |
|     {
 | |
|         testAddRule();
 | |
|         assertTrue(this.ruleService.rulesEnabled(this.nodeRef));
 | |
|         this.ruleService.disableRules(this.nodeRef);
 | |
|         assertFalse(this.ruleService.rulesEnabled(this.nodeRef));
 | |
|         this.ruleService.enableRules(this.nodeRef);
 | |
|         assertTrue(this.ruleService.rulesEnabled(this.nodeRef));
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Helper method to easily create a new node which can be actionable (or not)
 | |
|      * 
 | |
|      * @param parent        the parent node
 | |
|      */
 | |
|     private NodeRef createNewNode(NodeRef parent)
 | |
|     {
 | |
|         return this.nodeService.createNode(parent,
 | |
|                 ContentModel.ASSOC_CHILDREN,
 | |
|                 QName.createQName("{test}testnode"),
 | |
|                 ContentModel.TYPE_CONTAINER).getChildRef();
 | |
|     }
 | |
|     
 | |
|     public void testRuleServicePermissionsConsumer()
 | |
|     {
 | |
|         this.authenticationService.createAuthentication("conUser", "password".toCharArray());
 | |
|         this.permissionService.setPermission(this.nodeRef, "conUser", PermissionService.CONSUMER, true);
 | |
|         this.permissionService.setInheritParentPermissions(this.nodeRef, true);        
 | |
|         
 | |
|         this.authenticationService.authenticate("conUser", "password".toCharArray());        
 | |
|         Rule rule = createTestRule();
 | |
|         try
 | |
|         {
 | |
|             this.ruleService.saveRule(this.nodeRef, rule);
 | |
|             // Fail
 | |
|             fail("Consumers cannot create rules.");
 | |
|         }
 | |
|         catch (Exception exception)
 | |
|         {
 | |
|             // Ok
 | |
|         }
 | |
| 
 | |
|     }
 | |
|     
 | |
|     public void testRuleServicePermissionsEditor()
 | |
|     {
 | |
|         this.authenticationService.createAuthentication("editorUser", "password".toCharArray());
 | |
|         this.permissionService.setPermission(this.nodeRef, "editorUser", PermissionService.EDITOR, true);
 | |
|         this.permissionService.setInheritParentPermissions(this.nodeRef, true);        
 | |
|         
 | |
|         this.authenticationService.authenticate("editorUser", "password".toCharArray());        
 | |
|         Rule rule = createTestRule();
 | |
|         try
 | |
|         {
 | |
|             this.ruleService.saveRule(this.nodeRef, rule);
 | |
|             // Fail
 | |
|             fail("Editors cannot create rules.");
 | |
|         }
 | |
|         catch (Exception exception)
 | |
|         {
 | |
|             // Ok
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     public void testRuleServicePermissionsCoordinator()
 | |
|     {
 | |
|         this.authenticationService.createAuthentication("coordUser", "password".toCharArray());
 | |
|         this.permissionService.setPermission(this.nodeRef, "coordUser", PermissionService.COORDINATOR, true);
 | |
|         this.permissionService.setInheritParentPermissions(this.nodeRef, true);
 | |
|         
 | |
|     	this.authenticationService.authenticate(AuthenticationUtil.getAdminUserName(), "admin".toCharArray());    	
 | |
|         Rule rule2 = createTestRule();
 | |
|         this.ruleService.saveRule(this.nodeRef, rule2);        
 | |
|         this.authenticationService.clearCurrentSecurityContext();
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Tests the rule inheritance within the store, checking that the cache is reset correctly when 
 | |
|      * rules are added and removed.
 | |
|      */
 | |
|     public void testRuleInheritance()
 | |
|     {
 | |
|         // Create the nodes and rules
 | |
|         
 | |
|         NodeRef rootWithRules = createNewNode(this.rootNodeRef);
 | |
|         Rule rule1 = createTestRule();
 | |
|         this.ruleService.saveRule(rootWithRules, rule1);
 | |
|         Rule rule2 = createTestRule(true);
 | |
|         this.ruleService.saveRule(rootWithRules, rule2);
 | |
|         
 | |
|         NodeRef nonActionableChild = createNewNode(rootWithRules);
 | |
|         
 | |
|         NodeRef childWithRules = createNewNode(nonActionableChild);
 | |
|         Rule rule3 = createTestRule();
 | |
|         this.ruleService.saveRule(childWithRules, rule3);
 | |
|         Rule rule4 = createTestRule(true);
 | |
|         this.ruleService.saveRule(childWithRules, rule4);
 | |
|         
 | |
|         NodeRef rootWithRules2 = createNewNode(this.rootNodeRef);
 | |
|         this.nodeService.addChild(
 | |
|                 rootWithRules2, 
 | |
|                 childWithRules, 
 | |
|                 ContentModel.ASSOC_CHILDREN,
 | |
|                 QName.createQName("{test}testnode"));
 | |
|         Rule rule5 = createTestRule();
 | |
|         this.ruleService.saveRule(rootWithRules2, rule5);
 | |
|         Rule rule6 = createTestRule(true);
 | |
|         this.ruleService.saveRule(rootWithRules2, rule6);
 | |
|                         
 | |
|         // Check that the rules are inherited in the correct way
 | |
|         
 | |
|         List<? extends Rule> allRules = this.ruleService.getRules(childWithRules);
 | |
|         assertNotNull(allRules);
 | |
|         assertEquals(4, allRules.size());
 | |
|         assertTrue(allRules.contains(rule2));
 | |
|         assertTrue(allRules.contains(rule3));
 | |
|         assertTrue(allRules.contains(rule4));
 | |
|         assertTrue(allRules.contains(rule6));
 | |
|         
 | |
|         // Check the owning node ref
 | |
|         int count = 0;
 | |
|         for (Rule rule : allRules)
 | |
|         {
 | |
|             NodeRef owningNodeRef = this.ruleService.getOwningNodeRef(rule);
 | |
|             assertNotNull(owningNodeRef);
 | |
|             if (owningNodeRef.equals(childWithRules) == true)
 | |
|             {
 | |
|                 count++;
 | |
|             }
 | |
|         }
 | |
|         assertEquals(2, count);
 | |
|         
 | |
|         List<? extends Rule> myRules = this.ruleService.getRules(childWithRules, false);
 | |
|         assertNotNull(myRules);
 | |
|         assertEquals(2, myRules.size());
 | |
|         assertTrue(myRules.contains(rule3));
 | |
|         assertTrue(myRules.contains(rule4));
 | |
|         
 | |
|         List<? extends Rule> allRules2 = this.ruleService.getRules(nonActionableChild, true);
 | |
|         assertNotNull(allRules2);
 | |
|         assertEquals(1, allRules2.size());
 | |
|         assertTrue(allRules2.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> myRules2 = this.ruleService.getRules(nonActionableChild, false);
 | |
|         assertNotNull(myRules2);
 | |
|         assertEquals(0, myRules2.size());
 | |
|         
 | |
|         List<? extends Rule> allRules3 = this.ruleService.getRules(rootWithRules, true);
 | |
|         assertNotNull(allRules3);
 | |
|         assertEquals(2, allRules3.size());
 | |
|         assertTrue(allRules3.contains(rule1));
 | |
|         assertTrue(allRules3.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> myRules3 = this.ruleService.getRules(rootWithRules, false);
 | |
|         assertNotNull(myRules3);
 | |
|         assertEquals(2, myRules3.size());
 | |
|         assertTrue(myRules3.contains(rule1));
 | |
|         assertTrue(myRules3.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> allRules4 = this.ruleService.getRules(rootWithRules2, true);
 | |
|         assertNotNull(allRules4);
 | |
|         assertEquals(2, allRules4.size());
 | |
|         assertTrue(allRules4.contains(rule5));
 | |
|         assertTrue(allRules4.contains(rule6));
 | |
|         
 | |
|         List<? extends Rule> myRules4 = this.ruleService.getRules(rootWithRules2, false);
 | |
|         assertNotNull(myRules4);
 | |
|         assertEquals(2, myRules4.size());
 | |
|         assertTrue(myRules4.contains(rule5));
 | |
|         assertTrue(myRules4.contains(rule6));
 | |
|         
 | |
|         // Take the root node and add another rule
 | |
|         
 | |
|         Rule rule7 = createTestRule(true);
 | |
|         this.ruleService.saveRule(rootWithRules, rule7);
 | |
|         
 | |
|         List<? extends Rule> allRules5 = this.ruleService.getRules(childWithRules, true);
 | |
|         assertNotNull(allRules5);
 | |
|         assertEquals(5, allRules5.size());
 | |
|         assertTrue(allRules5.contains(rule2));
 | |
|         assertTrue(allRules5.contains(rule3));
 | |
|         assertTrue(allRules5.contains(rule4));
 | |
|         assertTrue(allRules5.contains(rule6));
 | |
|         assertTrue(allRules5.contains(rule7));
 | |
|         
 | |
|         List<? extends Rule> allRules6 = this.ruleService.getRules(nonActionableChild, true);
 | |
|         assertNotNull(allRules6);
 | |
|         assertEquals(2, allRules6.size());
 | |
|         assertTrue(allRules6.contains(rule2));
 | |
|         assertTrue(allRules6.contains(rule7));
 | |
|         
 | |
|         List<? extends Rule> allRules7 = this.ruleService.getRules(rootWithRules, true);
 | |
|         assertNotNull(allRules7);
 | |
|         assertEquals(3, allRules7.size());
 | |
|         assertTrue(allRules7.contains(rule1));
 | |
|         assertTrue(allRules7.contains(rule2));
 | |
|         assertTrue(allRules7.contains(rule7));
 | |
|         
 | |
|         List<? extends Rule> allRules8 = this.ruleService.getRules(rootWithRules2, true);
 | |
|         assertNotNull(allRules8);
 | |
|         assertEquals(2, allRules8.size());
 | |
|         assertTrue(allRules8.contains(rule5));
 | |
|         assertTrue(allRules8.contains(rule6));
 | |
|          
 | |
|         // Take the root node and and remove a rule
 | |
|         
 | |
|         this.ruleService.removeRule(rootWithRules, rule7);
 | |
|         
 | |
|         List<? extends Rule> allRules9 = this.ruleService.getRules(childWithRules, true);
 | |
|         assertNotNull(allRules9);
 | |
|         assertEquals(4, allRules9.size());
 | |
|         assertTrue(allRules9.contains(rule2));
 | |
|         assertTrue(allRules9.contains(rule3));
 | |
|         assertTrue(allRules9.contains(rule4));
 | |
|         assertTrue(allRules9.contains(rule6));
 | |
|         
 | |
|         List<? extends Rule> allRules10 = this.ruleService.getRules(nonActionableChild, true);
 | |
|         assertNotNull(allRules10);
 | |
|         assertEquals(1, allRules10.size());
 | |
|         assertTrue(allRules10.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> allRules11 = this.ruleService.getRules(rootWithRules, true);
 | |
|         assertNotNull(allRules11);
 | |
|         assertEquals(2, allRules11.size());
 | |
|         assertTrue(allRules11.contains(rule1));
 | |
|         assertTrue(allRules11.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> allRules12 = this.ruleService.getRules(rootWithRules2, true);
 | |
|         assertNotNull(allRules12);
 | |
|         assertEquals(2, allRules12.size());
 | |
|         assertTrue(allRules12.contains(rule5));
 | |
|         assertTrue(allRules12.contains(rule6));
 | |
|         
 | |
|         // Delete an association
 | |
|         
 | |
|         this.nodeService.removeChild(rootWithRules2, childWithRules);
 | |
|         
 | |
|         List<? extends Rule> allRules13 = this.ruleService.getRules(childWithRules, true);
 | |
|         assertNotNull(allRules13);
 | |
|         assertEquals(3, allRules13.size());
 | |
|         assertTrue(allRules13.contains(rule2));
 | |
|         assertTrue(allRules13.contains(rule3));
 | |
|         assertTrue(allRules13.contains(rule4));
 | |
|         
 | |
|         List<? extends Rule> allRules14 = this.ruleService.getRules(nonActionableChild, true);
 | |
|         assertNotNull(allRules14);
 | |
|         assertEquals(1, allRules14.size());
 | |
|         assertTrue(allRules14.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> allRules15 = this.ruleService.getRules(rootWithRules, true);
 | |
|         assertNotNull(allRules15);
 | |
|         assertEquals(2, allRules15.size());
 | |
|         assertTrue(allRules15.contains(rule1));
 | |
|         assertTrue(allRules15.contains(rule2));
 | |
|        
 | |
|         List<? extends Rule> allRules16 = this.ruleService.getRules(rootWithRules2, true);
 | |
|         assertNotNull(allRules16);
 | |
|         assertEquals(2, allRules16.size());
 | |
|         assertTrue(allRules16.contains(rule5));
 | |
|         assertTrue(allRules16.contains(rule6));
 | |
|         
 | |
|         this.ruleService.disableRules(rootWithRules2);
 | |
|         try
 | |
|         {
 | |
|             // Add an association
 | |
|             this.nodeService.addChild(
 | |
|                     rootWithRules2, 
 | |
|                     childWithRules, 
 | |
|                     ContentModel.ASSOC_CHILDREN,
 | |
|                     QName.createQName("{test}testnode"));
 | |
|         }
 | |
|         finally
 | |
|         {
 | |
|             this.ruleService.enableRules(rootWithRules2);
 | |
|         }
 | |
|         
 | |
|         List<? extends Rule> allRules17 = this.ruleService.getRules(childWithRules, true);
 | |
|         assertNotNull(allRules17);
 | |
|         assertEquals(4, allRules17.size());
 | |
|         assertTrue(allRules17.contains(rule2));
 | |
|         assertTrue(allRules17.contains(rule3));
 | |
|         assertTrue(allRules17.contains(rule4));
 | |
|         assertTrue(allRules17.contains(rule6));
 | |
|         
 | |
|         List<? extends Rule> allRules18 = this.ruleService.getRules(nonActionableChild, true);
 | |
|         assertNotNull(allRules18);
 | |
|         assertEquals(1, allRules18.size());
 | |
|         assertTrue(allRules18.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> allRules19 = this.ruleService.getRules(rootWithRules, true);
 | |
|         assertNotNull(allRules19);
 | |
|         assertEquals(2, allRules19.size());
 | |
|         assertTrue(allRules19.contains(rule1));
 | |
|         assertTrue(allRules19.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> allRules20 = this.ruleService.getRules(rootWithRules2, true);
 | |
|         assertNotNull(allRules20);
 | |
|         assertEquals(2, allRules20.size());
 | |
|         assertTrue(allRules20.contains(rule5));
 | |
|         assertTrue(allRules20.contains(rule6));
 | |
|         
 | |
|         // Delete node
 | |
|         
 | |
|         this.nodeService.deleteNode(rootWithRules2);
 | |
|         
 | |
|         List<? extends Rule> allRules21 = this.ruleService.getRules(childWithRules, true);
 | |
|         assertNotNull(allRules21);
 | |
|         assertEquals(3, allRules21.size());
 | |
|         assertTrue(allRules21.contains(rule2));
 | |
|         assertTrue(allRules21.contains(rule3));
 | |
|         assertTrue(allRules21.contains(rule4));
 | |
|         
 | |
|         List<? extends Rule> allRules22 = this.ruleService.getRules(nonActionableChild, true);
 | |
|         assertNotNull(allRules22);
 | |
|         assertEquals(1, allRules22.size());
 | |
|         assertTrue(allRules22.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> allRules23 = this.ruleService.getRules(rootWithRules, true);
 | |
|         assertNotNull(allRules23);
 | |
|         assertEquals(2, allRules23.size());
 | |
|         assertTrue(allRules23.contains(rule1));
 | |
|         assertTrue(allRules23.contains(rule2));              
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Ensure that the rule store can cope with a cyclic node graph
 | |
|      * 
 | |
|      * @throws Exception
 | |
|      */
 | |
|     public void testCyclicGraphWithInheritedRules()
 | |
|         throws Exception
 | |
|     {
 | |
|         NodeRef nodeRef1 = createNewNode(this.rootNodeRef);
 | |
|         NodeRef nodeRef2 = createNewNode(nodeRef1);
 | |
|         NodeRef nodeRef3 = createNewNode(nodeRef2);
 | |
|         try
 | |
|         {
 | |
|             this.nodeService.addChild(nodeRef3, nodeRef1, ContentModel.ASSOC_CHILDREN, QName.createQName("{test}loop"));
 | |
|             fail("Expected detection of cyclic relationship");
 | |
|         }
 | |
|         catch (CyclicChildRelationshipException e)
 | |
|         {
 | |
|             // expected
 | |
|             // the node will still have been created in the current transaction, although the txn will be rollback-only
 | |
|         }
 | |
|         
 | |
|         Rule rule1 = createTestRule(true);
 | |
|         this.ruleService.saveRule(nodeRef1, rule1);
 | |
|         Rule rule2 = createTestRule(true);
 | |
|         this.ruleService.saveRule(nodeRef2, rule2);
 | |
|         Rule rule3 = createTestRule(true);
 | |
|         this.ruleService.saveRule(nodeRef3, rule3);                
 | |
|         
 | |
|         List<? extends Rule> allRules1 = this.ruleService.getRules(nodeRef1, true);
 | |
|         assertNotNull(allRules1);
 | |
|         assertEquals(3, allRules1.size());
 | |
|         assertTrue(allRules1.contains(rule1));
 | |
|         assertTrue(allRules1.contains(rule2));
 | |
|         assertTrue(allRules1.contains(rule3));
 | |
|         
 | |
|         List<? extends Rule> allRules2 = this.ruleService.getRules(nodeRef2, true);
 | |
|         assertNotNull(allRules2);
 | |
|         assertEquals(3, allRules2.size());
 | |
|         assertTrue(allRules2.contains(rule1));
 | |
|         assertTrue(allRules2.contains(rule2));
 | |
|         assertTrue(allRules2.contains(rule3));
 | |
|         
 | |
|         List<? extends Rule> allRules3 = this.ruleService.getRules(nodeRef3, true);
 | |
|         assertNotNull(allRules3);
 | |
|         assertEquals(3, allRules3.size());
 | |
|         assertTrue(allRules3.contains(rule1));
 | |
|         assertTrue(allRules3.contains(rule2));
 | |
|         assertTrue(allRules3.contains(rule3));            
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Ensures that rules are not duplicated when inherited    
 | |
|      */
 | |
|     public void testRuleDuplication()
 | |
|     {
 | |
|         NodeRef nodeRef1 = createNewNode(this.rootNodeRef);
 | |
|         NodeRef nodeRef2 = createNewNode(nodeRef1);
 | |
|         NodeRef nodeRef3 = createNewNode(nodeRef2);
 | |
|         NodeRef nodeRef4 = createNewNode(nodeRef1);
 | |
|         this.nodeService.addChild(nodeRef4, nodeRef3, ContentModel.ASSOC_CHILDREN, QName.createQName("{test}test"));
 | |
|         
 | |
|         Rule rule1 = createTestRule(true);
 | |
|         this.ruleService.saveRule(nodeRef1, rule1);
 | |
|         Rule rule2 = createTestRule(true);
 | |
|         this.ruleService.saveRule(nodeRef2, rule2);
 | |
|         Rule rule3 = createTestRule(true);
 | |
|         this.ruleService.saveRule(nodeRef3, rule3);
 | |
|         Rule rule4 = createTestRule(true);
 | |
|         this.ruleService.saveRule(nodeRef4, rule4);
 | |
|         
 | |
|         List<? extends Rule> allRules1 = this.ruleService.getRules(nodeRef1, true);
 | |
|         assertNotNull(allRules1);
 | |
|         assertEquals(1, allRules1.size());
 | |
|         assertTrue(allRules1.contains(rule1));
 | |
|         
 | |
|         List<? extends Rule> allRules2 = this.ruleService.getRules(nodeRef2, true);
 | |
|         assertNotNull(allRules2);
 | |
|         assertEquals(2, allRules2.size());
 | |
|         assertTrue(allRules2.contains(rule1));
 | |
|         assertTrue(allRules2.contains(rule2));
 | |
|         
 | |
|         List<? extends Rule> allRules3 = this.ruleService.getRules(nodeRef3, true);
 | |
|         assertNotNull(allRules3);
 | |
|         assertEquals(4, allRules3.size());
 | |
|         assertTrue(allRules3.contains(rule1));
 | |
|         assertTrue(allRules3.contains(rule2));
 | |
|         assertTrue(allRules3.contains(rule3));
 | |
|         assertTrue(allRules3.contains(rule4));
 | |
|         
 | |
|         List<? extends Rule> allRules4 = this.ruleService.getRules(nodeRef4, true);
 | |
|         assertNotNull(allRules4);
 | |
|         assertEquals(2, allRules4.size());
 | |
|         assertTrue(allRules4.contains(rule1));
 | |
|         assertTrue(allRules4.contains(rule4));        
 | |
|     }
 | |
|     
 | |
|     public void testCyclicRules()
 | |
|     {
 | |
|     }
 | |
|     
 | |
|     public void testCyclicAsyncRules() throws Exception
 | |
|     {
 | |
|         NodeRef nodeRef = createNewNode(this.rootNodeRef);
 | |
|         
 | |
|         // Create the first rule
 | |
|         
 | |
|         Map<String, Serializable> conditionProps = new HashMap<String, Serializable>();
 | |
|         conditionProps.put(ComparePropertyValueEvaluator.PARAM_VALUE, "*.jpg");
 | |
| 
 | |
|         Map<String, Serializable> actionProps = new HashMap<String, Serializable>();
 | |
|         actionProps.put(ImageTransformActionExecuter.PARAM_MIME_TYPE, MimetypeMap.MIMETYPE_IMAGE_GIF);
 | |
|         actionProps.put(ImageTransformActionExecuter.PARAM_DESTINATION_FOLDER, nodeRef);
 | |
|         actionProps.put(ImageTransformActionExecuter.PARAM_ASSOC_TYPE_QNAME, ContentModel.ASSOC_CHILDREN);
 | |
|         actionProps.put(ImageTransformActionExecuter.PARAM_ASSOC_QNAME, ContentModel.ASSOC_CHILDREN);
 | |
|         
 | |
|         Rule rule = new Rule();
 | |
|         rule.setRuleType(this.ruleType.getName());
 | |
|         rule.setTitle("Convert from *.jpg to *.gif");
 | |
|         rule.setExecuteAsynchronously(true);
 | |
|         
 | |
|         Action action = this.actionService.createAction(ImageTransformActionExecuter.NAME);
 | |
|         action.setParameterValues(actionProps);
 | |
|         
 | |
|         ActionCondition actionCondition = this.actionService.createActionCondition(ComparePropertyValueEvaluator.NAME);
 | |
|         actionCondition.setParameterValues(conditionProps);
 | |
|         action.addActionCondition(actionCondition);        
 | |
|         
 | |
|         rule.setAction(action);
 | |
|         
 | |
|         // Create the next rule
 | |
|         
 | |
|         Map<String, Serializable> conditionProps2 = new HashMap<String, Serializable>();
 | |
|         conditionProps2.put(ComparePropertyValueEvaluator.PARAM_VALUE, "*.gif");
 | |
| 
 | |
|         Map<String, Serializable> actionProps2 = new HashMap<String, Serializable>();
 | |
|         actionProps2.put(ImageTransformActionExecuter.PARAM_MIME_TYPE, MimetypeMap.MIMETYPE_IMAGE_JPEG);
 | |
|         actionProps2.put(ImageTransformActionExecuter.PARAM_DESTINATION_FOLDER, nodeRef);
 | |
|         actionProps2.put(ImageTransformActionExecuter.PARAM_ASSOC_QNAME, ContentModel.ASSOC_CHILDREN);
 | |
|         
 | |
|         Rule rule2 = new Rule();
 | |
|         rule2.setRuleType(this.ruleType.getName());
 | |
|         rule2.setTitle("Convert from *.gif to *.jpg");
 | |
|         rule2.setExecuteAsynchronously(true);
 | |
|         
 | |
|         Action action2 = this.actionService.createAction(ImageTransformActionExecuter.NAME);
 | |
|         action2.setParameterValues(actionProps2);
 | |
|         
 | |
|         ActionCondition actionCondition2 = this.actionService.createActionCondition(ComparePropertyValueEvaluator.NAME);
 | |
|         actionCondition2.setParameterValues(conditionProps2);
 | |
|         action2.addActionCondition(actionCondition2);
 | |
|         
 | |
|         rule2.setAction(action2);
 | |
|         
 | |
|         // Save the rules
 | |
|         this.ruleService.saveRule(nodeRef, rule);
 | |
|         this.ruleService.saveRule(nodeRef, rule);
 | |
|         
 | |
|         // Now create new content
 | |
|         NodeRef contentNode = this.nodeService.createNode(nodeRef,
 | |
|                 ContentModel.ASSOC_CHILDREN,
 | |
|                 QName.createQName("{test}testnode"),
 | |
|                 ContentModel.TYPE_CONTENT).getChildRef();
 | |
|         this.nodeService.setProperty(contentNode, ContentModel.PROP_NAME, "myFile.jpg");
 | |
|         File file = AbstractContentTransformerTest.loadQuickTestFile("jpg");
 | |
|         ContentWriter writer = this.contentService.getWriter(contentNode, ContentModel.PROP_CONTENT, true);
 | |
|         writer.setEncoding("UTF-8");
 | |
|         writer.setMimetype(MimetypeMap.MIMETYPE_IMAGE_JPEG);
 | |
|         writer.putContent(file);
 | |
|         
 | |
|         setComplete();
 | |
|         endTransaction();
 | |
|         
 | |
|         //final NodeRef finalNodeRef = nodeRef;
 | |
|         
 | |
|         // Check to see what has happened
 | |
| //        ActionServiceImplTest.postAsyncActionTest(
 | |
| //                this.transactionService,
 | |
| //                10000, 
 | |
| //                10, 
 | |
| //                new AsyncTest()
 | |
| //                {
 | |
| //                    public boolean executeTest() 
 | |
| //                    {
 | |
| //                        List<ChildAssociationRef> assocs = RuleServiceImplTest.this.nodeService.getChildAssocs(finalNodeRef);
 | |
| //                        for (ChildAssociationRef ref : assocs)
 | |
| //                        {
 | |
| //                            NodeRef child = ref.getChildRef();
 | |
| //                            System.out.println("Child name: " + RuleServiceImplTest.this.nodeService.getProperty(child, ContentModel.PROP_NAME));
 | |
| //                        }
 | |
| //                        
 | |
| //                        return true;
 | |
| //                    };
 | |
| //                });
 | |
|     }    
 | |
|     
 | |
|     public void testDeleteSpaceWithExecuteScriptRule() throws Exception
 | |
|     {
 | |
|         endTransaction(); // So we don't hang indefinitely waiting for the outer transaction
 | |
|         transactionService.getRetryingTransactionHelper().doInTransaction(new RetryingTransactionCallback<Object>()
 | |
|         {
 | |
|             public Object execute()
 | |
|             {
 | |
|                 NodeRef storeRootNodeRef = nodeService.getRootNode(new StoreRef("workspace://SpacesStore"));
 | |
|                 // get company_home nodeRef
 | |
|                 NodeRef companyHomeNodeRef = searchService.selectNodes(storeRootNodeRef, "/app:company_home", null, namespaceService, false).get(0);
 | |
| 
 | |
|                 assertNotNull("NodeRef company_home is null", companyHomeNodeRef);
 | |
| 
 | |
|                 // create test folder in company_home
 | |
|                 QName testFolderName = QName.createQName(NamespaceService.CONTENT_MODEL_1_0_URI, "ISSUE_ETWOTWO_738_" + System.currentTimeMillis());
 | |
|                 ChildAssociationRef childAssocRef = nodeService.createNode(companyHomeNodeRef, ContentModel.ASSOC_CONTAINS, testFolderName, ContentModel.TYPE_FOLDER);
 | |
|                 NodeRef testFolderNodeRef = childAssocRef.getChildRef();
 | |
| 
 | |
|                 // get script nodeRef
 | |
|                 NodeRef scriptRef = searchService.selectNodes(storeRootNodeRef, "/app:company_home/app:dictionary/app:scripts/cm:backup.js.sample", null, namespaceService, false).get(0);
 | |
| 
 | |
|                 assertNotNull("NodeRef script is null", scriptRef);
 | |
| 
 | |
|                 // create rule
 | |
|                 Rule rule = new Rule();
 | |
|                 rule.setRuleType("inbound");
 | |
|                 rule.setTitle("rule title " + System.currentTimeMillis());
 | |
| 
 | |
|                 CompositeAction compositeAction = actionService.createCompositeAction();
 | |
|                 rule.setAction(compositeAction);
 | |
| 
 | |
|                 // add the conditions to the rule
 | |
|                 ActionCondition condition = actionService.createActionCondition("no-condition");
 | |
|                 condition.setParameterValues(new HashMap<String, Serializable>());
 | |
|                 condition.setInvertCondition(false);
 | |
|                 compositeAction.addActionCondition(condition);
 | |
| 
 | |
|                 // add the action to the rule
 | |
|                 Action action = actionService.createAction("script");
 | |
|                 Map<String, Serializable> repoActionParams = new HashMap<String, Serializable>();
 | |
|                 repoActionParams.put("script-ref", scriptRef);
 | |
|                 action.setParameterValues(repoActionParams);
 | |
|                 compositeAction.addAction(action);
 | |
| 
 | |
|                 // save rule
 | |
|                 ruleService.saveRule(testFolderNodeRef, rule);
 | |
| 
 | |
|                 // delete node with rule
 | |
|                 nodeService.deleteNode(testFolderNodeRef);
 | |
| 
 | |
|                 return null;
 | |
|             }
 | |
|         }, false, true);
 | |
|     }
 | |
| 
 | |
|     public void testPermissionsForPropagatedRules_ALF_8408() throws Exception
 | |
|     {
 | |
|         // Create parent and child folders
 | |
|         NodeRef parentNodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()), ContentModel.TYPE_FOLDER)
 | |
|                 .getChildRef();
 | |
| 
 | |
|         NodeRef childNodeRef = this.nodeService.createNode(parentNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("childnode" + GUID.generate()), ContentModel.TYPE_FOLDER)
 | |
|                 .getChildRef();
 | |
| 
 | |
|         // Remove all permissions for parent
 | |
|         permissionService.deletePermissions(parentNodeRef);
 | |
|         permissionService.setInheritParentPermissions(parentNodeRef, false);
 | |
| 
 | |
|         // Create test user
 | |
|         String username = "ruleTestUser" + GUID.generate();
 | |
|         this.authenticationService.createAuthentication(username, "password".toCharArray());
 | |
| 
 | |
|         // Set user permissions for child node
 | |
|         permissionService.deletePermissions(childNodeRef);
 | |
|         permissionService.setInheritParentPermissions(childNodeRef, false);
 | |
|         permissionService.setPermission(childNodeRef, username, PermissionService.CONTRIBUTOR, true);
 | |
| 
 | |
|         // Create rule for child node
 | |
|         Rule testRule = new Rule();
 | |
|         testRule.setRuleTypes(Collections.singletonList(RuleType.INBOUND));
 | |
|         testRule.setTitle("RuleServiceTest" + GUID.generate());
 | |
|         testRule.setDescription(DESCRIPTION);
 | |
|         testRule.applyToChildren(true);
 | |
|         Action action = this.actionService.createAction(AddFeaturesActionExecuter.NAME);
 | |
|         action.setParameterValue(AddFeaturesActionExecuter.PARAM_ASPECT_NAME, ContentModel.ASPECT_VERSIONABLE);
 | |
|         testRule.setAction(action);
 | |
|         this.ruleService.saveRule(parentNodeRef, testRule);
 | |
|         assertNotNull("Rule was not saved", testRule.getNodeRef());
 | |
| 
 | |
|         // Authenticate as test user
 | |
|         this.authenticationService.authenticate(username, "password".toCharArray());
 | |
|         authenticationComponent.setCurrentUser(username);
 | |
| 
 | |
|         // Search rules
 | |
|         List<Rule> rules = this.ruleService.getRules(childNodeRef, true, testRule.getRuleTypes().get(0));
 | |
|         assertNotNull("No rules found", rules);
 | |
|         assertTrue("Created rule is not found", new HashSet<Rule>(rules).contains(testRule));
 | |
| 
 | |
|         // New node
 | |
|         NodeRef actionedUponNodeRef = this.nodeService.createNode(childNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("actioneduponnode" + GUID.generate()),
 | |
|                 ContentModel.TYPE_CONTENT).getChildRef();
 | |
| 
 | |
|         // Testing immediate rule execution
 | |
|         if (this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE))
 | |
|         {
 | |
|             this.nodeService.removeAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE);
 | |
|         }
 | |
|         ((RuntimeRuleService) ruleService).executeRule(testRule, actionedUponNodeRef, null);
 | |
|         assertTrue("Rule was not executed", this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE));
 | |
| 
 | |
|         // Queue the rule to be executed later and execute pending rules
 | |
|         if (this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE))
 | |
|         {
 | |
|             this.nodeService.removeAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE);
 | |
|         }
 | |
|         ((RuntimeRuleService) ruleService).addRulePendingExecution(parentNodeRef, actionedUponNodeRef, testRule);
 | |
|         ((RuntimeRuleService) ruleService).executePendingRules();
 | |
|         assertTrue("Pending rule was not executed", this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * ALF-12726
 | |
|      * use FileFolderService to rename
 | |
|      */
 | |
|     public void testOutboundRuleTriggeredAfterRename1() throws Exception
 | |
|     {
 | |
|         String newName = "newName" + GUID.generate();
 | |
| 
 | |
|         // Create 2 folders
 | |
|         NodeRef folder1NodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()), ContentModel.TYPE_FOLDER)
 | |
|                 .getChildRef();
 | |
|         NodeRef folder2NodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()), ContentModel.TYPE_FOLDER)
 | |
|                 .getChildRef();
 | |
| 
 | |
|         // Create rule for folder1
 | |
|         Rule testRule = new Rule();
 | |
|         testRule.setRuleTypes(Collections.singletonList(RuleType.OUTBOUND));
 | |
|         testRule.setTitle("RuleServiceTest" + GUID.generate());
 | |
|         testRule.setDescription(DESCRIPTION);
 | |
|         testRule.applyToChildren(true);
 | |
|         Action action = this.actionService.createAction(CopyActionExecuter.NAME);
 | |
|         action.setParameterValue(CopyActionExecuter.PARAM_DESTINATION_FOLDER, folder2NodeRef);
 | |
|         testRule.setAction(action);
 | |
|         this.ruleService.saveRule(folder1NodeRef, testRule);
 | |
|         assertNotNull("Rule was not saved", testRule.getNodeRef());
 | |
| 
 | |
|         QName actionedQName = QName.createQName("actioneduponnode" + GUID.generate());
 | |
|         // New node
 | |
|         NodeRef actionedUponNodeRef = this.nodeService.createNode(folder1NodeRef, ContentModel.ASSOC_CHILDREN, actionedQName,
 | |
|                 ContentModel.TYPE_CONTENT).getChildRef();
 | |
|         ContentWriter writer = this.contentService.getWriter(actionedUponNodeRef, ContentModel.PROP_CONTENT, true);
 | |
|         writer.setMimetype("text/plain");
 | |
|         writer.putContent("TestContent");
 | |
| 
 | |
|         // Rename the node
 | |
|         this.fileFolderService.rename(actionedUponNodeRef, newName);
 | |
| 
 | |
|         // Check that the rule was not executed
 | |
|         List<ChildAssociationRef> childAssoc = this.nodeService.getChildAssocs(folder2NodeRef, RegexQNamePattern.MATCH_ALL, actionedQName);
 | |
|         assertEquals("The rule should not be triggered and no document should be present.", 0, childAssoc.size());
 | |
| 
 | |
|         // Check that the content is still in folder1
 | |
|         childAssoc = this.nodeService.getChildAssocs(folder1NodeRef, RegexQNamePattern.MATCH_ALL, QName.createQName(newName));
 | |
|         assertEquals("The rule should not be triggered and the document should be in folder1.", 1, childAssoc.size());
 | |
| 
 | |
|         this.nodeService.deleteNode(folder1NodeRef);
 | |
|         this.nodeService.deleteNode(folder2NodeRef);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * ALF-12726
 | |
|      * use NodeService to rename
 | |
|      */
 | |
|     public void testOutboundRuleTriggeredAfterRename2() throws Exception
 | |
|     {
 | |
|         UserTransaction txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
|         String newName = "newName" + GUID.generate();
 | |
| 
 | |
|         // Create 2 folders
 | |
|         NodeRef folder1NodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()), ContentModel.TYPE_FOLDER)
 | |
|                 .getChildRef();
 | |
|         NodeRef folder2NodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()), ContentModel.TYPE_FOLDER)
 | |
|                 .getChildRef();
 | |
| 
 | |
|         // Create rule for folder1
 | |
|         Rule testRule = new Rule();
 | |
|         testRule.setRuleTypes(Collections.singletonList(RuleType.OUTBOUND));
 | |
|         testRule.setTitle("RuleServiceTest" + GUID.generate());
 | |
|         testRule.setDescription(DESCRIPTION);
 | |
|         testRule.applyToChildren(true);
 | |
|         Action action = this.actionService.createAction(CopyActionExecuter.NAME);
 | |
|         action.setParameterValue(CopyActionExecuter.PARAM_DESTINATION_FOLDER, folder2NodeRef);
 | |
|         testRule.setAction(action);
 | |
|         this.ruleService.saveRule(folder1NodeRef, testRule);
 | |
|         assertNotNull("Rule was not saved", testRule.getNodeRef());
 | |
| 
 | |
|         QName actionedQName = QName.createQName("actioneduponnode" + GUID.generate());
 | |
|         // New node
 | |
|         NodeRef actionedUponNodeRef = this.nodeService.createNode(folder1NodeRef, ContentModel.ASSOC_CHILDREN, actionedQName,
 | |
|                 ContentModel.TYPE_CONTENT).getChildRef();
 | |
|         ContentWriter writer = this.contentService.getWriter(actionedUponNodeRef, ContentModel.PROP_CONTENT, true);
 | |
|         writer.setMimetype("text/plain");
 | |
|         writer.putContent("TestContent");
 | |
| 
 | |
|         // Rename the node
 | |
|         nodeService.setProperty(actionedUponNodeRef, ContentModel.PROP_NAME, newName);
 | |
|         txn.commit();
 | |
| 
 | |
|         txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
| 
 | |
|         // Check that the rule was not executed
 | |
|         List<ChildAssociationRef> childAssoc = this.nodeService.getChildAssocs(folder2NodeRef, RegexQNamePattern.MATCH_ALL, actionedQName);
 | |
|         assertEquals("The rule should not be triggered and no document should be present.", 0, childAssoc.size());
 | |
| 
 | |
|         // Check that the content is still in folder1
 | |
|         childAssoc = this.nodeService.getChildAssocs(folder1NodeRef, RegexQNamePattern.MATCH_ALL, actionedQName);
 | |
|         assertEquals("The rule should not be triggered and the document should be in folder1.", 1, childAssoc.size());
 | |
| 
 | |
|         assertEquals("The node should be renamed.", newName, nodeService.getProperty(actionedUponNodeRef, ContentModel.PROP_NAME));
 | |
| 
 | |
|         this.nodeService.deleteNode(folder1NodeRef);
 | |
|         this.nodeService.deleteNode(folder2NodeRef);
 | |
|         txn.commit();
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * MNT-11670
 | |
|      */
 | |
|     public void testRuleExecutionWhenSecurityContextIsEmpty() throws Exception
 | |
|     {
 | |
|         // Create parent and child folders
 | |
|         NodeRef parentNodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()), ContentModel.TYPE_FOLDER)
 | |
|                 .getChildRef();
 | |
|         
 | |
|         // rule is created and added to pending execution by any user
 | |
|         assertNotNull(AuthenticationUtil.getFullyAuthenticatedUser());
 | |
|         
 | |
|         // Create rule for child node
 | |
|         Rule testRule = new Rule();
 | |
|         testRule.setRuleTypes(Collections.singletonList(RuleType.INBOUND));
 | |
|         testRule.setTitle("RuleServiceTest" + GUID.generate());
 | |
|         testRule.setDescription(DESCRIPTION);
 | |
|         testRule.applyToChildren(true);
 | |
|         Action action = this.actionService.createAction(AddFeaturesActionExecuter.NAME);
 | |
|         action.setParameterValue(AddFeaturesActionExecuter.PARAM_ASPECT_NAME, ContentModel.ASPECT_VERSIONABLE);
 | |
|         testRule.setAction(action);
 | |
|         this.ruleService.saveRule(parentNodeRef, testRule);
 | |
|         assertNotNull("Rule was not saved", testRule.getNodeRef());
 | |
| 
 | |
|         // Search rules
 | |
|         List<Rule> rules = this.ruleService.getRules(parentNodeRef, true, testRule.getRuleTypes().get(0));
 | |
|         assertNotNull("No rules found", rules);
 | |
|         assertTrue("Created rule is not found", new HashSet<Rule>(rules).contains(testRule));
 | |
| 
 | |
|         // New node
 | |
|         NodeRef actionedUponNodeRef = this.nodeService.createNode(parentNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("actioneduponnode" + GUID.generate()),
 | |
|                 ContentModel.TYPE_CONTENT).getChildRef();
 | |
| 
 | |
|         // Queue the rule to be executed later and execute pending rules
 | |
|         if (this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE))
 | |
|         {
 | |
|             this.nodeService.removeAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE);
 | |
|         }
 | |
|         ((RuntimeRuleService) ruleService).addRulePendingExecution(parentNodeRef, actionedUponNodeRef, testRule);
 | |
|         
 | |
|         // no security context in case of the issue
 | |
|         AuthenticationUtil.clearCurrentSecurityContext();
 | |
|         assertNull(AuthenticationUtil.getFullyAuthenticatedUser());
 | |
|         assertNull(AuthenticationUtil.getRunAsUser());
 | |
|         
 | |
|         ((RuntimeRuleService) ruleService).executePendingRules();
 | |
|         assertTrue("Pending rule was not executed", this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE));
 | |
|     }
 | |
| 	    
 | |
|     /**
 | |
|      * Test for MNT-11695
 | |
|      */
 | |
|     public void testOutBoundRuleTriggerForPendingDelete() throws Exception
 | |
|     {
 | |
|         UserTransaction txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
|         // Create 1 folder with 2 folders inside
 | |
|         NodeRef parentFolderNodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()),
 | |
|                 ContentModel.TYPE_FOLDER).getChildRef();
 | |
|         NodeRef folder1NodeRef = this.nodeService.createNode(parentFolderNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()),
 | |
|                 ContentModel.TYPE_FOLDER).getChildRef();
 | |
|         NodeRef folder2NodeRef = this.nodeService.createNode(parentFolderNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()),
 | |
|                 ContentModel.TYPE_FOLDER).getChildRef();
 | |
| 
 | |
|         // Create rule for folder1
 | |
|         Rule testRule = new Rule();
 | |
|         testRule.setRuleTypes(Collections.singletonList(RuleType.OUTBOUND));
 | |
|         testRule.setTitle("RuleServiceTest" + GUID.generate());
 | |
|         testRule.setDescription(DESCRIPTION);
 | |
|         testRule.applyToChildren(true);
 | |
|         Action action = this.actionService.createAction(CopyActionExecuter.NAME);
 | |
|         action.setParameterValue(CopyActionExecuter.PARAM_DESTINATION_FOLDER, folder2NodeRef);
 | |
|         testRule.setAction(action);
 | |
|         this.ruleService.saveRule(folder1NodeRef, testRule);
 | |
|         assertNotNull("Rule was not saved", testRule.getNodeRef());
 | |
| 
 | |
|         QName actionedQName = QName.createQName("actioneduponnode" + GUID.generate());
 | |
|         // New node
 | |
|         NodeRef actionedUponNodeRef = this.nodeService.createNode(folder1NodeRef, ContentModel.ASSOC_CHILDREN, actionedQName, ContentModel.TYPE_CONTENT).getChildRef();
 | |
|         ContentWriter writer = this.contentService.getWriter(actionedUponNodeRef, ContentModel.PROP_CONTENT, true);
 | |
|         writer.setMimetype("text/plain");
 | |
|         writer.putContent("TestContent");
 | |
|         txn.commit();
 | |
| 
 | |
|         // Remove the parent folder
 | |
|         txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
|         try
 | |
|         {
 | |
|             nodeService.deleteNode(parentFolderNodeRef);
 | |
|         }
 | |
|         catch (Exception e)
 | |
|         {
 | |
|             fail("The nodes should be deleted without errors, but exception was thrown: " + e);
 | |
|         }
 | |
|         txn.commit();
 | |
| 
 | |
|         txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
|         assertFalse("The folder should be deleted.", nodeService.exists(parentFolderNodeRef));
 | |
|         txn.commit();
 | |
| 
 | |
|         // Now test move action
 | |
|         txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
|         // Create 1 folder with 2 folders inside
 | |
|         parentFolderNodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()),
 | |
|                 ContentModel.TYPE_FOLDER).getChildRef();
 | |
|         folder1NodeRef = this.nodeService.createNode(parentFolderNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()),
 | |
|                 ContentModel.TYPE_FOLDER).getChildRef();
 | |
|         folder2NodeRef = this.nodeService.createNode(parentFolderNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()),
 | |
|                 ContentModel.TYPE_FOLDER).getChildRef();
 | |
| 
 | |
|         // Create rule for folder1
 | |
|         testRule = new Rule();
 | |
|         testRule.setRuleTypes(Collections.singletonList(RuleType.OUTBOUND));
 | |
|         testRule.setTitle("RuleServiceTest" + GUID.generate());
 | |
|         testRule.setDescription(DESCRIPTION);
 | |
|         testRule.applyToChildren(true);
 | |
|         action = this.actionService.createAction(MoveActionExecuter.NAME);
 | |
|         action.setParameterValue(CopyActionExecuter.PARAM_DESTINATION_FOLDER, folder2NodeRef);
 | |
|         testRule.setAction(action);
 | |
|         this.ruleService.saveRule(folder1NodeRef, testRule);
 | |
|         assertNotNull("Rule was not saved", testRule.getNodeRef());
 | |
| 
 | |
|         actionedQName = QName.createQName("actioneduponnode" + GUID.generate());
 | |
|         // New node
 | |
|         actionedUponNodeRef = this.nodeService.createNode(folder1NodeRef, ContentModel.ASSOC_CHILDREN, actionedQName, ContentModel.TYPE_CONTENT).getChildRef();
 | |
|         writer = this.contentService.getWriter(actionedUponNodeRef, ContentModel.PROP_CONTENT, true);
 | |
|         writer.setMimetype("text/plain");
 | |
|         writer.putContent("TestContent");
 | |
|         txn.commit();
 | |
| 
 | |
|         // Remove the parent folder
 | |
|         txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
|         try
 | |
|         {
 | |
|             nodeService.deleteNode(parentFolderNodeRef);
 | |
|         }
 | |
|         catch (Exception e)
 | |
|         {
 | |
|             fail("The nodes should be deleted without errors, but exception was thrown: " + e);
 | |
|         }
 | |
|         txn.commit();
 | |
| 
 | |
|         txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
|         assertFalse("The folder should be deleted.", nodeService.exists(parentFolderNodeRef));
 | |
|         txn.commit();
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * MNT-9885. Testing rule trigger after removing Temporary Aspect from the node.
 | |
|      * 
 | |
|      * @throws Exception
 | |
|      */
 | |
|     public void testRuleTriggerWithTemporaryFiles() throws Exception
 | |
|     {
 | |
|         UserTransaction txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
| 
 | |
|         NodeRef parentNodeRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN,
 | |
|                 QName.createQName("parentnode" + GUID.generate()), ContentModel.TYPE_FOLDER).getChildRef();
 | |
| 
 | |
|         QName actionedQName = QName.createQName("actioneduponnode" + GUID.generate());
 | |
|         // New child node
 | |
|         NodeRef actionedUponNodeRef = this.nodeService.createNode(parentNodeRef, ContentModel.ASSOC_CHILDREN,
 | |
|                 actionedQName, ContentModel.TYPE_CONTENT).getChildRef();
 | |
| 
 | |
|         // Add Temporary Aspect to the child Node
 | |
|         this.nodeService.addAspect(actionedUponNodeRef, ContentModel.ASPECT_TEMPORARY, null);
 | |
| 
 | |
|         // Write some content to the child node
 | |
|         ContentWriter writer = this.contentService.getWriter(actionedUponNodeRef, ContentModel.PROP_CONTENT, true);
 | |
|         writer.setMimetype("text/plain");
 | |
|         writer.putContent("TestContent");
 | |
| 
 | |
|         // Create rule for Versionable Aspect
 | |
|         Rule testRule = new Rule();
 | |
|         testRule.setRuleTypes(Collections.singletonList(RuleType.INBOUND));
 | |
|         testRule.setTitle("RuleServiceTest" + GUID.generate());
 | |
|         testRule.setDescription(DESCRIPTION);
 | |
|         testRule.applyToChildren(true);
 | |
| 
 | |
|         Action action = this.actionService.createAction(AddFeaturesActionExecuter.NAME);
 | |
|         action.setParameterValue(AddFeaturesActionExecuter.PARAM_ASPECT_NAME, ContentModel.ASPECT_VERSIONABLE);
 | |
|         testRule.setAction(action);
 | |
| 
 | |
|         this.ruleService.saveRule(parentNodeRef, testRule);
 | |
|         assertNotNull("Rule was not saved", testRule.getNodeRef());
 | |
| 
 | |
|         // Search rules
 | |
|         List<Rule> rules = this.ruleService.getRules(parentNodeRef, true, testRule.getRuleTypes().get(0));
 | |
|         assertNotNull("No rules found", rules);
 | |
|         assertTrue("Created rule is not found", new HashSet<>(rules).contains(testRule));
 | |
| 
 | |
|         txn.commit();
 | |
| 
 | |
|         // Remove Temporary Aspect from child node
 | |
|         txn = transactionService.getUserTransaction();
 | |
|         txn.begin();
 | |
| 
 | |
|         assertTrue("Node has Temporary aspect: ", this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_TEMPORARY));
 | |
|         assertFalse("Node with Temporary aspect has versionable aspect: ", this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE));
 | |
| 
 | |
|         // Removing Tempporary aspect
 | |
|         this.nodeService.removeAspect(actionedUponNodeRef, ContentModel.ASPECT_TEMPORARY);
 | |
| 
 | |
|         txn.commit();
 | |
| 
 | |
|         // Add rule for parent Node
 | |
|         ((RuntimeRuleService) ruleService).addRulePendingExecution(parentNodeRef, actionedUponNodeRef, testRule);
 | |
|         ((RuntimeRuleService) ruleService).executePendingRules();
 | |
| 
 | |
|         assertTrue("Pending rule was not executed",
 | |
|                 this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE));
 | |
|         assertFalse("Node has temporary aspect",
 | |
|                 this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_TEMPORARY));
 | |
|         assertTrue("Node has versionable aspect",
 | |
|                 this.nodeService.hasAspect(actionedUponNodeRef, ContentModel.ASPECT_VERSIONABLE));
 | |
| 
 | |
|         this.nodeService.deleteNode(actionedUponNodeRef);
 | |
|         this.nodeService.deleteNode(parentNodeRef);
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * MNT-12819
 | |
|      * Create two rules: outbound (enabled) and inbound (disabled). Then try to remove them via removeAllRules method.
 | |
|      * @throws SystemException 
 | |
|      * @throws NotSupportedException 
 | |
|      */
 | |
|     @Test
 | |
|     public void testRemoveAllRulesForInboundAndOutbound() throws Exception
 | |
|     {
 | |
|         String scriptName = "nothingToDo.js";
 | |
|         createNothingToDoScript(scriptName);
 | |
|         
 | |
|         NodeRef storeRootNodeRef = nodeService.getRootNode(new StoreRef("workspace://SpacesStore"));
 | |
|         NodeRef scriptRef = searchService.selectNodes(storeRootNodeRef, "/app:company_home/app:dictionary/app:scripts/cm:"+scriptName, null, namespaceService, false).get(0);
 | |
|         
 | |
|         NodeRef folderForRulesRef = this.nodeService.createNode(rootNodeRef, ContentModel.ASSOC_CHILDREN, QName.createQName("parentnode" + GUID.generate()), ContentModel.TYPE_FOLDER)
 | |
|                 .getChildRef();
 | |
|      
 | |
|         try
 | |
|         {
 | |
|             // Create outbound rule for folderForRules
 | |
|             Rule outRule = new Rule();
 | |
|             outRule.setRuleType(RuleType.OUTBOUND);
 | |
|             outRule.setTitle("TestOutRule" + GUID.generate());
 | |
|             outRule.applyToChildren(true);
 | |
|             outRule.setRuleDisabled(false);
 | |
|             outRule.setExecuteAsynchronously(false);
 | |
|             outRule.setAction(createScriptAction());
 | |
|             this.ruleService.saveRule(folderForRulesRef, outRule);
 | |
|             assertNotNull("Rule was not saved", outRule.getNodeRef());
 | |
| 
 | |
|             // Create inbound rule for folderForRules
 | |
|             Rule inRule = new Rule();
 | |
|             inRule.setRuleType(RuleType.INBOUND);
 | |
|             inRule.setTitle("TestinRule" + GUID.generate());
 | |
|             inRule.applyToChildren(false);
 | |
|             inRule.setExecuteAsynchronously(false);
 | |
|             inRule.setRuleDisabled(true);
 | |
|             inRule.setAction(createScriptAction());
 | |
|             this.ruleService.saveRule(folderForRulesRef, inRule);
 | |
|             assertNotNull("Rule was not saved", inRule.getNodeRef());
 | |
| 
 | |
|             // remove rules
 | |
|             this.ruleService.removeAllRules(folderForRulesRef);
 | |
|         }
 | |
|         catch (InvalidNodeRefException exc)
 | |
|         {
 | |
|             fail("Cannot remove rules from folder");
 | |
|         }
 | |
|         finally
 | |
|         {
 | |
|             this.nodeService.deleteNode(folderForRulesRef);
 | |
|             this.nodeService.deleteNode(scriptRef);
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     private void createNothingToDoScript(String scriptName)
 | |
|     {
 | |
|         NodeRef storeRootNodeRef = nodeService.getRootNode(new StoreRef("workspace://SpacesStore"));
 | |
|         NodeRef scriptFolderRef = searchService.selectNodes(storeRootNodeRef, "/app:company_home/app:dictionary/app:scripts", null, namespaceService, false).get(0);
 | |
|         
 | |
|         try
 | |
|         {
 | |
|             FileInfo fileInfo = fileFolderService.create(scriptFolderRef, scriptName, ContentModel.TYPE_CONTENT);
 | |
| 
 | |
|             ContentWriter writer = fileFolderService.getWriter(fileInfo.getNodeRef());
 | |
|             assertNotNull("Writer is null", writer);
 | |
|             // write some content
 | |
|             String content = "function main(){}\nmain();";
 | |
|             writer.putContent(content);
 | |
|         }
 | |
|         catch (FileExistsException exc)
 | |
|         {
 | |
|             // file was created before
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     private Action createScriptAction()
 | |
|     {
 | |
|         // get script nodeRef
 | |
|         NodeRef storeRootNodeRef = nodeService.getRootNode(new StoreRef("workspace://SpacesStore"));
 | |
|         NodeRef scriptRef = searchService.selectNodes(storeRootNodeRef, "/app:company_home/app:dictionary/app:scripts/cm:nothingToDo.js", null, namespaceService, false).get(0);
 | |
|         assertNotNull("NodeRef script is null", scriptRef);
 | |
| 
 | |
|         // create action
 | |
|         CompositeAction compositeAction = actionService.createCompositeAction();
 | |
| 
 | |
|         // add the action to the rule
 | |
|         Action action = actionService.createAction("script");
 | |
|         Map<String, Serializable> repoActionParams = new HashMap<String, Serializable>();
 | |
|         repoActionParams.put("script-ref", scriptRef);
 | |
|         action.setParameterValues(repoActionParams);
 | |
|         compositeAction.addAction(action);
 | |
|         
 | |
|         return compositeAction;
 | |
|     }
 | |
| }
 |