新建 Rails项目 RSpec测试
项目环境:Linux
Rails 4.0.0
Ruby 2.3.1p112
gem :2.7.5
Bundler version 1.16.1
非关系型数据库:mongoDB
现在开始创建第一个项目。
接下来以Patient Model为例。
创建一个目录,执行:
mkdir rails_test
切换到rails_test目录,执行
cd rails_test
1、创建名为patient的项目,执行:
rails new patient
接下来会创建一系列的文件和依赖包。出现 Bundle complete!时说明已经创建成功了,接下来执行下一步。
2、查看我们所创建的项目,理解目录文件所代表的意思:
-- app 文件夹是我们的要操作的核心文件夹,按照一般的,我们分为:
-- -- assets 是我们前端页面存放js,css等所需要的文件夹。
-- -- controllers 是MVC架构中的控制层(C),负责路由转发接受前端传值等操作。
-- -- helpers 是帮助文档
-- -- mailers 邮件处理
-- -- models 是MVC中的模型层(M),负责数据处理包括格式,类型等操作。存入数 据库的持久化操作。
-- -- views 是MVC中的视图层(V),是前端代码逻辑。这里我们不去关注,接下 来再去深究。
其余的目录我大概简介一下就好啦。需要详细了解的问我,今天的主题不在这些基础上。
-- bin #rails脚本
-- config/ #路由、数据库等
-- db/ #数据库模式、迁移文件
-- lib/ #扩展模块
-- log/ #日志
-- public/ #公共资源
-- test/ #单元测试
-- config.ru #Rack服务器的程序设置、用于启动程序
-- Gemfile,Gemfile.lock #指定Gem依赖,用于bundler gem
-- Rakefile #保存并加载可在命令行中执行的任务,可添加任务在lib/tasks中
3、利用vi编辑器修改Gemfile 文件,添加mongoDB所支持的gem。执行:vi Gemfile ,
添加:
gem 'mongoid'
gem 'execjs'
gem 'therubyracer',:platforms =>:ruby
版本不清楚的情况下,最好不要写上版本号,让bundle 执行自动匹配,Rails 支持 mongoid 是5.0.0版本。添加成功之后按ESC ,接着执行:
:wq
保存退出。
4、执行
bundle install
注意这里,执行如果出错的话,打开Gemfile 将源中https改写成http保存退出成功。
5、接下来我们通过命令在config下新建一个mongoid.yml文件,执行
rails generate mongoid:config
创建成功,但是注意,如果不添加execjs,therubyracer的话找不到JavaScript就会创建失败。
6、
vi mongoid.yml
文件,修改数据库名,把localhost改成自己的IP,在Linux下通过ifconfig命令查看自己的IP ,数据库名修改为:patient。保存退出。
7、我们同时加入RSpec测试,vi Gemfile 打开输入如下内容:
group :development, :test do
gem 'rspec-rails'
gem 'factory_girl_rails'
end
group :test do
gem 'faker'
gem 'capybara'
gem 'launchy'
gem 'database_cleaner'
gem 'selenium-webdriver'
end
保存退出。
8、打开config/application.rb 文件,输入如下:
config.generators do |g|
g.test_framework :rspec,
fixtures: true,
view_specs: false,
controller_specs: false,
routing_specs: false
g.fixture_replacement :factory_girl,dir:"spec/factories"
end
保存退出。
9、做好创建测试程序的准备之后,我们需要创建一个名为spec的文件夹,该文件夹就是我们测试需要用到的,结构和app文件夹结构差不多,直接执行
rails generate rspec:install
文件夹就创建成功了。后面用到。
10、这里比较懒,我们通过脚手架创建一个j简单到只有两个属性的rails项目。手动创建的话请听下回分解。执行
rails g scaffold patient name:string sex:string
看到创建了一大堆的文件说明创建成功。先看一下成果吧,不过在启动服务之前,我们先通过后台添加一个数据。
11、执行:rails c 进入控制台,查看我们的模型是否存在,直接执行
Patient
如果存在则返回一模一样的值,否则报错。我直接执行持久化操作,执行
Patient.create({:name=>"za",:sex =>"f"})
OK,添加数据成功,接下来见证奇迹了。
12、执行:rails s 启动服务 地址栏输入:http://localhost:3000/patients。看到我们之前创建的模型就展示出来了。
并且CRUD都给你创建好了。直接执行就好啦。这就是脚手架的方便之处。
13、关闭服务。我们启动测试程序,执行
rspec
出现10 examples, 0 failures等字样并且不是红色就说明我们的测试就成功了。
14、添加一个模型验证,在 Patient模型里面添加非空验证,代码如下
validates_presence_of :name , :message=> "病人姓名不能为空"
接下来我们测试用户名为空是否能通过?注意测试程序的名字都是model_spec.rb,对应的我们找到spec/models/patient_spec.rb文件,用vi编辑器打开,添加如下代码:
it"病人姓名为空 "do
expect(Patient.new).to be_valid
end
再一次执行:rspec 发现报错了,说明测试成功啦。
那怎样让错误的程序测试成功?下节再讲吧