Skip to content
Extraits de code Groupes Projets
status_messages_controller_spec.rb 7,94 ko
Newer Older
  • Learn to ignore specific revisions
  • danielgrippi's avatar
    danielgrippi a validé
    #   Copyright (c) 2010-2011, Diaspora Inc.  This file is
    
    #   licensed under the Affero General Public License version 3 or later.  See
    #   the COPYRIGHT file.
    
    
    describe StatusMessagesController, :type => :controller do
    
    cmrd Senya's avatar
    cmrd Senya a validé
        sign_in alice, scope: :user
    
        allow(@controller).to receive(:current_user).and_return(alice)
    
      describe '#bookmarklet' do
        it 'succeeds' do
          get :bookmarklet
    
          expect(response).to be_success
    
        end
    
        it 'contains a complete html document' do
          get :bookmarklet
    
          doc = Nokogiri(response.body)
    
          expect(doc.xpath('//head').count).to equal 1
          expect(doc.xpath('//body').count).to equal 1
    
          get :bookmarklet, { url:   'https://www.youtube.com/watch?v=0Bmhjf0rKe8',
                              title: 'Surprised Kitty',
                              notes: 'cute kitty' }
    
          expect(response).to be_success
    
      describe '#new' do
        it 'succeeds' do
    
          get :new, :person_id => bob.person.id
    
          expect(response).to be_success
    
        it 'should redirect on desktop version' do
          get :new
    
          expect(response).to redirect_to(stream_path)
    
        let(:text) { "facebook, is that you?" }
    
          {
            status_message: {text: text},
            aspect_ids:     [@aspect1.id.to_s]
          }
    
        it 'creates with valid json' do
          post :create, status_message_hash.merge(:format => 'json')
    
          expect(response.status).to eq(201)
    
        it 'creates with invalid json' do
          post :create, status_message_hash.merge(:status_message => { :text => "0123456789" * 7000 }, :format => 'json')
    
          expect(response.status).to eq(403)
    
        it 'creates with valid mobile' do
          post :create, status_message_hash.merge(:format => 'mobile')
    
          expect(response.status).to eq(302)
          expect(response).to be_redirect
    
        it 'creates with invalid mobile' do
          post :create, status_message_hash.merge(:status_message => { :text => "0123456789" * 7000 }, :format => 'mobile')
    
          expect(response.status).to eq(302)
          expect(response).to be_redirect
    
        it 'removes getting started from new users' do
    
          expect(@controller).to receive(:remove_getting_started)
    
          post :create, status_message_hash
        end
    
        context "with aspect_ids" do
          before do
            @aspect2 = alice.aspects.create(name: "another aspect")
          end
    
          it "takes one aspect as array in aspect_ids" do
            post :create, status_message_hash
            expect(response.status).to eq(302)
            status_message = StatusMessage.find_by_text(text)
            expect(status_message.aspect_visibilities.map(&:aspect)).to eq([@aspect1])
          end
    
          it "takes one aspect as string in aspect_ids" do
            post :create, status_message_hash.merge(aspect_ids: @aspect1.id.to_s)
            expect(response.status).to eq(302)
            status_message = StatusMessage.find_by_text(text)
            expect(status_message.aspect_visibilities.map(&:aspect)).to eq([@aspect1])
          end
    
          it "takes public as array in aspect_ids" do
            post :create, status_message_hash.merge(aspect_ids: ["public"])
            expect(response.status).to eq(302)
            status_message = StatusMessage.find_by_text(text)
            expect(status_message.public).to be_truthy
          end
    
          it "takes public as string in aspect_ids" do
            post :create, status_message_hash.merge(aspect_ids: "public")
            expect(response.status).to eq(302)
            status_message = StatusMessage.find_by_text(text)
            expect(status_message.public).to be_truthy
          end
    
          it "takes all_aspects as array in aspect_ids" do
            post :create, status_message_hash.merge(aspect_ids: ["all_aspects"])
            expect(response.status).to eq(302)
            status_message = StatusMessage.find_by_text(text)
            expect(status_message.aspect_visibilities.map(&:aspect)).to match_array([@aspect1, @aspect2])
          end
    
          it "takes all_aspects as string in aspect_ids" do
            post :create, status_message_hash.merge(aspect_ids: "all_aspects")
            expect(response.status).to eq(302)
            status_message = StatusMessage.find_by_text(text)
            expect(status_message.aspect_visibilities.map(&:aspect)).to match_array([@aspect1, @aspect2])
          end
    
        it "dispatches the post to the specified services" do
    
          s1 = Services::Facebook.new
    
          alice.services << s1
          alice.services << Services::Twitter.new
    
          status_message_hash[:services] = ['facebook']
    
          service_types = Service.titles(status_message_hash[:services])
    
          expect(alice).to receive(:dispatch_post).with(anything(), hash_including(:service_types => service_types))
    
    zhitomirskiyi's avatar
    zhitomirskiyi a validé
          post :create, status_message_hash
        end
    
    
        it "works if services is a string" do
          s1 = Services::Facebook.new
          alice.services << s1
          status_message_hash[:services] = "facebook"
    
          expect(alice).to receive(:dispatch_post).with(anything(), hash_including(:service_types => ["Services::Facebook"]))
    
          post :create, status_message_hash
        end
    
    
        it "doesn't overwrite author_id" do
    
          status_message_hash[:status_message][:author_id] = bob.person.id
    
          new_message = StatusMessage.find_by_text(text)
    
          expect(new_message.author_id).to eq(alice.person.id)
    
          old_status_message = alice.post(:status_message, :text => "hello", :to => @aspect1.id)
    
          status_message_hash[:status_message][:id] = old_status_message.id
          post :create, status_message_hash
    
          expect(old_status_message.reload.text).to eq('hello')
    
        it "calls dispatch post once subscribers is set" do
          expect(alice).to receive(:dispatch_post) {|post, _opts|
            expect(post.subscribers).to eq([bob.person])
    
          }
          post :create, status_message_hash
        end
    
        it 'respsects provider_display_name' do
          status_message_hash.merge!(:aspect_ids => ['public'])
          status_message_hash[:status_message].merge!(:provider_display_name => "mobile")
          post :create, status_message_hash
    
          expect(StatusMessage.first.provider_display_name).to eq('mobile')
    
        it "has no participation" do
    
          post :create, status_message_hash
    
          new_message = StatusMessage.find_by_text(text)
    
          expect(new_message.participations.count).to eq(0)
    
            @photo1 = alice.build_post(:photo, :pending => true, :user_file=> File.open(photo_fixture_name), :to => @aspect1.id)
            @photo2 = alice.build_post(:photo, :pending => true, :user_file=> File.open(photo_fixture_name), :to => @aspect1.id)
    
    
            @photo1.save!
            @photo2.save!
    
            @hash = status_message_hash
            @hash[:photos] = [@photo1.id.to_s, @photo2.id.to_s]
          end
    
    Raphael Sofaer's avatar
    Raphael Sofaer a validé
          it "will post a photo without text" do
    
    Raphael Sofaer's avatar
    Raphael Sofaer a validé
            post :create, @hash
    
            expect(response).to be_redirect
    
    Raphael Sofaer's avatar
    Raphael Sofaer a validé
          end
    
            status_message = StatusMessage.find_by_text(text)
    
            expect(status_message.photos.map(&:id)).to match_array([@photo1, @photo2].map(&:id))
    
          it "sets the pending bit of referenced photos" do
    
    Jonne Haß's avatar
    Jonne Haß a validé
            inlined_jobs do
    
            expect(@photo1.reload.pending).to be false
            expect(@photo2.reload.pending).to be false
    
    
      describe '#remove_getting_started' do
        it 'removes the getting started flag from new users' do
          alice.getting_started = true
          alice.save
    
          expect {
            @controller.send(:remove_getting_started)
          }.to change {
    
            alice.reload.getting_started
          }.from(true).to(false)
        end
    
        it 'does nothing for returning users' do
    
          expect {
            @controller.send(:remove_getting_started)
          }.to_not change {