2015-04-26 12:48:37 +05:30
|
|
|
require('spec_helper')
|
|
|
|
|
|
|
|
describe Projects::UploadsController do
|
2017-09-10 17:25:29 +05:30
|
|
|
let(:project) { create(:project) }
|
2015-04-26 12:48:37 +05:30
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:jpg) { fixture_file_upload(Rails.root + 'spec/fixtures/rails_sample.jpg', 'image/jpg') }
|
|
|
|
let(:txt) { fixture_file_upload(Rails.root + 'spec/fixtures/doc_sample.txt', 'text/plain') }
|
|
|
|
|
|
|
|
describe "POST #create" do
|
|
|
|
before do
|
|
|
|
sign_in(user)
|
|
|
|
project.team << [user, :developer]
|
|
|
|
end
|
|
|
|
|
|
|
|
context "without params['file']" do
|
|
|
|
it "returns an error" do
|
2016-08-24 12:49:21 +05:30
|
|
|
post :create,
|
2015-04-26 12:48:37 +05:30
|
|
|
namespace_id: project.namespace.to_param,
|
2017-08-17 22:00:37 +05:30
|
|
|
project_id: project,
|
2015-04-26 12:48:37 +05:30
|
|
|
format: :json
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(422)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with valid image' do
|
|
|
|
before do
|
|
|
|
post :create,
|
|
|
|
namespace_id: project.namespace.to_param,
|
2017-08-17 22:00:37 +05:30
|
|
|
project_id: project,
|
2015-04-26 12:48:37 +05:30
|
|
|
file: jpg,
|
|
|
|
format: :json
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a content with original filename, new link, and correct type.' do
|
|
|
|
expect(response.body).to match '\"alt\":\"rails_sample\"'
|
2015-10-24 18:46:33 +05:30
|
|
|
expect(response.body).to match "\"url\":\"/uploads"
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
# NOTE: This is as close as we're getting to an Integration test for this
|
|
|
|
# behavior. We're avoiding a proper Feature test because those should be
|
|
|
|
# testing things entirely user-facing, which the Upload model is very much
|
|
|
|
# not.
|
|
|
|
it 'creates a corresponding Upload record' do
|
|
|
|
upload = Upload.last
|
|
|
|
|
|
|
|
aggregate_failures do
|
|
|
|
expect(upload).to exist
|
|
|
|
expect(upload.model).to eq project
|
|
|
|
end
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context 'with valid non-image file' do
|
|
|
|
before do
|
2016-08-24 12:49:21 +05:30
|
|
|
post :create,
|
2015-04-26 12:48:37 +05:30
|
|
|
namespace_id: project.namespace.to_param,
|
2017-08-17 22:00:37 +05:30
|
|
|
project_id: project,
|
2016-08-24 12:49:21 +05:30
|
|
|
file: txt,
|
2015-04-26 12:48:37 +05:30
|
|
|
format: :json
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a content with original filename, new link, and correct type.' do
|
|
|
|
expect(response.body).to match '\"alt\":\"doc_sample.txt\"'
|
2015-10-24 18:46:33 +05:30
|
|
|
expect(response.body).to match "\"url\":\"/uploads"
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET #show" do
|
|
|
|
let(:go) do
|
|
|
|
get :show,
|
|
|
|
namespace_id: project.namespace.to_param,
|
2017-08-17 22:00:37 +05:30
|
|
|
project_id: project,
|
2015-04-26 12:48:37 +05:30
|
|
|
secret: "123456",
|
|
|
|
filename: "image.jpg"
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the project is public" do
|
|
|
|
before do
|
|
|
|
project.update_attribute(:visibility_level, Project::PUBLIC)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when not signed in" do
|
|
|
|
context "when the file exists" do
|
|
|
|
before do
|
|
|
|
allow_any_instance_of(FileUploader).to receive(:file).and_return(jpg)
|
|
|
|
allow(jpg).to receive(:exists?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "responds with status 200" do
|
|
|
|
go
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(200)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file doesn't exist" do
|
|
|
|
it "responds with status 404" do
|
|
|
|
go
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(404)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when signed in" do
|
|
|
|
before do
|
|
|
|
sign_in(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file exists" do
|
|
|
|
before do
|
|
|
|
allow_any_instance_of(FileUploader).to receive(:file).and_return(jpg)
|
|
|
|
allow(jpg).to receive(:exists?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "responds with status 200" do
|
|
|
|
go
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(200)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file doesn't exist" do
|
|
|
|
it "responds with status 404" do
|
|
|
|
go
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(404)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the project is private" do
|
|
|
|
before do
|
|
|
|
project.update_attribute(:visibility_level, Project::PRIVATE)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when not signed in" do
|
|
|
|
context "when the file exists" do
|
|
|
|
before do
|
|
|
|
allow_any_instance_of(FileUploader).to receive(:file).and_return(jpg)
|
|
|
|
allow(jpg).to receive(:exists?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file is an image" do
|
|
|
|
before do
|
|
|
|
allow_any_instance_of(FileUploader).to receive(:image?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "responds with status 200" do
|
|
|
|
go
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(200)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file is not an image" do
|
|
|
|
it "redirects to the sign in page" do
|
|
|
|
go
|
|
|
|
|
|
|
|
expect(response).to redirect_to(new_user_session_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file doesn't exist" do
|
|
|
|
it "redirects to the sign in page" do
|
|
|
|
go
|
|
|
|
|
|
|
|
expect(response).to redirect_to(new_user_session_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when signed in" do
|
|
|
|
before do
|
|
|
|
sign_in(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the user has access to the project" do
|
|
|
|
before do
|
|
|
|
project.team << [user, :master]
|
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
context "when the file exists" do
|
2015-04-26 12:48:37 +05:30
|
|
|
before do
|
2017-08-17 22:00:37 +05:30
|
|
|
allow_any_instance_of(FileUploader).to receive(:file).and_return(jpg)
|
|
|
|
allow(jpg).to receive(:exists?).and_return(true)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
it "responds with status 200" do
|
|
|
|
go
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(response).to have_http_status(200)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
context "when the file doesn't exist" do
|
|
|
|
it "responds with status 404" do
|
|
|
|
go
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(response).to have_http_status(404)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the user doesn't have access to the project" do
|
|
|
|
context "when the file exists" do
|
|
|
|
before do
|
|
|
|
allow_any_instance_of(FileUploader).to receive(:file).and_return(jpg)
|
|
|
|
allow(jpg).to receive(:exists?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file is an image" do
|
|
|
|
before do
|
|
|
|
allow_any_instance_of(FileUploader).to receive(:image?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "responds with status 200" do
|
|
|
|
go
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(200)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file is not an image" do
|
|
|
|
it "responds with status 404" do
|
|
|
|
go
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(404)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the file doesn't exist" do
|
|
|
|
it "responds with status 404" do
|
|
|
|
go
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(response).to have_http_status(404)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|