/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.jackrabbit.test.api; import org.apache.jackrabbit.test.AbstractJCRTest; import javax.jcr.Property; import javax.jcr.Value; import javax.jcr.RepositoryException; import javax.jcr.Node; import javax.jcr.PathNotFoundException; import java.util.GregorianCalendar; import java.util.Calendar; /** * Tests the various {@link Property#setValue(Value)} methods. * <p> * Configuration requirements: * <p> * The node at {@link #testRoot} must allow a * child node of type {@link #testNodeType} with name {@link #nodeName1}. The * node type {@link #testNodeType} must define a single value date property * with name {@link #propertyName1}. * */ public class SetValueDateTest extends AbstractJCRTest { /** * The date value */ private Value value; /** * The node with the date property */ private Node node; /** * The date property */ private Property property1; protected void setUp() throws Exception { super.setUp(); // initialize some date value value = superuser.getValueFactory().createValue(GregorianCalendar.getInstance()); // create a new node under the testRootNode node = testRootNode.addNode(nodeName1, testNodeType); // create a new single-value property and save it Calendar initialValue = GregorianCalendar.getInstance(); initialValue.setTimeInMillis(0); property1 = node.setProperty(propertyName1, initialValue); superuser.save(); } protected void tearDown() throws Exception { value = null; node = null; property1 = null; super.tearDown(); } /** * Test the persistence of a property modified with an DateValues parameter * and saved from the Session */ public void testDateSession() throws RepositoryException { property1.setValue(value); superuser.save(); assertEquals("Date node property not saved", value, property1.getValue()); } /** * Test the persistence of a property modified with an date parameter and * saved from the parent Node */ public void testDateParent() throws RepositoryException { property1.setValue(value.getDate()); node.save(); Value orig = superuser.getValueFactory().createValue(value.getDate()); assertEquals("Date node property not saved", orig, property1.getValue()); } /** * Test the deletion of a property by assigning it a null value, saved from * the parent Node */ public void testRemoveDateParent() throws RepositoryException { property1.setValue((Value) null); node.save(); try { node.getProperty(propertyName1); fail("The property should not exist anymore, as a null Value has been assigned"); } catch (PathNotFoundException e) { //success : the property has been deleted by assigning it a null value } } /** * Test the deletion of a property by assigning it a null value, saved from * the Session */ public void testRemoveCalendarSession() throws RepositoryException { property1.setValue((Calendar) null); superuser.save(); try { node.getProperty(propertyName1); fail("The property should not exist anymore, as a null Calendar has been assigned"); } catch (PathNotFoundException e) { //success : the property has been deleted by assigning it a null value } } }