| /* |
| * Copyright (C) 2018 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.settings.homepage.contextualcards; |
| |
| import static com.google.common.truth.Truth.assertThat; |
| |
| import android.content.ContentValues; |
| import android.content.Context; |
| import android.database.Cursor; |
| import android.database.sqlite.SQLiteDatabase; |
| |
| import com.android.settings.intelligence.ContextualCardProto; |
| |
| import org.junit.After; |
| import org.junit.Before; |
| import org.junit.Test; |
| import org.junit.runner.RunWith; |
| import org.robolectric.RobolectricTestRunner; |
| import org.robolectric.RuntimeEnvironment; |
| |
| import java.util.ArrayList; |
| import java.util.List; |
| |
| @RunWith(RobolectricTestRunner.class) |
| public class CardDatabaseHelperTest { |
| |
| private Context mContext; |
| private CardDatabaseHelper mCardDatabaseHelper; |
| private SQLiteDatabase mDatabase; |
| |
| @Before |
| public void setUp() { |
| mContext = RuntimeEnvironment.application; |
| mCardDatabaseHelper = CardDatabaseHelper.getInstance(mContext); |
| mDatabase = mCardDatabaseHelper.getWritableDatabase(); |
| } |
| |
| @After |
| public void cleanUp() { |
| CardDatabaseHelper.getInstance(mContext).close(); |
| CardDatabaseHelper.sCardDatabaseHelper = null; |
| } |
| |
| @Test |
| public void testDatabaseSchema() { |
| final Cursor cursor = mDatabase.rawQuery("SELECT * FROM " + CardDatabaseHelper.CARD_TABLE, |
| null); |
| final String[] columnNames = cursor.getColumnNames(); |
| |
| final String[] expectedNames = { |
| CardDatabaseHelper.CardColumns.NAME, |
| CardDatabaseHelper.CardColumns.TYPE, |
| CardDatabaseHelper.CardColumns.SCORE, |
| CardDatabaseHelper.CardColumns.SLICE_URI, |
| CardDatabaseHelper.CardColumns.CATEGORY, |
| CardDatabaseHelper.CardColumns.LOCALIZED_TO_LOCALE, |
| CardDatabaseHelper.CardColumns.PACKAGE_NAME, |
| CardDatabaseHelper.CardColumns.APP_VERSION, |
| CardDatabaseHelper.CardColumns.TITLE_RES_NAME, |
| CardDatabaseHelper.CardColumns.TITLE_TEXT, |
| CardDatabaseHelper.CardColumns.SUMMARY_RES_NAME, |
| CardDatabaseHelper.CardColumns.SUMMARY_TEXT, |
| CardDatabaseHelper.CardColumns.ICON_RES_NAME, |
| CardDatabaseHelper.CardColumns.ICON_RES_ID, |
| CardDatabaseHelper.CardColumns.CARD_ACTION, |
| CardDatabaseHelper.CardColumns.EXPIRE_TIME_MS, |
| CardDatabaseHelper.CardColumns.SUPPORT_HALF_WIDTH, |
| CardDatabaseHelper.CardColumns.CARD_DISMISSED, |
| }; |
| |
| assertThat(columnNames).isEqualTo(expectedNames); |
| cursor.close(); |
| } |
| |
| @Test |
| public void getContextualCards_shouldSortByScore() { |
| insertFakeCard(mDatabase, "card1", 1, "uri1"); |
| insertFakeCard(mDatabase, "card2", 0, "uri2"); |
| insertFakeCard(mDatabase, "card3", 10, "uri3"); |
| // Should sort as 3,1,2 |
| try (final Cursor cursor = CardDatabaseHelper.getInstance(mContext).getContextualCards()) { |
| assertThat(cursor.getCount()).isEqualTo(3); |
| final List<ContextualCard> cards = new ArrayList<>(); |
| for (cursor.moveToFirst(); !cursor.isAfterLast(); cursor.moveToNext()) { |
| cards.add(new ContextualCard(cursor)); |
| } |
| assertThat(cards.get(0).getName()).isEqualTo("card3"); |
| assertThat(cards.get(1).getName()).isEqualTo("card1"); |
| assertThat(cards.get(2).getName()).isEqualTo("card2"); |
| } |
| } |
| |
| private static void insertFakeCard(SQLiteDatabase db, String name, double score, String uri) { |
| final ContentValues value = new ContentValues(); |
| value.put(CardDatabaseHelper.CardColumns.NAME, name); |
| value.put(CardDatabaseHelper.CardColumns.SCORE, score); |
| value.put(CardDatabaseHelper.CardColumns.SLICE_URI, uri); |
| |
| value.put(CardDatabaseHelper.CardColumns.TYPE, ContextualCard.CardType.SLICE); |
| value.put(CardDatabaseHelper.CardColumns.CATEGORY, |
| ContextualCardProto.ContextualCard.Category.DEFAULT.getNumber()); |
| value.put(CardDatabaseHelper.CardColumns.PACKAGE_NAME, |
| RuntimeEnvironment.application.getPackageName()); |
| value.put(CardDatabaseHelper.CardColumns.APP_VERSION, 1); |
| |
| db.insert(CardDatabaseHelper.CARD_TABLE, null, value); |
| } |
| } |