Skip to content
Extraits de code Groupes Projets
users_controller_spec.rb 8,27 ko
Newer Older
  • Learn to ignore specific revisions
  • danielgrippi's avatar
    danielgrippi a validé
    #   Copyright (c) 2010-2011, Diaspora Inc.  This file is
    
    Raphael's avatar
    Raphael a validé
    #   licensed under the Affero General Public License version 3 or later.  See
    
    #   the COPYRIGHT file.
    
    require 'spec_helper'
    
    describe UsersController do
      before do
    
        @user = alice
        @aspect = @user.aspects.first
    
        @aspect1 = @user.aspects.create(:name => "super!!")
    
        sign_in :user, @user
    
        @controller.stub(:current_user).and_return(@user)
    
      describe '#export' do
    
        it 'returns an xml file'  do
    
          get :export
          response.header["Content-Type"].should include "application/xml"
        end
      end
    
    
      describe '#export_photos' do
        it 'returns a tar file'  do
          get :export_photos
          response.header["Content-Type"].should include "application/octet-stream"
        end
      end
    
    
      describe 'user_photo' do
        it 'should return the url of the users profile photo' do
          get :user_photo, :username => @user.username
          response.should redirect_to(@user.profile.image_url)
        end
    
        it 'should 404 if no user is found' do
          get :user_photo, :username => 'none'
          response.should_not be_success
    
        it 'renders xml if atom is requested' do
    
          sm = Factory(:status_message, :public => true, :author => @user.person)
    
          get :public, :username => @user.username, :format => :atom
    
          response.body.should include(sm.raw_message)
    
        it 'renders xml if atom is requested with clickalbe urls' do
    
          sm = Factory(:status_message, :public => true, :author => @user.person)
    
          @user.person.posts.each do |p|
            p.text = "Goto http://diasporaproject.org/ now!"
            p.save
          end
          get :public, :username => @user.username, :format => :atom
    
          response.body.should include('a href')
    
    
        it 'redirects to a profile page if html is requested' do
          get :public, :username => @user.username
          response.should be_redirect
        end
    
        it 'redirects to a profile page if mobile is requested' do
          get :public, :username => @user.username, :format => :mobile
          response.should be_redirect
        end
    
        before do
          @params  = { :id => @user.id,
    
                      :user => { :diaspora_handle => "notreal@stuff.com" } }
    
        it "doesn't overwrite random attributes" do
    
          }.should_not change(@user, :diaspora_handle)
    
        it 'redirects to the user edit page' do
          put :update, @params
    
          response.should redirect_to edit_user_path
    
    Raphael Sofaer's avatar
    Raphael Sofaer a validé
        it 'responds with a 204 on a js request' do
    
          put :update, @params.merge(:format => :js)
    
    Raphael Sofaer's avatar
    Raphael Sofaer a validé
          response.status.should == 204
    
        context 'password updates' do
    
          before do
            @password_params = {:current_password => 'bluepin7',
                                :password => "foobaz",
                                :password_confirmation => "foobaz"}
    
          it "uses devise's update with password" do
            @user.should_receive(:update_with_password).with(hash_including(@password_params))
            @controller.stub!(:current_user).and_return(@user)
            put :update, :id => @user.id, :user => @password_params
    
          it 'allow the user to change his language' do
            old_language = 'en'
    
            @user.language = old_language
            @user.save
            put(:update, :id => @user.id, :user =>
    
                { :language => "fr"}
               )
    
            @user.reload
            @user.language.should_not == old_language
    
          it 'allow the user to change his (unconfirmed) email' do
            put(:update, :id => @user.id, :user => { :email => "my@newemail.com"})
            @user.reload
            @user.unconfirmed_email.should eql("my@newemail.com")
          end
    
          it 'informs the user about success' do
            put(:update, :id => @user.id, :user => { :email => "my@newemail.com"})
            request.flash[:notice].should eql(I18n.t('users.update.unconfirmed_email_changed'))
            request.flash[:error].should be_blank
          end
    
          it 'informs the user about failure' do
            put(:update, :id => @user.id, :user => { :email => "my@newemailcom"})
            request.flash[:error].should eql(I18n.t('users.update.unconfirmed_email_not_changed'))
            request.flash[:notice].should be_blank
          end
    
          it 'allow the user to change his (unconfirmed) email to blank (= abort confirmation)' do
            put(:update, :id => @user.id, :user => { :email => ""})
            @user.reload
            @user.unconfirmed_email.should eql(nil)
          end
    
          it 'sends out activation email on success' do
    
            Resque.should_receive(:enqueue).with(Jobs::Mail::ConfirmEmail, @user.id).once
    
            put(:update, :id => @user.id, :user => { :email => "my@newemail.com"})
          end
    
        describe 'email settings' do
          it 'lets the user turn off mail' do
            par = {:id => @user.id, :user => {:email_preferences => {'mentioned' => 'true'}}}
            proc{
              put :update, par
            }.should change(@user.user_preferences, :count).by(1)
          end
    
          it 'lets the user get mail again' do
            @user.user_preferences.create(:email_type => 'mentioned')
            par = {:id => @user.id, :user => {:email_preferences => {'mentioned' => 'false'}}}
            proc{
              put :update, par
            }.should change(@user.user_preferences, :count).by(-1)
          end
        end
    
      describe '#privacy_settings' do
        it "returns a 200" do
          get 'privacy_settings'
          response.status.should == 200
        end
      end
    
    
      describe '#edit' do
        it "returns a 200" do
    
          get 'edit', :id => @user.id
    
          response.status.should == 200
    
    maxwell's avatar
    maxwell a validé
    
        it 'set @email_pref to false when there is a user pref' do
          @user.user_preferences.create(:email_type => 'mentioned')
          get 'edit', :id => @user.id
          assigns[:email_prefs]['mentioned'].should be_false
        end
    
    
        it 'does not allow token auth' do
          sign_out :user
          bob.reset_authentication_token!
          get :edit, :auth_token => bob.authentication_token
          response.should redirect_to new_user_session_path
        end
    
        it 'does nothing if the password does not match' do
          Resque.should_not_receive(:enqueue)
    
    Sarah Mei's avatar
    Sarah Mei a validé
          delete :destroy, :user => { :current_password => "stuff" }
    
        it 'closes the account' do
          alice.should_receive(:close_account!)
    
    Sarah Mei's avatar
    Sarah Mei a validé
          delete :destroy, :user => { :current_password => "bluepin7" }
    
    danielgrippi's avatar
    danielgrippi a validé
          Resque.should_receive(:enqueue).with(Jobs::DeleteAccount, anything)
    
    Sarah Mei's avatar
    Sarah Mei a validé
          delete :destroy, :user => { :current_password => "bluepin7" }
    
      describe '#confirm_email' do
        before do
          @user.update_attribute(:unconfirmed_email, 'my@newemail.com')
        end
    
        it 'redirects to to the user edit page' do
          get 'confirm_email', :token => @user.confirm_email_token
          response.should redirect_to edit_user_path
        end
    
        it 'confirms email' do
          get 'confirm_email', :token => @user.confirm_email_token
          @user.reload
          @user.email.should eql('my@newemail.com')
          request.flash[:notice].should eql(I18n.t('users.confirm_email.email_confirmed', :email => 'my@newemail.com'))
          request.flash[:error].should be_blank
        end
    
        it 'does NOT confirm email with wrong token' do
          get 'confirm_email', :token => @user.confirm_email_token.reverse
          @user.reload
          @user.email.should_not eql('my@newemail.com')
          request.flash[:error].should eql(I18n.t('users.confirm_email.email_not_confirmed'))
          request.flash[:notice].should be_blank
        end
      end
    
    
      describe 'getting_started' do
        it 'does not fail miserably' do
    
          get :getting_started
          response.should be_success
    
          get :getting_started, :format => :mobile
          response.should be_success
    
    
      # This logic lives in application controller
      describe "#after_sign_in_path_for" do
        before do
          @controller.stub(:current_user).and_return(eve)
        end
    
        context 'getting started true on user' do
          before do
            eve.update_attribute(:getting_started, true)
          end
    
          it "redirects to getting started if the user has getting started set to true" do
            @controller.after_sign_in_path_for(eve).should == getting_started_path
          end
        end
      end