19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
171a44d5dcabc18cd5ef111f732ccff91683a1a093Neal Nguyenpackage android.database;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport junit.framework.Assert;
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.ContentValues;
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.Context;
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.database.Cursor;
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.database.sqlite.SQLiteDatabase;
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.provider.Contacts;
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.provider.Contacts.People;
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.test.PerformanceTestCase;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.test.TestCase;
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.File;
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.util.Random;
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Database Performance Tests
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
385a05c23f3d6a1a895bf5917aacd8bd9a5302ba00Jeff Brown@SuppressWarnings("deprecation")
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class DatabasePerformanceTests {
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static String[] children() {
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return new String[] {
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            ContactReadingTest1.class.getName(),
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf1Test.class.getName(),
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf2Test.class.getName(),
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf3Test.class.getName(),
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf4Test.class.getName(),
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf5Test.class.getName(),
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf6Test.class.getName(),
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf7Test.class.getName(),
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf8Test.class.getName(),
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf9Test.class.getName(),
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf10Test.class.getName(),
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf11Test.class.getName(),
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf12Test.class.getName(),
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf13Test.class.getName(),
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf14Test.class.getName(),
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf15Test.class.getName(),
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf16Test.class.getName(),
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf17Test.class.getName(),
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf18Test.class.getName(),
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf19Test.class.getName(),
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf20Test.class.getName(),
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf21Test.class.getName(),
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf22Test.class.getName(),
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf23Test.class.getName(),
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf24Test.class.getName(),
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf25Test.class.getName(),
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf26Test.class.getName(),
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf27Test.class.getName(),
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf28Test.class.getName(),
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf29Test.class.getName(),
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf30Test.class.getName(),
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Perf31Test.class.getName(),
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            };
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static abstract class PerformanceBase implements TestCase,
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            PerformanceTestCase {
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        protected static final int CURRENT_DATABASE_VERSION = 42;
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        protected SQLiteDatabase mDatabase;
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        protected File mDatabaseFile;
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        protected Context mContext;
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mContext = c;
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabaseFile = new File("/tmp", "perf_database_test.db");
889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (mDatabaseFile.exists()) {
899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabaseFile.delete();
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase = SQLiteDatabase.openOrCreateDatabase(mDatabaseFile.getPath(), null);
929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Assert.assertTrue(mDatabase != null);
939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.setVersion(CURRENT_DATABASE_VERSION);
949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void tearDown() {
979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.close();
989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabaseFile.delete();
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean isPerformanceOnly() {
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return true;
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // These test can only be run once.
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public int startPerformance(Intermediates intermediates) {
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return 0;
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public String numberName(int number) {
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            String result = "";
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (number >= 1000) {
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                result += numberName((number / 1000)) + " thousand";
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                number = (number % 1000);
1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if (number > 0) result += " ";
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (number >= 100) {
1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                result += ONES[(number / 100)] + " hundred";
1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                number = (number % 100);
1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if (number > 0) result += " ";
1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (number >= 20) {
1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                result += TENS[(number / 10)];
1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                number = (number % 10);
1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if (number > 0) result += " ";
1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (number > 0) {
1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                result += ONES[number];
1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return result;
1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Test reading all contact data.
1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class ContactReadingTest1 implements TestCase, PerformanceTestCase {
1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] PEOPLE_PROJECTION = new String[] {
1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project               Contacts.People._ID, // 0
1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project               Contacts.People.PRIMARY_PHONE_ID, // 1
1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project               Contacts.People.TYPE, // 2
1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project               Contacts.People.NUMBER, // 3
1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project               Contacts.People.LABEL, // 4
1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project               Contacts.People.NAME, // 5
1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project               Contacts.People.PRESENCE_STATUS, // 6
1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        };
1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private Cursor mCursor;
1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCursor = c.getContentResolver().query(People.CONTENT_URI, PEOPLE_PROJECTION, null,
1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    null, People.DEFAULT_SORT_ORDER);
1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void tearDown() {
1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCursor.close();
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean isPerformanceOnly() {
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return true;
1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public int startPerformance(Intermediates intermediates) {
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // This test can only be run once.
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return 0;
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            while (mCursor.moveToNext()) {
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                // Read out all of the data
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mCursor.getLong(0);
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mCursor.getLong(1);
1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mCursor.getLong(2);
1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mCursor.getString(3);
1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mCursor.getString(4);
1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mCursor.getString(5);
1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mCursor.getLong(6);
1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Test 1000 inserts
1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf1Test extends PerformanceBase {
1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 1000;
1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] statements = new String[SIZE];
2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                statements[i] =
2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        "INSERT INTO t1 VALUES(" + i + "," + r + ",'"
2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                + numberName(r) + "')";
2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL(statements[i]);
2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Test 1000 inserts into and indexed table
2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf2Test extends PerformanceBase {
2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 1000;
2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] statements = new String[SIZE];
2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                statements[i] =
2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        "INSERT INTO t1 VALUES(" + i + "," + r + ",'"
2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                + numberName(r) + "')";
2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1c ON t1(c)");
2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL(statements[i]);
2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * 100 SELECTs without an index
2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf3Test extends PerformanceBase {
2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"count(*)", "avg(b)"};
2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "b >= " + lower + " AND b < " + upper;
2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase
2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        .query("t1", COLUMNS, where[i], null, null, null, null);
2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * 100 SELECTs on a string comparison
3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf4Test extends PerformanceBase {
3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"count(*)", "avg(b)"};
3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "c LIKE '" + numberName(i) + "'";
3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase
3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        .query("t1", COLUMNS, where[i], null, null, null, null);
3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * 100 SELECTs with an index
3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf5Test extends PerformanceBase {
3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"count(*)", "avg(b)"};
3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1b ON t1(b)");
3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "b >= " + lower + " AND b < " + upper;
3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase
3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        .query("t1", COLUMNS, where[i], null, null, null, null);
3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  INNER JOIN without an index
3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf6Test extends PerformanceBase {
3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t1.a"};
3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t2(a INTEGER, b INTEGER, c VARCHAR(100))");
3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t2 VALUES(" + i + "," + r + ",'"
4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.query("t1 INNER JOIN t2 ON t1.b = t2.b", COLUMNS, null,
4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    null, null, null, null);
4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  INNER JOIN without an index on one side
4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf7Test extends PerformanceBase {
4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t1.a"};
4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t2(a INTEGER, b INTEGER, c VARCHAR(100))");
4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1b ON t1(b)");
4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
4409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
4459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t2 VALUES(" + i + "," + r + ",'"
4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
4529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.query("t1 INNER JOIN t2 ON t1.b = t2.b", COLUMNS, null,
4539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    null, null, null, null);
4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
4589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  INNER JOIN without an index on one side
4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf8Test extends PerformanceBase {
4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
4639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t1.a"};
4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
4739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t2(a INTEGER, b INTEGER, c VARCHAR(100))");
4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1b ON t1(b)");
4769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
4789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
4819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
4849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
4859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t2 VALUES(" + i + "," + r + ",'"
4869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
4879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.query("t1 INNER JOIN t2 ON t1.c = t2.c", COLUMNS, null,
4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    null, null, null, null);
4949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
4989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  100 SELECTs with subqueries. Subquery is using an index
4999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf9Test extends PerformanceBase {
5029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
5039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t1.a"};
5049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
5069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
5089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
5099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
5109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
5119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
5139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
5149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
5159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t2(a INTEGER, b INTEGER, c VARCHAR(100))");
5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i2b ON t2(b)");
5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
5229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
5269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
5279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t2 VALUES(" + i + "," + r + ",'"
5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
5299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] =
5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        "t1.b IN (SELECT t2.b FROM t2 WHERE t2.b >= " + lower
5369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                + " AND t2.b < " + upper + ")";
5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
5419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
5429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase
5449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        .query("t1", COLUMNS, where[i], null, null, null, null);
5459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  100 SELECTs on string comparison with Index
5519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf10Test extends PerformanceBase {
5549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
5559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"count(*)", "avg(b)"};
5569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
5659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
5669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i3c ON t1(c)");
5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
5699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "c LIKE '" + numberName(i) + "'";
5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase
5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        .query("t1", COLUMNS, where[i], null, null, null, null);
5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  100 SELECTs on integer
5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf11Test extends PerformanceBase {
5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"b"};
5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t1", COLUMNS, null, null, null, null, null);
6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  100 SELECTs on String
6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf12Test extends PerformanceBase {
6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"c"};
6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
6499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t1", COLUMNS, null, null, null, null, null);
6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  100 SELECTs on integer with index
6589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf13Test extends PerformanceBase {
6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
6629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"b"};
6639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
6659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
6669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
6679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
6689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
6709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
6719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1b on t1(b)");
6729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
6759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
6849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t1", COLUMNS, null, null, null, null, null);
6859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  100 SELECTs on String with index
6919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf14Test extends PerformanceBase {
6949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
6959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"c"};
6969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
6989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
6999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
7009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
7019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
7039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
7049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1c ON t1(c)");
7059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
7079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
7089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
7099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
7109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
7139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
7159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
7169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
7179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t1", COLUMNS, null, null, null, null, null);
7189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
7209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  100 SELECTs on String with starts with
7249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf15Test extends PerformanceBase {
7279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 100;
7289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"c"};
7299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
7309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
7329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
7339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
7349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
7359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
7379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
7389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1c ON t1(c)");
7399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
7419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
7429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
7439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
7449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
7479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
7489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "c LIKE '" + numberName(r).substring(0, 1) + "*'";
7499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
7539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
7559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
7569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
7579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase
7589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        .query("t1", COLUMNS, where[i], null, null, null, null);
7599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
7619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  1000  Deletes on an indexed table
7659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf16Test extends PerformanceBase {
7689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 1000;
7699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"c"};
7709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
7729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
7739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
7749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
7759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
7779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
7789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i3c ON t1(c)");
7799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
7819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
7829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
7839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
7849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
7879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
7899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
7909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
7919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.delete("t1", null, null);
7929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
7949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  1000  Deletes
7989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf17Test extends PerformanceBase {
8019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 1000;
8029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"c"};
8039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
8059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
8069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
8079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
8089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
8109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
8119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
8139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
8149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
8159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
8169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
8179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
8199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
8219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
8229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
8239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.delete("t1", null, null);
8249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
8259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
8269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
8279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  1000 DELETE's without an index with where clause
8309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf18Test extends PerformanceBase {
8339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 1000;
8349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
8359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
8379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
8389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
8399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
8409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
8429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
8439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
8459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
8469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
8479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
8489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
8499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
8519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
8529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
8539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "b >= " + lower + " AND b < " + upper;
8549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
8559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
8569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
8589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
8599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
8609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.delete("t1", where[i], null);
8619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
8629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
8639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
8649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  1000 DELETE's with an index with where clause
8679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf19Test extends PerformanceBase {
8709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 1000;
8719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
8729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
8749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
8759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
8769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
8779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
8799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
8809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1b ON t1(b)");
8819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
8839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
8849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
8859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
8869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
8879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
8899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
8909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
8919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "b >= " + lower + " AND b < " + upper;
8929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
8939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
8949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
8969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
8979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
8989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.delete("t1", where[i], null);
8999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
9009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
9019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  1000 update's with an index with where clause
9059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf20Test extends PerformanceBase {
9089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 1000;
9099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
9109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        ContentValues[] mValues = new ContentValues[SIZE];
9119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
9139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
9149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
9159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
9169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
9189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
9199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1b ON t1(b)");
9209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
9229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
9239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
9249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
9259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
9269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
9289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
9309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
9319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "b >= " + lower + " AND b < " + upper;
9329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                ContentValues b = new ContentValues(1);
9339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                b.put("b", upper);
9349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mValues[i] = b;
9359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
9379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
9389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
9409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
9419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
9429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.update("t1", mValues[i], where[i], null);
9439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
9449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
9459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  1000 update's without an index with where clause
9499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf21Test extends PerformanceBase {
9529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 1000;
9539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
9549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        ContentValues[] mValues = new ContentValues[SIZE];
9559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
9579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
9589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
9599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
9609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
9629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100))");
9639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
9659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
9669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t1 VALUES(" + i + "," + r + ",'"
9679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
9689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
9699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
9719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
9739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
9749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "b >= " + lower + " AND b < " + upper;
9759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                ContentValues b = new ContentValues(1);
9769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                b.put("b", upper);
9779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mValues[i] = b;
9789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
9799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
9809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
9829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
9839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
9849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.update("t1", mValues[i], where[i], null);
9859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
9869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
9879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 inserts for an integer
9919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf22Test extends PerformanceBase {
9949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
9959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        ContentValues[] mValues = new ContentValues[SIZE];
9969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
9989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
9999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
10009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
10019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
10039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER)");
10049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
10069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
10079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                ContentValues b = new ContentValues(1);
10089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                b.put("a", r);
10099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mValues[i] = b;
10109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
10119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
10129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
10149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
10159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
10169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.insert("t1", null, mValues[i]);
10179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
10189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
10199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 inserts for an integer -indexed table
10239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf23Test extends PerformanceBase {
10269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
10279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        ContentValues[] mValues = new ContentValues[SIZE];
10289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
10309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
10319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
10329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
10339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
10359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a INTEGER)");
10369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1a ON t1(a)");
10379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
10399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
10409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                ContentValues b = new ContentValues(1);
10419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                b.put("a", r);
10429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mValues[i] = b;
10439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
10449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
10459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
10479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
10489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
10499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.insert("t1", null, mValues[i]);
10509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
10519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
10529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 inserts for a String
10569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf24Test extends PerformanceBase {
10599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
10609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        ContentValues[] mValues = new ContentValues[SIZE];
10619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
10639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
10649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
10659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
10669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
10689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a VARCHAR(100))");
10699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
10719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
10729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                ContentValues b = new ContentValues(1);
10739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                b.put("a", numberName(r));
10749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mValues[i] = b;
10759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
10769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
10779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
10799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
10809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
10819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.insert("t1", null, mValues[i]);
10829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
10839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
10849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 inserts for a String - indexed table
10889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf25Test extends PerformanceBase {
10919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
10929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        ContentValues[] mValues = new ContentValues[SIZE];
10939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
10959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
10969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
10979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
10989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
11009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t1(a VARCHAR(100))");
11019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i1a ON t1(a)");
11029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
11049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
11059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                ContentValues b = new ContentValues(1);
11069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                b.put("a", numberName(r));
11079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mValues[i] = b;
11089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
11129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
11139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
11149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.insert("t1", null, mValues[i]);
11159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
11219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 selects for a String -starts with
11229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
11239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf26Test extends PerformanceBase {
11259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
11269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t3.a"};
11279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
11289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
11309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
11319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
11329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
11339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
11359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t3(a VARCHAR(100))");
11369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
11389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
11399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t3 VALUES('"
11409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
11419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
11449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
11459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "a LIKE '" + numberName(r).substring(0, 1) + "*'";
11469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
11519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
11529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
11539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t3", COLUMNS, where[i], null, null, null, null);
11549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
11579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
11599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 selects for a String - indexed table -starts with
11609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
11619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf27Test extends PerformanceBase {
11639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
11649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t3.a"};
11659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
11669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
11689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
11699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
11709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
11719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
11739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t3(a VARCHAR(100))");
11749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i3a ON t3(a)");
11759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
11779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
11789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t3 VALUES('"
11799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
11809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
11839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
11849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "a LIKE '" + numberName(r).substring(0, 1) + "*'";
11859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           }
11889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
11909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
11919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
11929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t3", COLUMNS, where[i], null, null, null, null);
11939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
11969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
11989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 selects for an integer -
11999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
12009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf28Test extends PerformanceBase {
12029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
12039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t4.a"};
12049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
12059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
12079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
12089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
12099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
12109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
12129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t4(a INTEGER)");
12139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
12159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
12169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t4 VALUES(" + r + ")");
12179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
12189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
12199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "a >= " + lower + " AND a < " + upper;
12209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
12219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           }
12229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
12249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
12259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
12269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t4", COLUMNS, where[i], null, null, null, null);
12279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
12289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
12299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
12309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
12329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 selects for an integer -indexed table
12339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
12349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf29Test extends PerformanceBase {
12369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
12379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t4.a"};
12389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
12399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
12419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
12429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
12439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
12449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
12469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t4(a INTEGER)");
12479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           mDatabase.execSQL("CREATE INDEX i4a ON t4(a)");
12489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
12509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
12519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t4 VALUES(" + r + ")");
12529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int lower = i * 100;
12549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int upper = (i + 10) * 100;
12559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "a >= " + lower + " AND a < " + upper;
12569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
12579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           }
12599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
12619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
12629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
12639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t4", COLUMNS, where[i], null, null, null, null);
12649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
12659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
12669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
12679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
12709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 selects for a String - contains 'e'
12719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
12729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf30Test extends PerformanceBase {
12749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
12759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t3.a"};
12769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
12779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
12799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
12809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
12819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
12829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
12849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t3(a VARCHAR(100))");
12859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
12879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
12889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t3 VALUES('"
12899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
12909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
12919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
12939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                 where[i] = "a LIKE '*e*'";
12949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
12969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           }
12979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
12989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
12999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
13009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
13019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t3", COLUMNS, where[i], null, null, null, null);
13029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
13039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
13049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
13059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
13079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  10000 selects for a String - contains 'e'-indexed table
13089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
13099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class Perf31Test extends PerformanceBase {
13119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final int SIZE = 10000;
13129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private static final String[] COLUMNS = {"t3.a"};
13139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private String[] where = new String[SIZE];
13149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
13169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setUp(Context c) {
13179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super.setUp(c);
13189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Random random = new Random(42);
13199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase
13219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              .execSQL("CREATE TABLE t3(a VARCHAR(100))");
13229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mDatabase.execSQL("CREATE INDEX i3a ON t3(a)");
13239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
13259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int r = random.nextInt(100000);
13269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.execSQL("INSERT INTO t3 VALUES('"
13279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + numberName(r) + "')");
13289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
13299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
13319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                where[i] = "a LIKE '*e*'";
13329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
13349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           }
13369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
13389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void run() {
13399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < SIZE; i++) {
13409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mDatabase.query("t3", COLUMNS, where[i], null, null, null, null);
13419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
13429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
13439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
13449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final String[] ONES =
13469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            {"zero", "one", "two", "three", "four", "five", "six", "seven",
13479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "eight", "nine", "ten", "eleven", "twelve", "thirteen",
13489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "fourteen", "fifteen", "sixteen", "seventeen", "eighteen",
13499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "nineteen"};
13509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
13519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final String[] TENS =
13529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            {"", "ten", "twenty", "thirty", "forty", "fifty", "sixty",
13539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "seventy", "eighty", "ninety"};
13549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
1355