user_spec.rb 1.49 KB
describe User do
  context 'validations' do
    it 'require that a name is present' do
      user = Fabricate.build(:user, :name => nil)
      expect(user).to_not be_valid
      expect(user.errors[:name]).to include("can't be blank")
    end

    it 'requires password without github login' do
      user = Fabricate.build(:user, :password => nil)
      expect(user).to_not be_valid
      expect(user.errors[:password]).to include("can't be blank")
    end

    it "doesn't require password with github login" do
      user = Fabricate.build(:user, :password => nil, :github_login => 'nashby')
      expect(user).to be_valid
    end

    it 'requires uniq github login' do
      user1 = Fabricate(:user, :github_login => 'nashby')
      expect(user1).to be_valid

      user2 = Fabricate.build(:user, :github_login => 'nashby')
      user2.save
      expect(user2).to_not be_valid
      expect(user2.errors[:github_login]).to include("is already taken")
    end

    it 'allows blank / null github_login' do
      user1 = Fabricate(:user, :github_login => ' ')
      expect(user1).to be_valid

      user2 = Fabricate.build(:user, :github_login => ' ')
      user2.save
      expect(user2).to be_valid
    end
  end

  context "First user" do
    it "should be created this admin access via db:seed" do
      expect {
        allow($stdout).to receive(:puts).and_return(true)
        require Rails.root.join('db/seeds.rb')
      }.to change {
        User.where(:admin => true).count
      }.from(0).to(1)
    end
  end
end