/* * Copyright (C) 2008 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.tests.flavorlib.app; import android.test.ActivityInstrumentationTestCase2; import android.test.suitebuilder.annotation.MediumTest; import android.test.suitebuilder.annotation.SmallTest; import android.widget.TextView; /** * An example of an {@link ActivityInstrumentationTestCase2} of a specific activity {@link Focus2}. * By virtue of extending {@link ActivityInstrumentationTestCase2}, the target activity is automatically * launched and finished before and after each test. This also extends * {@link android.test.InstrumentationTestCase}, which provides * access to methods for sending events to the target activity, such as key and * touch events. See {@link #sendKeys}. * * In general, {@link android.test.InstrumentationTestCase}s and {@link ActivityInstrumentationTestCase2}s * are heavier weight functional tests available for end to end testing of your * user interface. When run via a {@link android.test.InstrumentationTestRunner}, * the necessary {@link android.app.Instrumentation} will be injected for you to * user via {@link #getInstrumentation} in your tests. * * See {@link com.example.android.apis.AllTests} for documentation on running * all tests and individual tests in this application. */ public class MainActivityFlavorTest extends ActivityInstrumentationTestCase2<MainActivity> { private TextView mLibTextView1; private TextView mLibTextView2; /** * Creates an {@link ActivityInstrumentationTestCase2} that tests the {@link Focus2} activity. */ public MainActivityFlavorTest() { super(MainActivity.class); } @Override protected void setUp() throws Exception { super.setUp(); final MainActivity a = getActivity(); // ensure a valid handle to the activity has been returned assertNotNull(a); mLibTextView1 = (TextView) a.findViewById(R.id.lib_text1); mLibTextView2 = (TextView) a.findViewById(R.id.lib_text2); } /** * The name 'test preconditions' is a convention to signal that if this * test doesn't pass, the test case was not set up properly and it might * explain any and all failures in other tests. This is not guaranteed * to run before other tests, as junit uses reflection to find the tests. */ @MediumTest public void testPreconditions() { assertNotNull(mLibTextView1); assertNotNull(mLibTextView2); } @MediumTest public void testAndroidStrings() { assertEquals("SUCCESS-LIB1", mLibTextView1.getText().toString()); } @MediumTest public void testJavaStrings() { assertEquals("SUCCESS-LIB1", mLibTextView2.getText().toString()); } @SmallTest public void testFailureOk() { assertTrue("Testing failing test", false); } }