Skip to content
Snippets Groups Projects
admin_users_spec.rb 2.83 KiB
Newer Older
  • Learn to ignore specific revisions
  • gitlabhq's avatar
    gitlabhq committed
    require 'spec_helper'
    
    
    describe "Admin::Users", feature: true  do
    
    gitlabhq's avatar
    gitlabhq committed
      before { login_as :admin }
    
      describe "GET /admin/users" do
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
        before do
    
    gitlabhq's avatar
    gitlabhq committed
          visit admin_users_path
        end
    
        it "should be ok" do
          current_path.should == admin_users_path
        end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
        it "should have users list" do
    
    gitlabhq's avatar
    gitlabhq committed
          page.should have_content(@user.email)
          page.should have_content(@user.name)
        end
      end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
      describe "GET /admin/users/new" do
        before do
    
    gitlabhq's avatar
    gitlabhq committed
          visit new_admin_user_path
    
          fill_in "user_name", with: "Big Bang"
    
          fill_in "user_email", with: "bigbang@mail.com"
    
    gitlabhq's avatar
    gitlabhq committed
        end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
        it "should create new user" do
    
          expect { click_button "Create user" }.to change {User.count}.by(1)
    
    gitlabhq's avatar
    gitlabhq committed
        end
    
    
        it "should apply defaults to user" do
          click_button "Create user"
    
    Dmitriy Zaporozhets's avatar
    Dmitriy Zaporozhets committed
          user = User.find_by(username: 'bang')
    
          user.projects_limit.should == Gitlab.config.gitlab.default_projects_limit
          user.can_create_group.should == Gitlab.config.gitlab.default_can_create_group
        end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
        it "should create user with valid data" do
    
          click_button "Create user"
    
    Dmitriy Zaporozhets's avatar
    Dmitriy Zaporozhets committed
          user = User.find_by(username: 'bang')
    
    gitlabhq's avatar
    gitlabhq committed
          user.name.should ==  "Big Bang"
          user.email.should == "bigbang@mail.com"
        end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
        it "should call send mail" do
    
          Notify.should_receive(:new_user_email)
    
          click_button "Create user"
    
    gitlabhq's avatar
    gitlabhq committed
        end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
        it "should send valid email to user with email & password" do
    
          click_button "Create user"
    
    Dmitriy Zaporozhets's avatar
    Dmitriy Zaporozhets committed
          user = User.find_by(username: 'bang')
    
          email = ActionMailer::Base.deliveries.last
          email.subject.should have_content("Account was created")
          email.text_part.body.should have_content(user.email)
          email.text_part.body.should have_content('password')
    
    Marin Jankovski's avatar
    Marin Jankovski committed
        end
    
    gitlabhq's avatar
    gitlabhq committed
      end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
      describe "GET /admin/users/:id" do
        before do
    
    gitlabhq's avatar
    gitlabhq committed
          visit admin_users_path
    
    Saito's avatar
    Saito committed
          click_link "#{@user.name}"
    
    gitlabhq's avatar
    gitlabhq committed
        end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
        it "should have user info" do
    
    gitlabhq's avatar
    gitlabhq committed
          page.should have_content(@user.email)
          page.should have_content(@user.name)
        end
      end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
      describe "GET /admin/users/:id/edit" do
        before do
    
          @simple_user = create(:user)
    
    gitlabhq's avatar
    gitlabhq committed
          visit admin_users_path
          click_link "edit_user_#{@simple_user.id}"
        end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
        it "should have user edit page" do
    
    gitlabhq's avatar
    gitlabhq committed
          page.should have_content("Name")
          page.should have_content("Password")
        end
    
        describe "Update user" do
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
          before do
    
            fill_in "user_name", with: "Big Bang"
            fill_in "user_email", with: "bigbang@mail.com"
    
    gitlabhq's avatar
    gitlabhq committed
            check "user_admin"
    
            click_button "Save changes"
    
    gitlabhq's avatar
    gitlabhq committed
          end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
          it "should show page with  new data" do
    
    gitlabhq's avatar
    gitlabhq committed
            page.should have_content("bigbang@mail.com")
            page.should have_content("Big Bang")
          end
    
    
    Nihad Abbasov's avatar
    Nihad Abbasov committed
          it "should change user entry" do
    
    gitlabhq's avatar
    gitlabhq committed
            @simple_user.reload
            @simple_user.name.should == "Big Bang"
            @simple_user.is_admin?.should be_true
          end
        end
      end
    end