View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements.  See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache License, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License.  You may obtain a copy of the License at
8    *
9    *      http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  package org.apache.log4j.chainsaw;
18  
19  import com.thoughtworks.xstream.XStream;
20  import com.thoughtworks.xstream.io.xml.DomDriver;
21  
22  import junit.framework.TestCase;
23  
24  public class LogPanelPreferenceModelTest extends TestCase {
25  
26      public void testLogPanelPreferenceModelSerialization() throws Exception {
27          LogPanelPreferenceModel model = new LogPanelPreferenceModel();
28          
29          
30          /**
31           * First modify the model from it's default state so we know we're actually storing
32           * something 'different' for deserialization tests
33           */
34          
35          model.setLevelIcons(!model.isLevelIcons());
36          model.setWrapMessage(!model.isWrapMessage());
37          model.setDateFormatPattern("yyyyDDmm");
38          model.setLoggerPrecision("FATAL");
39          model.setLogTreePanelVisible(!model.isLogTreePanelVisible());
40          model.setScrollToBottom(model.isScrollToBottom());
41          model.setToolTips(!model.isToolTips());
42          
43          XStream stream = new XStream(new DomDriver());
44          String xml = stream.toXML(model);
45  //        System.out.println(xml);
46          
47          LogPanelPreferenceModel restored = (LogPanelPreferenceModel) stream.fromXML(xml);
48          
49          assertEquals(model.isLevelIcons(), restored.isLevelIcons());
50          assertEquals(model.getDateFormatPattern(), restored.getDateFormatPattern());
51          assertEquals(model.getLoggerPrecision(), restored.getLoggerPrecision());
52          assertEquals(model.isLogTreePanelVisible(), restored.isLogTreePanelVisible());
53          assertEquals(model.isScrollToBottom(), restored.isScrollToBottom());
54          assertEquals(model.isToolTips(), restored.isToolTips());
55          
56          
57          
58      }
59  }