/******************************************************************************* * Mission Control Technologies, Copyright (c) 2009-2012, United States Government * as represented by the Administrator of the National Aeronautics and Space * Administration. All rights reserved. * * The MCT platform is licensed 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. * * MCT includes source code licensed under additional open source licenses. See * the MCT Open Source Licenses file included with this distribution or the About * MCT Licenses dialog available at runtime from the MCT Help menu for additional * information. *******************************************************************************/ package gov.nasa.arc.mct.defaults.view; import gov.nasa.arc.mct.components.AbstractComponent; import gov.nasa.arc.mct.gui.View; import gov.nasa.arc.mct.services.component.ComponentTypeInfo; import gov.nasa.arc.mct.services.component.TypeInfo; import gov.nasa.arc.mct.services.component.ViewInfo; import gov.nasa.arc.mct.services.component.ViewType; import java.util.HashSet; import java.util.Set; import javax.swing.Icon; import org.testng.Assert; import org.testng.annotations.Test; public class TestDefaultViewProvider { @Test public void testGetViews() { // Ensure platform is providing necessary view types Set<ViewType> viewTypes = new HashSet<ViewType>(); for (ViewInfo vi : new DefaultViewProvider().getViews("component")) { viewTypes.add(vi.getViewType()); } // Needed for browse trees, directory areas Assert.assertTrue(viewTypes.contains(ViewType.NODE)); // Needed as top-level housing Assert.assertTrue(viewTypes.contains(ViewType.LAYOUT)); // Needed for inspecting selections Assert.assertTrue(viewTypes.contains(ViewType.INSPECTOR)); // Needed for adding common view switchers to custom inspectors Assert.assertTrue(viewTypes.contains(ViewType.VIEW_SWITCHER)); // Needed for browsing Assert.assertTrue(viewTypes.contains(ViewType.NAVIGATOR)); // Needed for titling inspectors Assert.assertTrue(viewTypes.contains(ViewType.TITLE)); // Needed for containing inspectors Assert.assertTrue(viewTypes.contains(ViewType.RIGHT)); } @Test public void testGetAsset() { // Verify provider is giving default icons DefaultViewProvider provider = new DefaultViewProvider(); TypeInfo<?> info; // Should give icons for any kind of type info (esp components and views) info = new ComponentTypeInfo("","",AbstractComponent.class); Assert.assertNotNull(provider.getAsset(info, Icon.class)); info = new ViewInfo(View.class,"",ViewType.OBJECT); Assert.assertNotNull(provider.getAsset(info, Icon.class)); info = new TypeInfo<TestDefaultViewProvider>(TestDefaultViewProvider.class){}; Assert.assertNotNull(provider.getAsset(info, Icon.class)); // Should not give anything other than icons Assert.assertNull(provider.getAsset(info, getClass())); } }