文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android之单元测试及数据库操作

2022-06-06 12:57

关注

  一、安卓下的单元测试   1.创建一个单元类,继承超类AndroidTestCase   2.在AndroidManifest.xml配置清单中配置以下两点   首先在manifest节点下添加节点instrumentation,targetPackage包名与单元测试类包名保持一致   <instrumentation   android:name="android.test.InstrumentationTestRunner"   android:targetPackage="com.myandroid.db" />   然后在application节点下添加节点   <uses-library android:name="android.test.runner" />   二、数据库的操作   首先创建一个帮助类,继承SQLiteOpenHelper,实现父类中的构造函数。   在这个类中,传入上下文,数据库名称,版本号,做表结构的初始化,版本号改变时更改表结构   代码如下

 

public class PersonDBHelper extends SQLiteOpenHelper { public PersonDBHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); // TODO 自动生成的构造函数存根 } //第一次创建数据库时执行此方法,适合做数据库表结构的初始化 @Override public void onCreate(SQLiteDatabase db) { //创建用户表 db.execSQL("create table userInfo(id integer primary key autoincrement,username varchar(50),telphone varchar(20),createdate datetime)"); } //当数据库的版本发生变化时调用 @Override public void onUpgrade(SQLiteDatabase db, int arg1, int arg2) { //更改用户表结构 db.execSQL("alter table userInfo add remark varchar(50)"); } }

  接下来根据创建帮助类写业务逻辑方法

  public class PersonDao {   private PersonDBHelper personDBHelper;   //源码-使用字段生成构造函数   public PersonDao(PersonDBHelper personDBHelper) {   super();   this.personDBHelper = personDBHelper;   }   public boolean GetList(String username){   SQLiteDatabase db =personDBHelper.getReadableDatabase();   if(db.isOpen()){   Cursor reader =db.rawQuery("select * from userInfo where username=?",   new String []{username});//参数化查询   if(reader.moveToNext()){   return true;   }   reader.close();   db.close();   }   return false;   }   public boolean Insert(Person model ){   Object [] parms =new Object[]{model.getUsername(),model.getTelphone  (),model.getCreatedate()};   SQLiteDatabase db =personDBHelper.getReadableDatabase();   if(db.isOpen()){   db.execSQL("insert into userInfo(username,telphone,createdate) values  (?,?,?)", parms);   db.close();   return true;   }   return false;   }   }

 

  然后用Android下的单元测试测试PersonDao类的方法   public class testPersonDao extends AndroidTestCase {   public void testAdd(){   Person person =new Person();   person.setUsername("黄忠");   person.setTelphone("15110041588");   person.setRemark("我要飞的更高");   person.setCreatedate(new Date());   PersonDBHelper personDBHelper =new PersonDBHelper(getContext(), "person.db", null, 1);   PersonDao dao =new PersonDao(personDBHelper);   boolean res =dao.Insert(person);   assertEquals(true, res);   }   }


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯