我的观点
<%= form_tag({:action => 'upload_image', :car_id => @car.id}, :multipart => true) do %>
<label for="upload_file"><%= t('field.select_image') %></label>
<%= file_field 'upload', 'datafile' %> <%= submit_tag t('field.upload_file') %>
<% end %>
我的控制器
def upload_image
if params[:upload].present? && params[:car_id].present?
DataFile.save_image_file(params[:upload][:datafile], params[:car_id]) # My methods to save image and other operations with file
end
redirect_to images_path(:car_id => params[:car_id])
end
我的 Rspec 测试(不起作用)
before :each do
@car = FactoryGirl.create(:car)
@file = fixture_file_upload('/files/test-bus-1.jpg', 'image/jpg')
end
it "can upload a car" do
post :upload_image, :upload => @file, :car_id => @car.id
response.should redirect_to images_path(:car_id => @car.id)
end
错误:失败/错误:post :upload_image, :upload => @file, :car_id => @car.id NoMethodError: undefined method `[]' for # File:/tmp/test-bus-1.jpg20120826-29027- plg28d
怎么了?