while(rs.next()) {
content = content + rs.getString("学生姓名") + "\t" + rs.getString("xxxx") + "\t" + rs.getString("xxx") + "\n"
}
textArea.setText(content)
按升序那个,直接在sql里面控制就行了
SELECT ......... FROM .... ORDER BY 学号 ASC
它分成以下几个步骤: 建立mock; 将mock和待测试的对象连接起来; 在mock上设置预期的返回值; 开启replay模式,准备记录实际发生的调用; 进行测试; 验证测试结果,调用顺序是否正确,返回值是否符合期望;首个先我们创建一个应用,功能很简单就是读取该应用目录下的一个txt文件内容,并展示到应用的activity上。public class MockContextExampleActivity extends Activity {
public final static String FILE_NAME = “myfile.txt”
private TextView mTv
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState)
setContentView(R.layout.main)
mTv = (TextView) findViewById(R.id.TextView01)
final byte[] buffer = new byte[1024]
try {
final FileInputStream fis = openFileInput(FILE_NAME)
final int n = fis.read(buffer)
mTv.setText(new String(buffer, 0, n-1))
} catch (Exception e) {
mTv.setText(e.toString())
mTv.setTextColor(Color.RED)
}
}
//这里写了个getText方法,测试工程会用到。
public String getText() {
return mTv.getText().toString()
}
运行一下,此时我们的包目录下没有myfile.txt,页面显示的可能是个错误。OK,然后我们创建两个文件。一个名为myfile.txt,一个test.myfile.txt。前者用于应用中显示的文件内容,后者是作为测试Mock调用的。
echo “This is real data” >data/data/com.example.aatg.mockcontextexample/files/myfile.txt
echo “This is *MOCK* data” >data/data/com.example.aatg.mockcontextexample/files/test.myfile.txt
再次运行下,应该可以看到Activity上显示的是This is real data。
OK,下面开始编写测试代码。我们的目的是测试这个app能够正确读取文件,假设现在我怕是不是开发在代码里写死了“This is real data”这句话(作为测试,有点怀疑精神很正常)。OK,现在我用另外一个文件test.myfile.txt来代替myfile.txt会不会出错。
public class MockContextExampleTest extends ActivityUnitTestCase<MockContextExampleActivity>{
private static final String PREFIX = “test.”
private RenamingDelegatingContext mMockContext
public MockContextExampleTest() {
super(MockContextExampleActivity.class)
}
@Override
protected void setUp() throws Exception {
super.setUp()
mMockContext = new RenamingDelegatingContext(getInstrumentation().getTargetContext(), PREFIX)
mMockContext.makeExistingFilesAndDbsAccessible()
}
@Override
protected void tearDown() throws Exception {
super.tearDown()
}
public void testSampleTextDisplayed(){
setActivityContext(mMockContext)
startActivity(new Intent(), null, null)
final MockContextExampleActivity mActivity = getActivity()
assertNotNull(mActivity)
String text = mActivity.getText()
assertEquals(“This is *MOCK* data”, text)
}
}
主要看下RenamingDelegatingContext函数的使用,PREFIX是表示文件或数据库的前缀。另外这里为什么使用getTargetContext方法而不是getContext,后者我们经常在UiTest中使用到。这里其实看下注释就明白了:
//getContext():The instrumentation’s package context.
//getTargetContext(): A Context in the target application.
运行下测试,pass。这说明getText方法返回的string已经是This is *MOCK* data 而不是 This is real data了。这我就可以证明,开发没有写死这段话。以上就是RenamingDelegatingContext函数如何来mock文件的,数据库的使用也是一样的。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)