1 /*
2  * Copyright (C) 2012 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package com.android.cts.verifier.p2p.testcase;
17 
18 import android.content.Context;
19 import android.net.wifi.WifiManager;
20 import android.net.wifi.p2p.WifiP2pManager;
21 import android.net.wifi.p2p.WifiP2pManager.Channel;
22 
23 import com.android.cts.verifier.R;
24 
25 /**
26  * A test case defines the fixture to run p2p tests. To define a test case <br>
27  *
28  * 1) implement a subclass of TestCase<br>
29  * 2) define instance variables that store the state of the fixture<br>
30  * 3) initialize the fixture state by overriding setUp if needed. At default, p2p channel
31  *  and p2p manager is initialized.<br>
32  * 4) implement test case by overriding executeTest. executeTest must return the message
33  * id to be shown in result text view.
34  * 5) clean-up after a test by overriding tearDown if needed. At default, all services
35  *  and requests are cleared.<br>
36  */
37 public abstract class TestCase {
38 
39     /*
40      * The test case id.
41      */
42     public static final String EXTRA_TEST_NAME =
43             "com.android.cts.verifier.p2p.testcase.EXTRA_TEST_NAME";
44 
45     protected static final int TIMEOUT = 25000;
46     protected static final int TIMEOUT_FOR_USER_ACTION = 60000;
47     protected static final int SUCCESS = 0;
48 
49     protected Context mContext;
50     protected String mReason;
51 
52     protected WifiP2pManager mP2pMgr;
53     protected WifiManager mWifiMgr;
54     protected Channel mChannel;
55     // this is used for multi-client test
56     protected Channel mSubChannel;
57 
58     private Thread mThread;
59     private TestCaseListener mListener;
60 
61     /**
62      * Constructor
63      * @param context Activity context cannot be null.
64      * @param handler Must be the handler of GUI thread. cannot be null.
65      * @param textView The result message to be shown. cannot be null.
66      * @param listener The test listener. can be null.
67      */
TestCase(Context context)68     public TestCase(Context context) {
69         mContext = context;
70     }
71 
72     /**
73      * Start test case.
74      *
75      * Test case is executed in another thread.
76      * After the test, the result message is shown in text view.
77      */
start(TestCaseListener listener)78     public void start(TestCaseListener listener) {
79         mListener = listener;
80 
81         stop();
82         mThread = new Thread(new Runnable() {
83             @Override
84             public void run() {
85                 mListener.onTestStarted();
86                 try {
87                     setUp();
88                 } catch(Exception e) {
89                     mListener.onTestFailed(mContext.getString(R.string.p2p_setup_error));
90                     return;
91                 }
92 
93                 try {
94                     if (executeTest()) {
95                         mListener.onTestSuccess();
96                     } else {
97                         mListener.onTestFailed(getReason());
98                     }
99                 } catch(Exception e) {
100                     e.printStackTrace();
101                     mListener.onTestFailed(
102                             mContext.getString(R.string.p2p_unexpected_error));
103                 } finally {
104                     tearDown();
105                 }
106             }});
107         mThread.start();
108     }
109 
110     /**
111      * Stop test case.
112      */
stop()113     public void stop() {
114         if (mThread != null) {
115             mThread.interrupt();
116             mThread = null;
117         }
118     }
119 
120     /**
121      * Return test name.
122      * @return test name.
123      */
getTestName()124     abstract public String getTestName();
125 
126     /**
127      * Return test id. It must be unique.
128      * @return test id.
129      */
getTestId()130     public String getTestId() {
131         return this.getClass().getName();
132     }
133 
134     /**
135      * Execute test case.
136      * @return the message id to be shown in text view.
137      * @throws InterruptedException
138      */
executeTest()139     abstract protected boolean executeTest() throws InterruptedException;
140 
141     /**
142      * Set up the test case.
143      */
setUp()144     protected void setUp() {
145         mP2pMgr = (WifiP2pManager) mContext.getSystemService(Context.WIFI_P2P_SERVICE);
146         mWifiMgr = (WifiManager) mContext.getSystemService(Context.WIFI_SERVICE);
147         mChannel = mP2pMgr.initialize(mContext, mContext.getMainLooper(), null);
148         mSubChannel = mP2pMgr.initialize(mContext, mContext.getMainLooper(), null);
149     }
150 
151     /**
152      * Tear down the test case.
153      */
tearDown()154     protected void tearDown() {
155         if (mP2pMgr != null) {
156             mP2pMgr.clearLocalServices(mChannel, null);
157             mP2pMgr.clearServiceRequests(mChannel, null);
158             mP2pMgr.clearLocalServices(mSubChannel, null);
159             mP2pMgr.clearServiceRequests(mSubChannel, null);
160         }
161 
162         if (mChannel != null) {
163             mChannel.close();
164         }
165     }
166 
167     /**
168      * Notify a message to the application.
169      * @param id
170      */
notifyTestMsg(int id)171     protected void notifyTestMsg(int id) {
172         mListener.onTestMsgReceived(mContext.getString(id));
173     }
174 
175     /**
176      * Get reason for the failure.
177      * @return
178      */
getReason()179     private String getReason() {
180        if (mReason == null) {
181            return mContext.getString(R.string.p2p_unexpected_error);
182        }
183        return mReason;
184     }
185 
186     public static interface TestCaseListener {
187 
188         /**
189          * This function is invoked when the test case starts.
190          */
onTestStarted()191         public void onTestStarted();
192 
193         /**
194          * This function is invoked when the test notify a message to application.
195          * @param msg
196          */
onTestMsgReceived(String msg)197         public void onTestMsgReceived(String msg);
198 
199         /**
200          * This function is invoked when the test is success.
201          */
onTestSuccess()202         public void onTestSuccess();
203 
204         /**
205          * This function is invoked when the test is failed.
206          * @param reason
207          */
onTestFailed(String reason)208         public void onTestFailed(String reason);
209     }
210 }
211