Railsチュートリアル6章について大事だと思ったことをまとめます!
テストコードはRspecを利用して書いております。
・特定の属性のみ更新したい場合はupdate_attributeを使う
user = User.new(name: "The Dude", email: "dude@abides.org")
user.update_attribute(:name, "BBB")
--------------------------------------------------------------------------------------
テストコード 正しくないことをテストする
まずは正しいことをテストする場合
expect(@user).to be_valid
次に正しくないことをテストする場合
expect(@user).not_to be_valid
---------------------------------------------------------------------------------------
データベースのインデックス migrationにadd_index
これは本の索引みたいなもの。情報を調べに行く
索引がなければ最初から最後までみていかなければならないuser.firstからuser.lastまで(full scan)
索引があれば1回の手間で済む。
def change
create_table :users do |t|
t.string :name, null:false
t.string :email, null:false
t.timestamps
end
add_index :users, :email, unique: true
ここ!! emailを調べにいける。 unique: trueは別
end
end
---------------------------------------------------------------------------------------
メールアドレス 大文字小文字を区別しないようにする
userを保存する前にモデル内のbefore_saveでemailをdowncaseにする!
class User < ApplicationRecord
before_save { self.email = email.downcase }
ここ!!
# before_save { email.downcase! } こっちでもいいよ
validates :name, presence: true, length: { maximum: 50 }
VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-]+(\.[a-z\d\-]+)*\.[a-z]+\z/i
validates :email, presence: true, length: { maximum: 255 },
format: { with: VALID_EMAIL_REGEX },
uniqueness: true
has_secure_password
validates :password, presence: true, length: { minimum: 6 }
end
---------------------------------------------------------------------------------------
has_secure_password
・ハッシュ化したパスワードをpassword_digestという属性に保存できる。
・passwordとpassword_confirmstionが使えるようになる。
・authenticateメソッドを使えるようになる。
これはpasswordと、ハッシュ化されたpassword_digestを比較できる。
**has_secure_passwordを使うためにはbycryptというgemを導入する必要がある。
---------------------------------------------------------------------------------------
テストコード(Rspec使用)
RSpec.describe User, type: :model do
before do
@user = User.new(name: "Example User", email: "user@example.com",password: "foobar", password_confirmation: "foobar")
end
it 'should be valid' do
expect(@user).to be_valid
end
it "name should be present" do
@user.name = " "
expect(@user).not_to be_valid
end
it "email should be present" do
@user.email = " "
expect(@user).not_to be_valid
end
it "name should not be too long" do
@user.name = "a" * 51
expect(@user).not_to be_valid
end
it "email should not be too long" do
expect(@user).not_to be_valid
end
it "email validation should accept valid addresses" do
valid_addresses = %w[user@example.com USER@foo.COM A_US-ER@foo.bar.org
first.last@foo.jp alice+bob@baz.cn]
valid_addresses.each do |valid_address|
@user.email = valid_address
expect(@user).to be_valid
# @user.valid?, "#{valid_address.inspect} should be valid"
end
end
it "email validation should reject invalid addresses" do
invalid_addresses = %w[user@example,com user_at_foo.org user.name@example.
foo@bar_baz.com foo@bar+baz.com foo@bar..com]
invalid_addresses.each do |invalid_address|
@user.email = invalid_address
expect(@user).not_to be_valid
end
end
it "email addresses should be unique" do
duplicate_user = @user.dup
# duplicate_user.email = @user.email.upcase
# モデル内のbefore actionでdowncaseにするようにしたので必要なくなった
@user.save
expect(duplicate_user).not_to be_valid
end
it "email addresses should be saved as lower-case" do
@user.email = mixed_case_email
@user.save
expect(mixed_case_email.downcase).to eq(@user.reload.email)
end
it "password should be present (nonblank)" do
@user.password = @user.password_confirmation = " " * 6
expect(@user).not_to be_valid
end
it "password should have a minimum length" do
@user.password = @user.password_confirmation = "a" * 5
expect(@user).not_to be_valid
end
end
以上で6章終わりです!