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