aboutsummaryrefslogtreecommitdiffstats
path: root/tests/src/org/lineageos/tests/util/ColorUtilTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'tests/src/org/lineageos/tests/util/ColorUtilTest.java')
-rw-r--r--tests/src/org/lineageos/tests/util/ColorUtilTest.java123
1 files changed, 123 insertions, 0 deletions
diff --git a/tests/src/org/lineageos/tests/util/ColorUtilTest.java b/tests/src/org/lineageos/tests/util/ColorUtilTest.java
new file mode 100644
index 00000000..9ce91f96
--- /dev/null
+++ b/tests/src/org/lineageos/tests/util/ColorUtilTest.java
@@ -0,0 +1,123 @@
+/**
+ * Copyright (c) 2016, The CyanogenMod 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 org.lineageos.tests.util;
+
+import android.graphics.Bitmap;
+import android.graphics.Canvas;
+import android.graphics.Color;
+import android.graphics.Paint;
+import android.graphics.drawable.BitmapDrawable;
+import android.graphics.drawable.ColorDrawable;
+import android.test.AndroidTestCase;
+import lineageos.util.ColorUtils;
+import org.mockito.Mockito;
+import org.mockito.invocation.InvocationOnMock;
+import org.mockito.stubbing.Answer;
+
+public class ColorUtilTest extends AndroidTestCase {
+ private ColorUtils mColorUtils;
+
+ @Override
+ protected void setUp() throws Exception {
+ super.setUp();
+ mColorUtils = new ColorUtils();
+ }
+
+ public void testDropAlpha() {
+ // With pre-existing alpha
+ int color = 0xBBCCDD;
+ int alpha = 0xAA000000;
+ int result = mColorUtils.dropAlpha(color | alpha);
+ // Assert alpha was removed
+ assertEquals(Color.alpha(result), 0);
+ // Ensure color is preserved
+ assertEquals(result & color, color);
+
+ // Without pre-existing alpha
+ color = Color.argb(0, 100, 200 ,300);
+ result = mColorUtils.dropAlpha(color);
+ // Assert alpha was removed
+ assertEquals(Color.alpha(result), 0);
+ // Ensure color is preserved
+ assertEquals(result, color);
+ }
+
+ public void testGenerateAlertColorFromDrawable() {
+ // Test null drawable
+ int color = mColorUtils.generateAlertColorFromDrawable(null);
+ assertEquals(color, Color.BLACK);
+
+ Bitmap bitmap = Bitmap.createBitmap(10, 10, Bitmap.Config.ARGB_8888);
+ BitmapDrawable bitmapDrawable = new BitmapDrawable(bitmap);
+ bitmapDrawable.setBounds(0, 0, 10, 10);
+ Canvas canvas = new Canvas(bitmap);
+ canvas.drawColor(Color.RED);
+
+ // Test fully red bitmap
+ color = mColorUtils.generateAlertColorFromDrawable(bitmapDrawable);
+ assertEquals(color, Color.RED);
+ color = mColorUtils.generateAlertColorFromDrawable(
+ getColorDrawableFromBitmapDrawable(bitmapDrawable));
+ assertEquals(color, Color.RED);
+
+ // Test blue/red bitmap with blue dominating
+ Paint p = new Paint();
+ p.setColor(Color.BLUE);
+ p.setStyle(Paint.Style.FILL_AND_STROKE);
+ canvas.drawRect(0, 0, 8, 8, p);
+ color = mColorUtils.generateAlertColorFromDrawable(bitmapDrawable);
+ assertEquals(color, Color.BLUE);
+ color = mColorUtils.generateAlertColorFromDrawable(
+ getColorDrawableFromBitmapDrawable(bitmapDrawable));
+ assertEquals(color, Color.BLUE);
+
+ // Test large white + small blue scenario
+ canvas.drawColor(Color.WHITE);
+ canvas.drawRect(0, 0, 2, 2, p);
+ color = mColorUtils.generateAlertColorFromDrawable(bitmapDrawable);
+ assertEquals(color, Color.BLUE);
+ color = mColorUtils.generateAlertColorFromDrawable(
+ getColorDrawableFromBitmapDrawable(bitmapDrawable));
+ assertEquals(color, Color.BLUE);
+
+ // Test large white + small black scenario
+ canvas.drawColor(Color.WHITE);
+ p.setColor(Color.BLACK);
+ canvas.drawRect(0, 0, 2, 2, p);
+ color = mColorUtils.generateAlertColorFromDrawable(bitmapDrawable);
+ assertEquals(color, Color.WHITE);
+ color = mColorUtils.generateAlertColorFromDrawable(
+ getColorDrawableFromBitmapDrawable(bitmapDrawable));
+ assertEquals(color, Color.WHITE);
+
+ assertEquals(bitmap.isRecycled(), false);
+ bitmap.recycle();
+ }
+
+ private ColorDrawable getColorDrawableFromBitmapDrawable(final BitmapDrawable bitmapDrawable) {
+ ColorDrawable colorDrawable = Mockito.mock(ColorDrawable.class);
+ Mockito.doAnswer(new Answer() {
+ @Override
+ public Object answer(InvocationOnMock invocation) throws Throwable {
+ Canvas canvas = (Canvas) invocation.getArguments()[0];
+ bitmapDrawable.draw(canvas);
+ return null;
+ }
+ }).when(colorDrawable).draw(Mockito.any(Canvas.class));
+ return colorDrawable;
+ }
+}