[RSpec] LEVEL 1: INTRODUCTION
level Introduction
2023-09-14 08:59:21 时间
Install RSpec:
Describe
Lets start writing a specification for the Tweet
class. Write a describe
block for the Tweet model without any examples inside it.
#tweet.rb class Tweet end
Answer:
#tweet_spec.rb describe Tweet do end
It
Now create a pending test called "can set status"
.
describe Tweet do it "can set status" end
Couple of ways to make test pending:
Expectation
Now let's write the example. Go ahead and instantiate a tweet
, give it the status "Nom nom nom"
, and test the status has been properly set to this value using an ==
equality matcher.
class Tweet attr_accessor :status def initialize(options={}) self.status = options[:status] end def public? self.status && self.status[0] != "@" end end
Answer:
describe Tweet do it 'can set status' do tweet = Tweet.new tweet.status = "Nom nom nom" tweet.status.should == "Nom nom nom" end end
Matchers
Using a predicate 'be' matcher, make sure that a tweet
like "Nom nom nom"
(which is not a reply because it doesn't start with an '@' sign) is public
.
describe Tweet do it 'without a leading @ symbol should be public' do tweet = Tweet.new(status: 'Nom nom nom') tweet.should be_public end end
Comparison Matchers
Finish the example below to ensure that our tweet.status.length
is less than or equal to 140 characters. Use a be
matcher in your spec.
class Tweet attr_accessor :status def initialize(options={}) self.status = options[:status] end def public? self.status && self.status[0] != "@" end def status=(status) @status = status ? status[0...140] : status end end
Answer:
describe Tweet do it 'truncates the status to 140 characters' do tweet = Tweet.new(status: 'Nom nom nom' * 100) tweet.status.length.should be <= 140 end end
Predict 'be':
相关文章
- basics of level set
- CSP Level 3浅析&简单的bypass
- ORA-47405: negative trust level for Factor string ORACLE 报错 故障修复 远程处理
- ORA-55203: Tag data translation level not found ORACLE 报错 故障修复 远程处理
- ORA-00166: remote/local nesting level is too deep ORACLE 报错 故障修复 远程处理
- ORA-12461: undefined level string for policy string ORACLE 报错 故障修复 远程处理
- MySQL Error number: MY-013699; Symbol: ER_HEALTH_WARNING_DISK_USAGE_LEVEL_3; SQLSTATE: HY000 报错 故障修复 远程处理
- Oracle 视图 USER_DIM_LEVEL_KEY 官方解释,作用,如何使用详细说明
- 的使用利用Oracle中的Level概念轻松管理权限(oracle中level)