为了获得一个好的开始,您可以使用bundle gem
命令和rspec --init
。
~/code $ bundle gem my_lib
create my_lib/Gemfile
create my_lib/Rakefile
create my_lib/LICENSE.txt
create my_lib/README.md
create my_lib/.gitignore
create my_lib/my_lib.gemspec
create my_lib/lib/my_lib.rb
create my_lib/lib/my_lib/version.rb
Initializating git repo in /Users/john/code/my_lib
~/code $ cd my_lib/
~/code/my_lib $ git commit -m "Empty project"
~/code/my_lib $ rspec --init
The --configure option no longer needs any arguments, so true was ignored.
create spec/spec_helper.rb
create .rspec
- 代码进入
lib
- 规格进去
spec
- 测试数据或文件进入
spec/fixtures/
- 需要所有的红宝石文件
lib/my_lib.rb
。您也可以根据自己的喜好在该文件或它们自己的文件中定义例外。
- C源文件进入
ext/my_lib
- Shell脚本和可执行文件进入
bin
如有疑问,只需看看其他宝石的布置方式即可。
更多信息:
您应该将rspec添加为gemspec中的开发依赖项,以使其他开发人员更轻松
- 编辑my_lib.gemspec,增加
gem.add_development_dependency 'rspec'
和gem.add_development_dependency 'rake'
接近底部。
- 在spec / spec_helper.rb的顶部添加
Bundler.setup
和require 'my_lib'
以确保在运行规范时加载了gem依赖项。
- 将
require "rspec/core/rake_task"
和添加task :default => :spec
到您的Rakefile中,以便运行rake
将运行您的规格。
在您进行最新创作时,guard-rspec可以在文件更改时自动运行规范,从而提醒您注意规范失败,从而节省了时间和麻烦。
~/code/my_lib $ git add spec/spec_helper.rb
~/code/my_lib $ git commit -am "Add RSpec"
~/code/my_lib $ vim my_lib.gemspec # add guard development dependency
~/code/my_lib $ bundle
~/code/my_lib $ bundle exec guard init
~/code/my_lib $ vim Guardfile # Remove the sections below the top one
~/code/my_lib $ git add Guardfile
~/code/my_lib $ git commit -am "Add Guard"
对创建感到满意后,将其推送到github
# create a github repository for your gem, then push it up
~/code/my_lib $ curl -u myusername https://api.github.com/user/repos -d '{"name":"my_lib"}'
~/code/my_lib $ git remote add origin git@github.com:myusername/my_lib.git
~/code/my_lib $ git push
然后,当您准备在Rubygems.org上发布自己的gem时,请运行rake release
,它将逐步引导您完成这些步骤。
~/code/my_lib $ rake release
其他参考