Railsチュートリアル6章

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回の手間で済む。

 
class CreateUsers < ActiveRecord::Migration[6.0]
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を導入する必要がある。

gem 'bcrypt', '3.1.13'

 

---------------------------------------------------------------------------------------

テストコード(Rspec使用)

 

require 'rails_helper'

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
@user.email = "a" * 244 + "@example.com"
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
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
mixed_case_email = "Foo@ExAMPle.CoM"
@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章終わりです!