Merge commit 'pd/master'
This commit is contained in:
commit
03308b942f
@ -43,7 +43,8 @@ module Webrat
|
||||
end
|
||||
|
||||
def to_param
|
||||
param_parser.parse_query_parameters("#{name}=#{@value}")
|
||||
value = @value.to_s.gsub('&', '%26')
|
||||
param_parser.parse_query_parameters("#{name}=#{value}")
|
||||
end
|
||||
|
||||
def set(value)
|
||||
@ -239,11 +240,19 @@ module Webrat
|
||||
|
||||
class FileField < Field
|
||||
|
||||
attr_accessor :content_type
|
||||
|
||||
def set(value, content_type = nil)
|
||||
super(value)
|
||||
@content_type = content_type
|
||||
end
|
||||
|
||||
def to_param
|
||||
if @value.nil?
|
||||
super
|
||||
else
|
||||
replace_param_value(super, @value, ActionController::TestUploadedFile.new(@value))
|
||||
file = content_type ? ActionController::TestUploadedFile.new(@value, content_type) : ActionController::TestUploadedFile.new(@value)
|
||||
replace_param_value(super, @value, file)
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -101,13 +101,14 @@ module Webrat
|
||||
|
||||
# Verifies that an input file field exists on the current page and sets
|
||||
# its value to the given +file+, so that the file will be uploaded
|
||||
# along with the form.
|
||||
# along with the form. An optional <tt>content_type</tt> may be given.
|
||||
#
|
||||
# Example:
|
||||
# attaches_file "Photo", "/path/to/the/photo.jpg"
|
||||
def attaches_file(id_or_name_or_label, path)
|
||||
# attaches_file "Resume", "/path/to/the/resume.txt"
|
||||
# attaches_file "Photo", "/path/to/the/image.png", "image/png"
|
||||
def attaches_file(id_or_name_or_label, path, content_type = nil)
|
||||
field = find_field(id_or_name_or_label, FileField)
|
||||
field.set(path)
|
||||
field.set(path, content_type)
|
||||
end
|
||||
|
||||
alias_method :attach_file, :attaches_file
|
||||
|
@ -56,4 +56,17 @@ describe "attaches_file" do
|
||||
@session.attaches_file "Spreadsheet", @filename
|
||||
@session.clicks_button
|
||||
end
|
||||
|
||||
it "should allow the content type to be specified" do
|
||||
@session.response_body = <<-EOS
|
||||
<form method="post" action="/widgets">
|
||||
<label for="person_picture">Picture</label>
|
||||
<input type="file" id="person_picture" name="person[picture]" />
|
||||
<input type="submit" />
|
||||
</form>
|
||||
EOS
|
||||
ActionController::TestUploadedFile.expects(:new).with(@filename, "image/png").returns(@uploaded_file)
|
||||
@session.attaches_file "Picture", @filename, "image/png"
|
||||
@session.clicks_button
|
||||
end
|
||||
end
|
||||
|
@ -48,6 +48,18 @@ describe "selects" do
|
||||
@session.clicks_button
|
||||
end
|
||||
|
||||
it "should send values with HTML encoded ampersands" do
|
||||
@session.response_body = <<-EOS
|
||||
<form method="post" action="/login">
|
||||
<select name="encoded"><option value="A & B">Encoded</option></select>
|
||||
<input type="submit" />
|
||||
</form>
|
||||
EOS
|
||||
@session.expects(:post).with("/login", "encoded" => "A & B")
|
||||
@session.selects "Encoded", :from => "encoded"
|
||||
@session.clicks_button
|
||||
end
|
||||
|
||||
it "should work with empty select lists" do
|
||||
@session.response_body = <<-EOS
|
||||
<form method="post" action="/login">
|
||||
|
Loading…
Reference in New Issue
Block a user