/************************************************************** * * 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 ifc.document; import lib.MultiPropertyTest; import com.sun.star.util.DateTime; /** * Testing com.sun.star.document.DocumentInfo * service properties :

*

* Properties testing is automated by lib.MultiPropertyTest. * @see com.sun.star.document.DocumentInfo */ public class _DocumentInfo extends MultiPropertyTest { /** * Overrides compare method. Can compare DateTime * structures. */ protected boolean compare(Object ob1, Object ob2) { if (ob1 instanceof DateTime && ob2 instanceof DateTime) { DateTime dt1 = (DateTime)ob1; DateTime dt2 = (DateTime)ob2; return dt1.Year == dt2.Year && dt1.Month == dt2.Month && dt1.Day == dt2.Day && dt1.Hours == dt2.Hours && dt1.Minutes == dt2.Minutes && dt1.Seconds == dt2.Seconds && dt1.HundredthSeconds == dt2.HundredthSeconds; } else { return super.compare(ob1, ob2); } } /** * Prints DateTime. */ protected String toString(Object obj) { if (obj instanceof DateTime) { DateTime dt = (DateTime)obj; return dt.Year + ":" + dt.Month + ":" + dt.Day + ":" + dt.Hours + ":" + dt.Minutes + ":" + dt.Seconds + ":" + dt.HundredthSeconds; } else { return super.toString(obj); } } /** * Tester for properties with DateTime type which * creates new structure if old property value was null. */ class DatePropertyTester extends PropertyTester { protected Object getNewValue(String propName, Object oldValue) { if (oldValue == null || util.utils.isVoid(oldValue)) { DateTime dt = new DateTime(); dt.Year = 2000; dt.Month = 10; dt.Day = 18; dt.Hours = 19; dt.Minutes = 41; return dt; } else { return super.getNewValue(propName, oldValue); } } } /** * Can be void. */ public void _PrintDate() { testProperty("PrintDate", new DatePropertyTester()); } /** * Can be void. */ public void _TemplateDate() { testProperty("TemplateDate", new DatePropertyTester()); } /** * Can be void. */ public void _ModifyDate() { testProperty("ModifyDate", new DatePropertyTester()); } }