am 5becdc32: am a970bf52: Merge change I34f51342 into eclair

Merge commit '5becdc32c899f1e8031f5a694c064cb559a8fc88' into eclair-mr2-plus-aosp

* commit '5becdc32c899f1e8031f5a694c064cb559a8fc88':
  Fix the layoutlib test to run from adt-tests.
This commit is contained in:
Xavier Ducrohet
2009-10-05 16:09:29 -07:00
committed by Android Git Automerger
6 changed files with 53 additions and 67 deletions

View File

@ -73,6 +73,48 @@ public class BridgeTest extends TestCase {
} }
} }
/**
* Mock implementation of {@link IStyleResourceValue}.
*/
private static class StyleResourceValueMock extends ResourceValue
implements IStyleResourceValue {
private String mParentStyle = null;
private HashMap<String, IResourceValue> mItems = new HashMap<String, IResourceValue>();
StyleResourceValueMock(String name) {
super(name);
}
StyleResourceValueMock(String name, String parentStyle) {
super(name);
mParentStyle = parentStyle;
}
public String getParentStyle() {
return mParentStyle;
}
public IResourceValue findItem(String name) {
return mItems.get(name);
}
public void addItem(IResourceValue value) {
mItems.put(value.getName(), value);
}
@Override
public void replaceWith(ResourceValue value) {
super.replaceWith(value);
if (value instanceof StyleResourceValueMock) {
mItems.clear();
mItems.putAll(((StyleResourceValueMock)value).mItems);
}
}
}
public void testComputeLayout() throws Exception { public void testComputeLayout() throws Exception {
TestParser parser = new TestParser(); TestParser parser = new TestParser();
@ -88,8 +130,10 @@ public class BridgeTest extends TestCase {
// FIXME need a dummy font for the tests! // FIXME need a dummy font for the tests!
ILayoutResult result = mBridge.computeLayout(parser, new Integer(1) /* projectKey */, ILayoutResult result = mBridge.computeLayout(parser, new Integer(1) /* projectKey */,
screenWidth, screenHeight, screenWidth, screenHeight, false /* full render */,
"Theme", projectResources, frameworkResources, null, null); 160, 160f, 160f,
"Theme", false /* is project theme */,
projectResources, frameworkResources, null, null);
display(result.getRootView(), ""); display(result.getRootView(), "");
} }
@ -191,7 +235,7 @@ public class BridgeTest extends TestCase {
* a style item value. If the number of string in the array is not even, an exception is thrown. * a style item value. If the number of string in the array is not even, an exception is thrown.
*/ */
private IStyleResourceValue createStyle(String styleName, String... items) { private IStyleResourceValue createStyle(String styleName, String... items) {
StyleResourceValue value = new StyleResourceValue(styleName); StyleResourceValueMock value = new StyleResourceValueMock(styleName);
if (items.length % 3 == 0) { if (items.length % 3 == 0) {
for (int i = 0 ; i < items.length;) { for (int i = 0 ; i < items.length;) {
@ -220,8 +264,10 @@ public class BridgeTest extends TestCase {
// FIXME need a dummy font for the tests! // FIXME need a dummy font for the tests!
ILayoutResult result = mBridge.computeLayout(parser, new Integer(1) /* projectKey */, ILayoutResult result = mBridge.computeLayout(parser, new Integer(1) /* projectKey */,
screenWidth, screenHeight, screenWidth, screenHeight, false /* full render */,
"Theme", projectResources, frameworkResources, null, null); 160, 160f, 160f,
"Theme", false /* is project theme */,
projectResources, frameworkResources, null, null);
display(result.getRootView(), ""); display(result.getRootView(), "");
} }

View File

@ -41,7 +41,7 @@ public class BridgeXmlBlockParserTest extends TestCase {
@Override @Override
protected void setUp() throws Exception { protected void setUp() throws Exception {
super.setUp(); super.setUp();
URL url = this.getClass().getClassLoader().getResource("data/layout1.xml"); URL url = this.getClass().getClassLoader().getResource("layout1.xml");
mXmlPath = url.getFile(); mXmlPath = url.getFile();
mDoc = getXmlDocument(mXmlPath); mDoc = getXmlDocument(mXmlPath);
} }

View File

@ -12,7 +12,7 @@ public class NinePatchTest extends TestCase {
@Override @Override
protected void setUp() throws Exception { protected void setUp() throws Exception {
URL url = this.getClass().getClassLoader().getResource("data/button.9.png"); URL url = this.getClass().getClassLoader().getResource("button.9.png");
mPatch = NinePatch.load(url, false /* convert */); mPatch = NinePatch.load(url, false /* convert */);
} }

View File

@ -1,60 +0,0 @@
/*
* Copyright (C) 2008 The Android Open Source Project
*
* 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.
*/
package com.android.layoutlib.bridge;
import com.android.layoutlib.api.IResourceValue;
import com.android.layoutlib.api.IStyleResourceValue;
import java.util.HashMap;
class StyleResourceValue extends ResourceValue implements IStyleResourceValue {
private String mParentStyle = null;
private HashMap<String, IResourceValue> mItems = new HashMap<String, IResourceValue>();
StyleResourceValue(String name) {
super(name);
}
StyleResourceValue(String name, String parentStyle) {
super(name);
mParentStyle = parentStyle;
}
public String getParentStyle() {
return mParentStyle;
}
public IResourceValue findItem(String name) {
return mItems.get(name);
}
public void addItem(IResourceValue value) {
mItems.put(value.getName(), value);
}
@Override
public void replaceWith(ResourceValue value) {
super.replaceWith(value);
if (value instanceof StyleResourceValue) {
mItems.clear();
mItems.putAll(((StyleResourceValue)value).mItems);
}
}
}

View File

Before

Width:  |  Height:  |  Size: 3.7 KiB

After

Width:  |  Height:  |  Size: 3.7 KiB