晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/alt/ruby20/lib64/ruby/gems/2.0.0/gems/rack-1.6.4/test/ |
| Current File : //opt/alt/ruby20/lib64/ruby/gems/2.0.0/gems/rack-1.6.4/test/spec_content_length.rb |
require 'rack/content_length'
require 'rack/lint'
require 'rack/mock'
describe Rack::ContentLength do
def content_length(app)
Rack::Lint.new Rack::ContentLength.new(app)
end
def request
Rack::MockRequest.env_for
end
should "set Content-Length on Array bodies if none is set" do
app = lambda { |env| [200, {'Content-Type' => 'text/plain'}, ["Hello, World!"]] }
response = content_length(app).call(request)
response[1]['Content-Length'].should.equal '13'
end
should "not set Content-Length on variable length bodies" do
body = lambda { "Hello World!" }
def body.each ; yield call ; end
app = lambda { |env| [200, {'Content-Type' => 'text/plain'}, body] }
response = content_length(app).call(request)
response[1]['Content-Length'].should.be.nil
end
should "not change Content-Length if it is already set" do
app = lambda { |env| [200, {'Content-Type' => 'text/plain', 'Content-Length' => '1'}, "Hello, World!"] }
response = content_length(app).call(request)
response[1]['Content-Length'].should.equal '1'
end
should "not set Content-Length on 304 responses" do
app = lambda { |env| [304, {}, []] }
response = content_length(app).call(request)
response[1]['Content-Length'].should.equal nil
end
should "not set Content-Length when Transfer-Encoding is chunked" do
app = lambda { |env| [200, {'Content-Type' => 'text/plain', 'Transfer-Encoding' => 'chunked'}, []] }
response = content_length(app).call(request)
response[1]['Content-Length'].should.equal nil
end
# Using "Connection: close" for this is fairly contended. It might be useful
# to have some other way to signal this.
#
# should "not force a Content-Length when Connection:close" do
# app = lambda { |env| [200, {'Connection' => 'close'}, []] }
# response = content_length(app).call({})
# response[1]['Content-Length'].should.equal nil
# end
should "close bodies that need to be closed" do
body = Struct.new(:body) do
attr_reader :closed
def each; body.join; end
def close; @closed = true; end
def to_ary; end
end.new(%w[one two three])
app = lambda { |env| [200, {'Content-Type' => 'text/plain'}, body] }
response = content_length(app).call(request)
body.closed.should.equal nil
response[2].close
body.closed.should.equal true
end
should "support single-execute bodies" do
body = Struct.new(:body) do
def each
yield body.shift until body.empty?
end
def to_ary; end
end.new(%w[one two three])
app = lambda { |env| [200, {'Content-Type' => 'text/plain'}, body] }
response = content_length(app).call(request)
expected = %w[one two three]
response[1]['Content-Length'].should.equal expected.join.size.to_s
response[2].to_enum.to_a.should.equal expected
end
end
|