RM-2422 (Reuse existing classify file dialog for edit classification)

+review RM

git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/modules/recordsmanagement/HEAD@108909 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
Tuna Aksoy
2015-07-23 21:13:05 +00:00
parent ebc34f9209
commit 671fbfcaa1
6 changed files with 299 additions and 30 deletions

View File

@@ -925,12 +925,20 @@
<property name="capability" value="MoveDmRecords"/>
</bean>
<bean id="classificationPropertyDecorator"
<bean id="currentClassificationPropertyDecorator"
parent="baseDecorator"
class="org.alfresco.repo.jscript.app.ClassificationPropertyDecorator"
class="org.alfresco.repo.jscript.app.CurrentClassificationPropertyDecorator"
depends-on="classifiedContentDictionaryBootstrap">
<property name="propertyName" value="clf:currentClassification" />
<property name="classificationSchemeService" ref="ClassificationSchemeService" />
</bean>
<bean id="classificationReasonsPropertyDecorator"
parent="baseDecorator"
class="org.alfresco.repo.jscript.app.ClassificationReasonsPropertyDecorator"
depends-on="classifiedContentDictionaryBootstrap">
<property name="propertyName" value="clf:classificationReasons" />
<property name="classificationSchemeService" ref="ClassificationSchemeService" />
</bean>
</beans>

View File

@@ -392,6 +392,12 @@
</profile>
</profiles>
<dependencies>
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>2.3.1</version>
</dependency>
<!-- Alfresco dependencies -->
<dependency>
<groupId>org.alfresco</groupId>
<artifactId>${webapp.id}</artifactId>

View File

@@ -0,0 +1,99 @@
/*
* Copyright (C) 2005-2015 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.jscript.app;
import static org.alfresco.util.ParameterCheck.mandatory;
import java.io.Serializable;
import org.alfresco.module.org_alfresco_module_rm.classification.ClassificationReason;
import org.alfresco.module.org_alfresco_module_rm.classification.ClassificationSchemeService;
import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.service.namespace.QName;
import org.json.simple.JSONArray;
import org.json.simple.JSONAware;
import org.json.simple.JSONObject;
import com.google.gson.Gson;
/**
* Classification reasons property decorator
*
* @author Tuna Aksoy
* @since 3.0
*/
public class ClassificationReasonsPropertyDecorator extends BasePropertyDecorator
{
/** Constants */
protected static final String ID = "id";
protected static final String LABEL = "label";
protected static final String VALUE = "value";
protected static final String DISPLAY_LABEL = "displayLabel";
protected static final String FULL_REASON = "fullReason";
/** Classification scheme service */
private ClassificationSchemeService classificationSchemeService;
/**
* @return the classificationSchemeService
*/
protected ClassificationSchemeService getClassificationSchemeService()
{
return this.classificationSchemeService;
}
/**
* @param classificationSchemeService the classificationSchemeService to set
*/
public void setClassificationSchemeService(ClassificationSchemeService classificationSchemeService)
{
this.classificationSchemeService = classificationSchemeService;
}
/**
* @see org.alfresco.repo.jscript.app.PropertyDecorator#decorate(org.alfresco.service.namespace.QName, org.alfresco.service.cmr.repository.NodeRef, java.io.Serializable)
*/
@SuppressWarnings("unchecked")
public JSONAware decorate(QName propertyName, NodeRef nodeRef, Serializable value)
{
mandatory("value", value);
JSONArray jsonArray = new JSONArray();
JSONArray classificationReasonIds = new Gson().fromJson(value.toString(), JSONArray.class);
for (int i = 0; i < classificationReasonIds.size(); i++)
{
String classificationReasonId = (String) classificationReasonIds.get(i);
ClassificationReason classificationReason = getClassificationSchemeService().getClassificationReasonById(classificationReasonId);
String classificationReasonDisplayLabel = classificationReason.getDisplayLabel();
String classificationFullReason = classificationReasonId + ": " + classificationReasonDisplayLabel;
JSONObject jsonObject = new JSONObject();
jsonObject.put(ID, classificationReasonId);
jsonObject.put(LABEL, classificationFullReason);
jsonObject.put(VALUE, classificationReasonId);
jsonObject.put(DISPLAY_LABEL, classificationReasonDisplayLabel);
jsonObject.put(FULL_REASON, classificationFullReason);
jsonArray.add(jsonObject);
}
return jsonArray;
}
}

View File

@@ -29,16 +29,16 @@ import org.json.simple.JSONAware;
import org.json.simple.JSONObject;
/**
* Classification property decorator
* Current classification property decorator
*
* @author Tuna Aksoy
* @since 3.0
*/
public class ClassificationPropertyDecorator extends BasePropertyDecorator
public class CurrentClassificationPropertyDecorator extends BasePropertyDecorator
{
/** Constants */
private static final String ID = "id";
private static final String LABEL = "label";
protected static final String ID = "id";
protected static final String LABEL = "label";
/** Classification scheme service */
private ClassificationSchemeService classificationSchemeService;

View File

@@ -0,0 +1,169 @@
/*
* Copyright (C) 2005-2015 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.jscript.app;
import static org.alfresco.repo.jscript.app.ClassificationReasonsPropertyDecorator.DISPLAY_LABEL;
import static org.alfresco.repo.jscript.app.ClassificationReasonsPropertyDecorator.FULL_REASON;
import static org.alfresco.repo.jscript.app.ClassificationReasonsPropertyDecorator.ID;
import static org.alfresco.repo.jscript.app.ClassificationReasonsPropertyDecorator.LABEL;
import static org.alfresco.repo.jscript.app.ClassificationReasonsPropertyDecorator.VALUE;
import static org.alfresco.util.GUID.generate;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.mockito.Mockito.doReturn;
import org.alfresco.module.org_alfresco_module_rm.classification.ClassificationReason;
import org.alfresco.module.org_alfresco_module_rm.classification.ClassificationSchemeService;
import org.json.simple.JSONArray;
import org.json.simple.JSONObject;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;
import com.google.gson.Gson;
import com.google.gson.JsonSyntaxException;
/**
* Classification reasons property decorator unit test
*
* @author Tuna Aksoy
* @since 3.0
*/
@RunWith(MockitoJUnitRunner.class)
public class ClassificationReasonsPropertyDecoratorUnitTest
{
/** Classification reasons property decorator */
private @InjectMocks ClassificationReasonsPropertyDecorator decorator = new ClassificationReasonsPropertyDecorator();
/** Mocked classification scheme service */
private @Mock ClassificationSchemeService mockedClassificationSchemeService;
/**
* Given that no classification reason id is supplied
* When decorated
* Then an {@link IllegalArgumentException} is thrown
*/
@Test(expected = IllegalArgumentException.class)
public void testDecoratorWithoutClassificationId()
{
decorator.decorate(null, null, null);
}
/**
* Given that a classification reason id in an invalid format is supplied
* When decorated
* Then an {@link JsonSyntaxException} is thrown
*/
@Test(expected = JsonSyntaxException.class)
public void testDecoratorWithInvalidClassificationReasonId()
{
String classificationReasonId = generate();
String classificationReasonDisplayLabel = generate();
ClassificationReason classificationReason = new ClassificationReason(classificationReasonId, classificationReasonDisplayLabel);
doReturn(classificationReason).when(mockedClassificationSchemeService).getClassificationReasonById(classificationReasonId);
decorator.decorate(null, null, classificationReasonId);
}
/**
* Given that a classification reason id is supplied
* When decorated
* Then the result is a {@link JSONArray} containing the classification reason id, label, value, display label and full reason
*/
@SuppressWarnings("unchecked")
@Test
public void testDecoratorWithClassificationReasonId()
{
String classificationReasonId = generate();
String classificationReasonDisplayLabel = generate();
String classificationFullReason = classificationReasonId + ": " + classificationReasonDisplayLabel;
ClassificationReason classificationReason = new ClassificationReason(classificationReasonId, classificationReasonDisplayLabel);
doReturn(classificationReason).when(mockedClassificationSchemeService).getClassificationReasonById(classificationReasonId);
JSONArray classificationReasonIds = new JSONArray();
classificationReasonIds.add(classificationReasonId);
JSONArray decoratedProperty = (JSONArray) decorator.decorate(null, null, new Gson().toJson(classificationReasonIds));
assertNotNull(decoratedProperty);
assertEquals(1, decoratedProperty.size());
JSONObject jsonObject = (JSONObject) decoratedProperty.get(0);
assertNotNull(jsonObject);
assertEquals(classificationReasonId, jsonObject.get(ID));
assertEquals(classificationFullReason, jsonObject.get(LABEL));
assertEquals(classificationReasonId, jsonObject.get(VALUE));
assertEquals(classificationReasonDisplayLabel, jsonObject.get(DISPLAY_LABEL));
assertEquals(classificationFullReason, jsonObject.get(FULL_REASON));
}
/**
* Given that two classification reason id are supplied
* When decorated
* Then the result is a {@link JSONArray} containing the classification reason ids,
* labels, values, display labels and full reasons of both classification reasons
*/
@SuppressWarnings("unchecked")
@Test
public void testDecorateWithMultipleClassificationReasonIds()
{
String classificationReasonId1 = generate();
String classificationReasonDisplayLabel1 = generate();
String classificationFullReason1 = classificationReasonId1 + ": " + classificationReasonDisplayLabel1;
String classificationReasonId2 = generate();
String classificationReasonDisplayLabel2 = generate();
String classificationFullReason2 = classificationReasonId2 + ": " + classificationReasonDisplayLabel2;
ClassificationReason classificationReason1 = new ClassificationReason(classificationReasonId1, classificationReasonDisplayLabel1);
ClassificationReason classificationReason2 = new ClassificationReason(classificationReasonId2, classificationReasonDisplayLabel2);
doReturn(classificationReason1).when(mockedClassificationSchemeService).getClassificationReasonById(classificationReasonId1);
doReturn(classificationReason2).when(mockedClassificationSchemeService).getClassificationReasonById(classificationReasonId2);
JSONArray classificationReasonIds = new JSONArray();
classificationReasonIds.add(classificationReasonId1);
classificationReasonIds.add(classificationReasonId2);
JSONArray decoratedProperty = (JSONArray) decorator.decorate(null, null, new Gson().toJson(classificationReasonIds));
assertNotNull(decoratedProperty);
assertEquals(2, decoratedProperty.size());
JSONObject jsonObject1 = (JSONObject) decoratedProperty.get(0);
assertNotNull(jsonObject1);
assertEquals(classificationReasonId1, jsonObject1.get(ID));
assertEquals(classificationFullReason1, jsonObject1.get(LABEL));
assertEquals(classificationReasonId1, jsonObject1.get(VALUE));
assertEquals(classificationReasonDisplayLabel1, jsonObject1.get(DISPLAY_LABEL));
assertEquals(classificationFullReason1, jsonObject1.get(FULL_REASON));
JSONObject jsonObject2 = (JSONObject) decoratedProperty.get(1);
assertNotNull(jsonObject2);
assertEquals(classificationReasonId2, jsonObject2.get(ID));
assertEquals(classificationFullReason2, jsonObject2.get(LABEL));
assertEquals(classificationReasonId2, jsonObject2.get(VALUE));
assertEquals(classificationReasonDisplayLabel2, jsonObject2.get(DISPLAY_LABEL));
assertEquals(classificationFullReason2, jsonObject2.get(FULL_REASON));
}
}

View File

@@ -18,6 +18,8 @@
*/
package org.alfresco.repo.jscript.app;
import static org.alfresco.repo.jscript.app.CurrentClassificationPropertyDecorator.ID;
import static org.alfresco.repo.jscript.app.CurrentClassificationPropertyDecorator.LABEL;
import static org.alfresco.util.GUID.generate;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
@@ -25,51 +27,36 @@ import static org.mockito.Mockito.doReturn;
import org.alfresco.module.org_alfresco_module_rm.classification.ClassificationLevel;
import org.alfresco.module.org_alfresco_module_rm.classification.ClassificationSchemeService;
import org.alfresco.module.org_alfresco_module_rm.test.util.BaseUnitTest;
import org.json.simple.JSONObject;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;
/**
* Classification property decorator test
* Current classification property decorator unit test
*
* @author Tuna Aksoy
* @since 3.0
*/
public class ClassificationPropertyDecoratorTest extends BaseUnitTest
@RunWith(MockitoJUnitRunner.class)
public class CurrentClassificationPropertyDecoratorUnitTest
{
/** Constants */
private static final String ID = "id";
private static final String LABEL = "label";
/** Classification property decorator */
private ClassificationPropertyDecorator decorator;
/** Current classification property decorator */
private @InjectMocks CurrentClassificationPropertyDecorator decorator = new CurrentClassificationPropertyDecorator();
/** Mocked classification scheme service */
private @Mock ClassificationSchemeService mockedClassificationSchemeService;
/**
* @see org.alfresco.module.org_alfresco_module_rm.test.util.BaseUnitTest#before()
*/
@Before
@Override
public void before() throws Exception
{
super.before();
decorator = new ClassificationPropertyDecorator();
decorator.setClassificationSchemeService(mockedClassificationSchemeService);
}
/**
* Given that no classification id is supplied
* When decorated
* Then an {@link IllegalArgumentException} is thrown
*/
@Test
@Test(expected = IllegalArgumentException.class)
public void testDecoratorWithoutClassificationId()
{
exception.expect(IllegalArgumentException.class);
decorator.decorate(null, null, null);
}