blob: bf3c3d30c68f0d99a0cff882f585293ec7a0b89e [file] [log] [blame]
/*
* Copyright (C) 2011 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.tools.lint.checks;
import com.android.tools.lint.detector.api.Detector;
@SuppressWarnings("javadoc")
public class InefficientWeightDetectorTest extends AbstractCheckTest {
@Override
protected Detector getDetector() {
return new InefficientWeightDetector();
}
public void testWeights() throws Exception {
assertEquals(
"res/layout/inefficient_weight.xml:3: Error: Wrong orientation? No orientation specified, and the default is horizontal, yet this layout has multiple children where at least one has layout_width=\"match_parent\" [Orientation]\n" +
"<LinearLayout\n" +
"^\n" +
"res/layout/inefficient_weight.xml:10: Warning: Use a layout_width of 0dp instead of match_parent for better performance [InefficientWeight]\n" +
" android:layout_width=\"match_parent\"\n" +
" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n" +
"res/layout/inefficient_weight.xml:24: Warning: Use a layout_height of 0dp instead of wrap_content for better performance [InefficientWeight]\n" +
" android:layout_height=\"wrap_content\"\n" +
" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n" +
"1 errors, 2 warnings\n",
lintFiles("res/layout/inefficient_weight.xml"));
}
public void testWeights2() throws Exception {
assertEquals(
"res/layout/nested_weights.xml:23: Warning: Nested weights are bad for performance [NestedWeights]\n" +
" android:layout_weight=\"1\"\n" +
" ~~~~~~~~~~~~~~~~~~~~~~~~~\n" +
"0 errors, 1 warnings\n" +
"",
lintFiles("res/layout/nested_weights.xml"));
}
public void testWeights3() throws Exception {
assertEquals(
"res/layout/baseline_weights.xml:2: Warning: Set android:baselineAligned=\"false\" on this element for better performance [DisableBaselineAlignment]\n" +
"<LinearLayout xmlns:android=\"http://schemas.android.com/apk/res/android\"\n" +
"^\n" +
"0 errors, 1 warnings\n" +
"",
lintFiles("res/layout/baseline_weights.xml"));
}
public void testWeights4() throws Exception {
assertEquals(
"res/layout/activity_item_two_pane.xml:1: Warning: Set android:baselineAligned=\"false\" on this element for better performance [DisableBaselineAlignment]\n" +
"<LinearLayout xmlns:android=\"http://schemas.android.com/apk/res/android\"\n" +
"^\n" +
"0 errors, 1 warnings\n",
lintFiles("res/layout/activity_item_two_pane.xml"));
}
public void testNoVerticalWeights3() throws Exception {
// Orientation=vertical
assertEquals(
"No warnings.",
lintFiles("res/layout/baseline_weights2.xml"));
}
public void testNoVerticalWeights4() throws Exception {
// Orientation not specified ==> horizontal
assertEquals(
"res/layout/baseline_weights3.xml:2: Warning: Set android:baselineAligned=\"false\" on this element for better performance [DisableBaselineAlignment]\n" +
"<LinearLayout xmlns:android=\"http://schemas.android.com/apk/res/android\"\n" +
"^\n" +
"0 errors, 1 warnings\n" +
"",
lintFiles("res/layout/baseline_weights3.xml"));
}
public void testSuppressed() throws Exception {
assertEquals(
"No warnings.",
lintFiles("res/layout/inefficient_weight2.xml"));
}
public void testNestedWeights() throws Exception {
// Regression test for http://code.google.com/p/android/issues/detail?id=22889
// (Comment 8)
assertEquals(
"No warnings.",
lintFiles("res/layout/nested_weights2.xml"));
}
public void testWrong0Dp() throws Exception {
assertEquals(
"res/layout/wrong0dp.xml:19: Error: Suspicious size: this will make the view invisible, should be used with layout_weight [Suspicious0dp]\n" +
" android:layout_width=\"0dp\"\n" +
" ~~~~~~~~~~~~~~~~~~~~~~~~~~\n" +
"res/layout/wrong0dp.xml:25: Error: Suspicious size: this will make the view invisible, should be used with layout_weight [Suspicious0dp]\n" +
" android:layout_height=\"0dp\"\n" +
" ~~~~~~~~~~~~~~~~~~~~~~~~~~~\n" +
"res/layout/wrong0dp.xml:34: Error: Suspicious size: this will make the view invisible, probably intended for layout_height [Suspicious0dp]\n" +
" android:layout_width=\"0dp\"\n" +
" ~~~~~~~~~~~~~~~~~~~~~~~~~~\n" +
"res/layout/wrong0dp.xml:67: Error: Suspicious size: this will make the view invisible, probably intended for layout_width [Suspicious0dp]\n" +
" android:layout_height=\"0dp\"\n" +
" ~~~~~~~~~~~~~~~~~~~~~~~~~~~\n" +
"res/layout/wrong0dp.xml:90: Error: Suspicious size: this will make the view invisible, probably intended for layout_width [Suspicious0dp]\n" +
" android:layout_height=\"0dp\"\n" +
" ~~~~~~~~~~~~~~~~~~~~~~~~~~~\n" +
"5 errors, 0 warnings\n",
lintFiles("res/layout/wrong0dp.xml"));
}
public void testOrientation() throws Exception {
assertEquals(""
+ "res/layout/orientation.xml:52: Error: No orientation specified, and the default is horizontal. This is a common source of bugs when children are added dynamically. [Orientation]\n"
+ " <LinearLayout\n"
+ " ^\n"
+ "1 errors, 0 warnings\n",
lintFiles("res/layout/orientation.xml"));
}
public void testIncremental1() throws Exception {
assertEquals(""
+ "res/layout/orientation2.xml:5: Error: No orientation specified, and the default is horizontal. This is a common source of bugs when children are added dynamically. [Orientation]\n"
+ " <LinearLayout\n"
+ " ^\n"
+ "1 errors, 0 warnings\n",
lintProjectIncrementally("res/layout/orientation2.xml",
"res/layout/orientation2.xml"));
}
public void testIncremental2() throws Exception {
assertEquals("No warnings.",
lintProjectIncrementally("res/layout/orientation2.xml",
"res/layout/orientation2.xml",
"res/values/styles-inherited-orientation.xml"));
}
public void testIncremental3() throws Exception {
assertEquals("No warnings.",
lintProjectIncrementally("res/layout/orientation2.xml",
"res/layout/orientation2.xml",
"res/values/styles-orientation.xml"));
}
public void testIncremental4() throws Exception {
assertEquals(""
+ "res/layout/inefficient_weight3.xml:9: Warning: Use a layout_height of 0dp instead of (undefined) for better performance [InefficientWeight]\n"
+ " <Button\n"
+ " ^\n"
+ "0 errors, 1 warnings\n",
lintProjectIncrementally(
"res/layout/inefficient_weight3.xml",
"res/layout/inefficient_weight3.xml"));
}
public void testIncremental5() throws Exception {
assertEquals("No warnings.",
lintProjectIncrementally(
"res/layout/inefficient_weight3.xml",
"res/layout/inefficient_weight3.xml",
"res/values/styles-orientation.xml"));
}
public void testIncremental6() throws Exception {
assertEquals(""
+ "res/layout/inefficient_weight3.xml:9: Warning: Use a layout_height of 0dp instead of wrap_content for better performance [InefficientWeight]\n"
+ " <Button\n"
+ " ^\n"
+ "0 errors, 1 warnings\n",
lintProjectIncrementally(
"res/layout/inefficient_weight3.xml",
"res/layout/inefficient_weight3.xml",
"res/values/styles-inherited-orientation.xml"));
}
}