मेरे पास एक बहुत ही सरल AsyncTask कार्यान्वयन उदाहरण है और इसे Android JUnit ढांचे का उपयोग करके परीक्षण करने में समस्या हो रही है।
यह ठीक काम करता है जब मैं तुरंत आवेदन करता हूं और इसे सामान्य अनुप्रयोग में निष्पादित करता हूं। हालाँकि जब इसे किसी Android परीक्षण फ्रेमवर्क क्लासेस (यानी AndroidTestCase , ActivityUnitTestCase , ActivityInstrumentationTestCase2 आदि) से निष्पादित किया जाता है , तो यह अजीब व्यवहार करता है:
- यह
doInBackground()
विधि को सही ढंग से निष्पादित करता है - हालांकि वह अपने सूचना विधियां (में से किसी का आह्वान नहीं करता है
onPostExecute()
,onProgressUpdate()
, आदि) - बस चुपचाप उन्हें किसी भी त्रुटि के बिना दिखाए ध्यान नहीं देता।
यह बहुत ही सरल AsyncTask उदाहरण है:
package kroz.andcookbook.threads.asynctask;
import android.os.AsyncTask;
import android.util.Log;
import android.widget.ProgressBar;
import android.widget.Toast;
public class AsyncTaskDemo extends AsyncTask<Integer, Integer, String> {
AsyncTaskDemoActivity _parentActivity;
int _counter;
int _maxCount;
public AsyncTaskDemo(AsyncTaskDemoActivity asyncTaskDemoActivity) {
_parentActivity = asyncTaskDemoActivity;
}
@Override
protected void onPreExecute() {
super.onPreExecute();
_parentActivity._progressBar.setVisibility(ProgressBar.VISIBLE);
_parentActivity._progressBar.invalidate();
}
@Override
protected String doInBackground(Integer... params) {
_maxCount = params[0];
for (_counter = 0; _counter <= _maxCount; _counter++) {
try {
Thread.sleep(1000);
publishProgress(_counter);
} catch (InterruptedException e) {
// Ignore
}
}
}
@Override
protected void onProgressUpdate(Integer... values) {
super.onProgressUpdate(values);
int progress = values[0];
String progressStr = "Counting " + progress + " out of " + _maxCount;
_parentActivity._textView.setText(progressStr);
_parentActivity._textView.invalidate();
}
@Override
protected void onPostExecute(String result) {
super.onPostExecute(result);
_parentActivity._progressBar.setVisibility(ProgressBar.INVISIBLE);
_parentActivity._progressBar.invalidate();
}
@Override
protected void onCancelled() {
super.onCancelled();
_parentActivity._textView.setText("Request to cancel AsyncTask");
}
}
यह एक परीक्षण का मामला है। यहाँ AsyncTaskDemoActivity एक बहुत ही सरल गतिविधि है जो मोड में AsyncTask के परीक्षण के लिए UI प्रदान करती है:
package kroz.andcookbook.test.threads.asynctask;
import java.util.concurrent.ExecutionException;
import kroz.andcookbook.R;
import kroz.andcookbook.threads.asynctask.AsyncTaskDemo;
import kroz.andcookbook.threads.asynctask.AsyncTaskDemoActivity;
import android.content.Intent;
import android.test.ActivityUnitTestCase;
import android.widget.Button;
public class AsyncTaskDemoTest2 extends ActivityUnitTestCase<AsyncTaskDemoActivity> {
AsyncTaskDemo _atask;
private Intent _startIntent;
public AsyncTaskDemoTest2() {
super(AsyncTaskDemoActivity.class);
}
protected void setUp() throws Exception {
super.setUp();
_startIntent = new Intent(Intent.ACTION_MAIN);
}
protected void tearDown() throws Exception {
super.tearDown();
}
public final void testExecute() {
startActivity(_startIntent, null, null);
Button btnStart = (Button) getActivity().findViewById(R.id.Button01);
btnStart.performClick();
assertNotNull(getActivity());
}
}
यह सब कोड ठीक काम कर रहा है, इस तथ्य को छोड़कर कि एंड्रॉइड टेस्टिंग फ्रेमवर्क के भीतर निष्पादित होने पर AsyncTask इसे लागू नहीं करता है। कोई विचार?
Service.doSomething()
?