我有以下活动:
package codeguru.startactivityforresult;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
public class ChildActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.child);
this.resultButton = (Button) this.findViewById(R.id.result_button);
this.resultButton.setOnClickListener(onResult);
}
private View.OnClickListener onResult = new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent result = new Intent();
result.putExtra(ChildActivity.this.getString(R.string.result), ChildActivity.this.getResources().getInteger(R.integer.result));
ChildActivity.this.setResult(RESULT_OK, result);
ChildActivity.this.finish();
}
};
private Button resultButton = null;
}
并进行以下JUnit测试:
package codeguru.startactivityforresult;
import android.app.Activity;
import android.test.ActivityInstrumentationTestCase2;
import android.test.UiThreadTest;
import android.widget.Button;
import junit.framework.Assert;
public class ChildActivityTest extends ActivityInstrumentationTestCase2<ChildActivity> {
public ChildActivityTest() {
super(ChildActivity.class);
}
@Override
public void setUp() throws Exception {
super.setUp();
this.setActivityInitialTouchMode(false);
this.activity = this.getActivity();
this.resultButton = (Button) this.activity.findViewById(R.id.result_button);
}
@Override
public void tearDown() throws Exception {
super.tearDown();
}
@UiThreadTest
public void testResultButtonOnClick() {
Assert.assertTrue(this.resultButton.performClick());
Assert.fail("How do I check the returned result?");
}
private Activity activity;
private Button resultButton;
}
我如何确保单击按钮设置正确的结果(调用setResult()
),该结果将返回到任何以此为起始的活动startActivityForResult()
?
使用问题中的当前Activity实现,即,通过单击ChildActivity中的按钮设置结果,然后立即销毁该活动,在ChildActivityTest中我们无法做很多测试结果相关的东西。
相关问题测试onActivityResult()的答案显示了如何在MainActivityTest中独立测试startActivityForResult()和/或onActivityResult()。通过独立方式,MainActivityTest不依赖于ChildActivity的交互,检测将捕获ChildActivity的创建并立即将其杀死,然后返回准备好的烘焙模拟ActivityResult,从而对MainActivity进行单元测试。
如果您不希望检测中断并返回模拟的ActivityResult,则可以让ChildActivity继续进行,然后在ChildActivity中模拟交互,然后将实际的ActivityResult返回给MainActivity。说如果您要MainActivity启动ChildActivity作为结果,然后更新TextView,以测试整个端到端的交互/合作,请参见下面的示例代码:
public class MainActivityTest extends ActivityInstrumentationTestCase2<MainActivity> {
... ...
public void testStartActivityForResult() {
MainActivity mainActivity = getActivity();
assertNotNull(activity);
// Check initial value in TextView:
TextView text = (TextView) mainActivity.findViewById(com.example.R.id.textview1);
assertEquals(text.getText(), "default vaule");
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// Create an ActivityMonitor that monitor ChildActivity, do not interrupt, do not return mock result:
Instrumentation.ActivityMonitor activityMonitor = getInstrumentation().addMonitor(ChildActivity.class.getName(), null , false);
// Simulate a button click in MainActivity that start ChildActivity for result:
final Button button = (Button) mainActivity.findViewById(com.example.R.id.button1);
mainActivity.runOnUiThread(new Runnable() {
public void run() {
button.performClick();
}
});
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
getInstrumentation().waitForIdleSync();
ChildActivity childActivity = (ChildActivity) getInstrumentation().waitForMonitorWithTimeout(activityMonitor, 5);
// ChildActivity is created and gain focus on screen:
assertNotNull(childActivity);
// Simulate a button click in ChildActivity that set result and finish ChildActivity:
final Button button2 = (Button) childActivity.findViewById(com.example.R.id.button1);
childActivity.runOnUiThread(new Runnable() {
public void run() {
button2.performClick();
}
});
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
getInstrumentation().waitForIdleSync();
// TextView in MainActivity should be changed:
assertEquals(text.getText(), "default value changed");
}
... ...
}
我在这里添加了三个Thread.sleep()调用,以便您有机会在运行JUnit Test时看到单击模拟的按钮。如您在这里看到的那样,一个独立的ChildActivityTest不足以测试整个合作,实际上我们是通过MainActivityTest间接测试ChildActivity.setResult()的,因为我们从一开始就需要模拟整个交互。
我有一个带有两个衰减函数(ES 2.4.4)的查询,我使用对查询项中的衰减函数得分求和。对于测试,我使用来防止任何其他分数(来自查询)影响我的分数(我想测试衰减函数)。 这些是我的衰减函数: 我的结果包括2篇不同日期的文章(2017-08-28,2009-05-08)具有相同的优先级(1000)和相同的分数!(13.122)怎么会这样?为什么没有获得更好的分数?所以我试图解释查询。 对于2017-
所以我有一个打开活动的通知: 我制作的活动是一个简单的对话框样式的活动。当我从通知抽屉中打开活动时,在任何其他应用程序上,如facebook、whatsapp、chrome浏览器等,活动就会按预期打开。问题是当我试图关闭它,并回到以前的应用程序。 单击对话框中创建的“关闭”按钮时: 同样的事情发生了:活动结束了,但我要回到主屏幕,而不是上一个应用程序。为什么?? *注意:以前的应用程序仍然在后台工
问题内容: 如果我运行查询,例如: 即使查询与任何记录都不匹配,它也会始终返回结果吗?还是我需要验证并确保结果返回一行? 问题答案: 是的,因为它是一个聚合并且返回零。除非您添加GROUP BY,否则由于没有组,因此没有结果… 除非您添加GROUP BY,然后没有任何行,否则MAX / SUM等将返回NULL。只有COUNT传回没有结果的数字 编辑,有点晚:SUM会像MAX一样返回NULL 编辑,
问题内容: 我正在使用Newtonsoft的Json.Net从以下json中选择节点: 以下C#代码段 产量: 现在,这很酷,我想做的是按客户端代码过滤,我认为 可以,但是我显然对语法不够了解。这将返回一个空列表: 并且单个令牌选择器返回null: 我在https://jsonpath.curiousconcept.com/上尝试了几种不同的配置,看来我的查询语法确实坏了。 使用Flow Comm
我想mock接受对象参数的方法。此对象参数是从动态创建的。不会返回预期的结果,尽管这两个对象具有相同的数据,但只是不同的哈希代码。 有没有什么方法来模拟方法,使它能够以预期的结果响应?
接口测试没有预期结果如何测试?(即没有接口文档中写的预期结果) 希望知道的小伙伴回答一下,谢谢!