/* * Copyright (C) 2012 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.cts.verifier.p2p.testcase; import android.content.Context; import android.net.wifi.WifiManager; import android.net.wifi.p2p.WifiP2pManager; import android.net.wifi.p2p.WifiP2pManager.Channel; import com.android.cts.verifier.R; /** * A test case defines the fixture to run p2p tests. To define a test case
* * 1) implement a subclass of TestCase
* 2) define instance variables that store the state of the fixture
* 3) initialize the fixture state by overriding setUp if needed. At default, p2p channel * and p2p manager is initialized.
* 4) implement test case by overriding executeTest. executeTest must return the message * id to be shown in result text view. * 5) clean-up after a test by overriding tearDown if needed. At default, all services * and requests are cleared.
*/ public abstract class TestCase { /* * The test case id. */ public static final String EXTRA_TEST_NAME = "com.android.cts.verifier.p2p.testcase.EXTRA_TEST_NAME"; protected static final int TIMEOUT = 25000; protected static final int TIMEOUT_FOR_USER_ACTION = 60000; protected static final int SUCCESS = 0; protected Context mContext; protected String mReason; protected WifiP2pManager mP2pMgr; protected WifiManager mWifiMgr; protected Channel mChannel; // this is used for multi-client test protected Channel mSubChannel; private Thread mThread; private TestCaseListener mListener; /** * Constructor * @param context Activity context cannot be null. * @param handler Must be the handler of GUI thread. cannot be null. * @param textView The result message to be shown. cannot be null. * @param listener The test listener. can be null. */ public TestCase(Context context) { mContext = context; } /** * Start test case. * * Test case is executed in another thread. * After the test, the result message is shown in text view. */ public void start(TestCaseListener listener) { mListener = listener; stop(); mThread = new Thread(new Runnable() { @Override public void run() { mListener.onTestStarted(); try { setUp(); } catch(Exception e) { mListener.onTestFailed(mContext.getString(R.string.p2p_setup_error)); return; } try { if (executeTest()) { mListener.onTestSuccess(); } else { mListener.onTestFailed(getReason()); } } catch(Exception e) { e.printStackTrace(); mListener.onTestFailed( mContext.getString(R.string.p2p_unexpected_error)); } finally { tearDown(); } }}); mThread.start(); } /** * Stop test case. */ public void stop() { if (mThread != null) { mThread.interrupt(); mThread = null; } } /** * Return test name. * @return test name. */ abstract public String getTestName(); /** * Return test id. It must be unique. * @return test id. */ public String getTestId() { return this.getClass().getName(); } /** * Execute test case. * @return the message id to be shown in text view. * @throws InterruptedException */ abstract protected boolean executeTest() throws InterruptedException; /** * Set up the test case. */ protected void setUp() { mP2pMgr = (WifiP2pManager) mContext.getSystemService(Context.WIFI_P2P_SERVICE); mWifiMgr = (WifiManager) mContext.getSystemService(Context.WIFI_SERVICE); mChannel = mP2pMgr.initialize(mContext, mContext.getMainLooper(), null); mSubChannel = mP2pMgr.initialize(mContext, mContext.getMainLooper(), null); } /** * Tear down the test case. */ protected void tearDown() { if (mP2pMgr != null) { mP2pMgr.clearLocalServices(mChannel, null); mP2pMgr.clearServiceRequests(mChannel, null); mP2pMgr.clearLocalServices(mSubChannel, null); mP2pMgr.clearServiceRequests(mSubChannel, null); } if (mChannel != null) { mChannel.close(); } } /** * Notify a message to the application. * @param id */ protected void notifyTestMsg(int id) { mListener.onTestMsgReceived(mContext.getString(id)); } /** * Get reason for the failure. * @return */ private String getReason() { if (mReason == null) { return mContext.getString(R.string.p2p_unexpected_error); } return mReason; } public static interface TestCaseListener { /** * This function is invoked when the test case starts. */ public void onTestStarted(); /** * This function is invoked when the test notify a message to application. * @param msg */ public void onTestMsgReceived(String msg); /** * This function is invoked when the test is success. */ public void onTestSuccess(); /** * This function is invoked when the test is failed. * @param reason */ public void onTestFailed(String reason); } }