diff options
author | eregon <eregon@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-05-07 12:04:49 +0000 |
---|---|---|
committer | eregon <eregon@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-05-07 12:04:49 +0000 |
commit | 95e8c48dd3348503a8c7db5d0498894a1b676395 (patch) | |
tree | 9eef7f720314ebaff56845a74e203770e62284e4 /spec/rubyspec/library/uri/mailto | |
parent | ed7d803500de38186c74bce94d233e85ef51e503 (diff) | |
download | ruby-95e8c48dd3348503a8c7db5d0498894a1b676395.tar.gz |
Add in-tree mspec and ruby/spec
* For easier modifications of ruby/spec by MRI developers.
* .gitignore: track changes under spec.
* spec/mspec, spec/rubyspec: add in-tree mspec and ruby/spec.
These files can therefore be updated like any other file in MRI.
Instructions are provided in spec/README.
[Feature #13156] [ruby-core:79246]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@58595 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'spec/rubyspec/library/uri/mailto')
-rw-r--r-- | spec/rubyspec/library/uri/mailto/build_spec.rb | 98 | ||||
-rw-r--r-- | spec/rubyspec/library/uri/mailto/headers_spec.rb | 10 | ||||
-rw-r--r-- | spec/rubyspec/library/uri/mailto/set_headers_spec.rb | 6 | ||||
-rw-r--r-- | spec/rubyspec/library/uri/mailto/set_to_spec.rb | 6 | ||||
-rw-r--r-- | spec/rubyspec/library/uri/mailto/to_mailtext_spec.rb | 6 | ||||
-rw-r--r-- | spec/rubyspec/library/uri/mailto/to_rfc822text_spec.rb | 6 | ||||
-rw-r--r-- | spec/rubyspec/library/uri/mailto/to_s_spec.rb | 6 | ||||
-rw-r--r-- | spec/rubyspec/library/uri/mailto/to_spec.rb | 10 |
8 files changed, 148 insertions, 0 deletions
diff --git a/spec/rubyspec/library/uri/mailto/build_spec.rb b/spec/rubyspec/library/uri/mailto/build_spec.rb new file mode 100644 index 0000000000..cb57f0c794 --- /dev/null +++ b/spec/rubyspec/library/uri/mailto/build_spec.rb @@ -0,0 +1,98 @@ +require File.expand_path('../../../../spec_helper', __FILE__) +require 'uri' + +describe "URI::Mailto.build" do + it "conforms to the MatzRuby tests" do + ok = [] + bad = [] + + # RFC2368, 6. Examples + # mailto:chris@example.com + ok << ["mailto:chris@example.com"] + ok[-1] << ["chris@example.com", nil] + ok[-1] << {to: "chris@example.com"} + + # mailto:infobot@example.com?subject=current-issue + ok << ["mailto:infobot@example.com?subject=current-issue"] + ok[-1] << ["infobot@example.com", ["subject=current-issue"]] + ok[-1] << {to: "infobot@example.com", + headers: ["subject=current-issue"]} + + # mailto:infobot@example.com?body=send%20current-issue + ok << ["mailto:infobot@example.com?body=send%20current-issue"] + ok[-1] << ["infobot@example.com", ["body=send%20current-issue"]] + ok[-1] << {to: "infobot@example.com", + headers: ["body=send%20current-issue"]} + + # mailto:infobot@example.com?body=send%20current-issue%0D%0Asend%20index + ok << ["mailto:infobot@example.com?body=send%20current-issue%0D%0Asend%20index"] + ok[-1] << ["infobot@example.com", + ["body=send%20current-issue%0D%0Asend%20index"]] + ok[-1] << {to: "infobot@example.com", + headers: ["body=send%20current-issue%0D%0Asend%20index"]} + + # mailto:foobar@example.com?In-Reply-To=%3c3469A91.D10AF4C@example.com + ok << ["mailto:foobar@example.com?In-Reply-To=%3c3469A91.D10AF4C@example.com"] + ok[-1] << ["foobar@example.com", + ["In-Reply-To=%3c3469A91.D10AF4C@example.com"]] + ok[-1] << {to: "foobar@example.com", + headers: ["In-Reply-To=%3c3469A91.D10AF4C@example.com"]} + + # mailto:majordomo@example.com?body=subscribe%20bamboo-l + ok << ["mailto:majordomo@example.com?body=subscribe%20bamboo-l"] + ok[-1] << ["majordomo@example.com", ["body=subscribe%20bamboo-l"]] + ok[-1] << {to: "majordomo@example.com", + headers: ["body=subscribe%20bamboo-l"]} + + # mailto:joe@example.com?cc=bob@example.com&body=hello + ok << ["mailto:joe@example.com?cc=bob@example.com&body=hello"] + ok[-1] << ["joe@example.com", ["cc=bob@example.com", "body=hello"]] + ok[-1] << {to: "joe@example.com", + headers: ["cc=bob@example.com", "body=hello"]} + + # mailto:?to=joe@example.com&cc=bob@example.com&body=hello + ok << ["mailto:?to=joe@example.com&cc=bob@example.com&body=hello"] + ok[-1] << [nil, + ["to=joe@example.com", "cc=bob@example.com", "body=hello"]] + ok[-1] << {headers: ["to=joe@example.com", "cc=bob@example.com", "body=hello"]} + + # mailto:gorby%25kremvax@example.com + ok << ["mailto:gorby%25kremvax@example.com"] + ok[-1] << ["gorby%25kremvax@example.com", nil] + ok[-1] << {to: "gorby%25kremvax@example.com"} + + # mailto:unlikely%3Faddress@example.com?blat=foop + ok << ["mailto:unlikely%3Faddress@example.com?blat=foop"] + ok[-1] << ["unlikely%3Faddress@example.com", ["blat=foop"]] + ok[-1] << {to: "unlikely%3Faddress@example.com", + headers: ["blat=foop"]} + + ok_all = ok.flatten.join("\0") + + # mailto:joe@example.com?cc=bob@example.com?body=hello ; WRONG! + bad << ["joe@example.com", ["cc=bob@example.com?body=hello"]] + + # mailto:javascript:alert() + bad << ["javascript:alert()", []] + + # '=' which is in hname or hvalue is wrong. + bad << ["foo@example.jp?subject=1+1=2", []] + + ok.each do |x| + URI::MailTo.build(x[1]).to_s.should == x[0] + URI::MailTo.build(x[2]).to_s.should == x[0] + end + + bad.each do |x| + lambda { URI::MailTo.build(x) }.should raise_error(URI::InvalidComponentError) + end + + ok.flatten.join("\0").should == ok_all + end +end + + + +describe "URI::MailTo.build" do + it "needs to be reviewed for spec completeness" +end diff --git a/spec/rubyspec/library/uri/mailto/headers_spec.rb b/spec/rubyspec/library/uri/mailto/headers_spec.rb new file mode 100644 index 0000000000..844fdee714 --- /dev/null +++ b/spec/rubyspec/library/uri/mailto/headers_spec.rb @@ -0,0 +1,10 @@ +require File.expand_path('../../../../spec_helper', __FILE__) +require 'uri' + +describe "URI::MailTo#headers" do + it "needs to be reviewed for spec completeness" +end + +describe "URI::MailTo#headers=" do + it "needs to be reviewed for spec completeness" +end diff --git a/spec/rubyspec/library/uri/mailto/set_headers_spec.rb b/spec/rubyspec/library/uri/mailto/set_headers_spec.rb new file mode 100644 index 0000000000..c1384d5dca --- /dev/null +++ b/spec/rubyspec/library/uri/mailto/set_headers_spec.rb @@ -0,0 +1,6 @@ +require File.expand_path('../../../../spec_helper', __FILE__) +require 'uri' + +describe "URI::MailTo#set_headers" do + it "needs to be reviewed for spec completeness" +end diff --git a/spec/rubyspec/library/uri/mailto/set_to_spec.rb b/spec/rubyspec/library/uri/mailto/set_to_spec.rb new file mode 100644 index 0000000000..a8351a2092 --- /dev/null +++ b/spec/rubyspec/library/uri/mailto/set_to_spec.rb @@ -0,0 +1,6 @@ +require File.expand_path('../../../../spec_helper', __FILE__) +require 'uri' + +describe "URI::MailTo#set_to" do + it "needs to be reviewed for spec completeness" +end diff --git a/spec/rubyspec/library/uri/mailto/to_mailtext_spec.rb b/spec/rubyspec/library/uri/mailto/to_mailtext_spec.rb new file mode 100644 index 0000000000..4c7a48874f --- /dev/null +++ b/spec/rubyspec/library/uri/mailto/to_mailtext_spec.rb @@ -0,0 +1,6 @@ +require File.expand_path('../../../../spec_helper', __FILE__) +require 'uri' + +describe "URI::MailTo#to_mailtext" do + it "needs to be reviewed for spec completeness" +end diff --git a/spec/rubyspec/library/uri/mailto/to_rfc822text_spec.rb b/spec/rubyspec/library/uri/mailto/to_rfc822text_spec.rb new file mode 100644 index 0000000000..e769f62deb --- /dev/null +++ b/spec/rubyspec/library/uri/mailto/to_rfc822text_spec.rb @@ -0,0 +1,6 @@ +require File.expand_path('../../../../spec_helper', __FILE__) +require 'uri' + +describe "URI::MailTo#to_rfc822text" do + it "needs to be reviewed for spec completeness" +end diff --git a/spec/rubyspec/library/uri/mailto/to_s_spec.rb b/spec/rubyspec/library/uri/mailto/to_s_spec.rb new file mode 100644 index 0000000000..2709d19d27 --- /dev/null +++ b/spec/rubyspec/library/uri/mailto/to_s_spec.rb @@ -0,0 +1,6 @@ +require File.expand_path('../../../../spec_helper', __FILE__) +require 'uri' + +describe "URI::MailTo#to_s" do + it "needs to be reviewed for spec completeness" +end diff --git a/spec/rubyspec/library/uri/mailto/to_spec.rb b/spec/rubyspec/library/uri/mailto/to_spec.rb new file mode 100644 index 0000000000..f30d23dd53 --- /dev/null +++ b/spec/rubyspec/library/uri/mailto/to_spec.rb @@ -0,0 +1,10 @@ +require File.expand_path('../../../../spec_helper', __FILE__) +require 'uri' + +describe "URI::MailTo#to" do + it "needs to be reviewed for spec completeness" +end + +describe "URI::MailTo#to=" do + it "needs to be reviewed for spec completeness" +end |